mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-01 23:37:43 +03:00
1421c92ba5
refs #6413 - PUT endpoint to publish a post/page for the scheduler - fn endpoint to get all scheduled posts (with from/to query params) for the scheduler - hardcoded permission handling for scheduler client - fix event bug: unscheduled - basic structure for scheduling - post scheduling basics - offer easy option to change adapter - integrate the default scheduler adapter - update scheduled posts when blog TZ changes - safety check before scheduler can publish a post (not allowed to publish in the future or past) - add force flag to allow publishing in the past - invalidate cache header for /schedules/posts/:id
100 lines
3.1 KiB
JavaScript
100 lines
3.1 KiB
JavaScript
var Promise = require('bluebird'),
|
|
moment = require('moment'),
|
|
utils = require(__dirname + '/../utils'),
|
|
events = require(__dirname + '/../../events'),
|
|
errors = require(__dirname + '/../../errors'),
|
|
models = require(__dirname + '/../../models'),
|
|
schedules = require(__dirname + '/../../api/schedules'),
|
|
_private = {};
|
|
|
|
_private.normalize = function normalize(options) {
|
|
var object = options.object,
|
|
apiUrl = options.apiUrl,
|
|
client = options.client;
|
|
|
|
return {
|
|
time: object.get('published_at'),
|
|
url: apiUrl + '/schedules/posts/' + object.get('id') + '?client_id=' + client.get('slug') + '&client_secret=' + client.get('secret'),
|
|
extra: {
|
|
httpMethod: 'PUT',
|
|
oldTime: object.updated('published_at') || null
|
|
}
|
|
};
|
|
};
|
|
|
|
_private.loadClient = function loadClient() {
|
|
return models.Client.findOne({slug: 'ghost-scheduler'}, {columns: ['slug', 'secret']});
|
|
};
|
|
|
|
_private.loadScheduledPosts = function () {
|
|
return schedules.getScheduledPosts({
|
|
from: moment().subtract(7, 'days').startOf('day').toDate(),
|
|
to: moment().endOf('day').toDate()
|
|
}).then(function (result) {
|
|
return result.posts || [];
|
|
});
|
|
};
|
|
|
|
exports.init = function init(options) {
|
|
options = options || {};
|
|
|
|
var config = options.postScheduling,
|
|
apiUrl = options.apiUrl,
|
|
adapter = null,
|
|
client = null;
|
|
|
|
if (!config) {
|
|
return Promise.reject(new errors.IncorrectUsage('post-scheduling: no config was provided'));
|
|
}
|
|
|
|
if (!apiUrl) {
|
|
return Promise.reject(new errors.IncorrectUsage('post-scheduling: no apiUrl was provided'));
|
|
}
|
|
|
|
return _private.loadClient()
|
|
.then(function (_client) {
|
|
client = _client;
|
|
|
|
return utils.createAdapter(config);
|
|
})
|
|
.then(function (_adapter) {
|
|
adapter = _adapter;
|
|
|
|
return _private.loadScheduledPosts();
|
|
})
|
|
.then(function (scheduledPosts) {
|
|
if (!scheduledPosts.length) {
|
|
return;
|
|
}
|
|
|
|
scheduledPosts.forEach(function (object) {
|
|
adapter.reschedule(_private.normalize({object: object, apiUrl: apiUrl, client: client}));
|
|
});
|
|
})
|
|
.then(function () {
|
|
adapter.run();
|
|
})
|
|
.then(function () {
|
|
events.onMany([
|
|
'post.scheduled',
|
|
'page.scheduled'
|
|
], function (object) {
|
|
adapter.schedule(_private.normalize({object: object, apiUrl: apiUrl, client: client}));
|
|
});
|
|
|
|
events.onMany([
|
|
'post.rescheduled',
|
|
'page.rescheduled'
|
|
], function (object) {
|
|
adapter.reschedule(_private.normalize({object: object, apiUrl: apiUrl, client: client}));
|
|
});
|
|
|
|
events.onMany([
|
|
'post.unscheduled',
|
|
'page.unscheduled'
|
|
], function (object) {
|
|
adapter.unschedule(_private.normalize({object: object, apiUrl: apiUrl, client: client}));
|
|
});
|
|
});
|
|
};
|