2016-06-23 17:24:58 +09:00
|
|
|
import Newsletter from '../namespace.js';
|
2016-06-28 17:33:30 +09:00
|
|
|
import moment from 'moment';
|
2016-04-05 11:03:53 +09:00
|
|
|
|
2016-07-07 12:49:57 +09:00
|
|
|
const defaultFrequency = [1]; // every monday
|
|
|
|
const defaultTime = '00:00'; // GMT
|
|
|
|
|
2015-04-22 07:50:11 +09:00
|
|
|
SyncedCron.options = {
|
2016-06-28 17:33:30 +09:00
|
|
|
log: true,
|
2015-04-22 07:50:11 +09:00
|
|
|
collectionName: 'cronHistory',
|
|
|
|
utc: false,
|
|
|
|
collectionTTL: 172800
|
2015-05-01 18:22:00 +02:00
|
|
|
};
|
2015-04-22 07:50:11 +09:00
|
|
|
|
2016-06-28 17:33:30 +09:00
|
|
|
const addZero = num => {
|
|
|
|
return num < 10 ? "0"+num : num;
|
|
|
|
};
|
|
|
|
|
2015-04-22 07:50:11 +09:00
|
|
|
var getSchedule = function (parser) {
|
2016-02-17 20:44:52 +09:00
|
|
|
var frequency = Telescope.settings.get('newsletterFrequency', defaultFrequency);
|
2015-04-22 07:50:11 +09:00
|
|
|
var recur = parser.recur();
|
|
|
|
var schedule;
|
|
|
|
|
2015-06-23 22:40:43 -04:00
|
|
|
// Default is once a week (Mondays)
|
|
|
|
if (!!frequency) {
|
|
|
|
schedule = recur.on(frequency).dayOfWeek();
|
2015-04-22 07:50:11 +09:00
|
|
|
}
|
2015-06-23 22:40:43 -04:00
|
|
|
else {
|
|
|
|
schedule = recur.on(2).dayOfWeek();
|
|
|
|
}
|
|
|
|
|
2016-06-28 17:33:30 +09:00
|
|
|
const offsetInMinutes = new Date().getTimezoneOffset();
|
|
|
|
const GMTtime = moment.duration(Telescope.settings.get('newsletterTime', defaultTime));
|
|
|
|
const serverTime = GMTtime.subtract(offsetInMinutes, "minutes");
|
|
|
|
const serverTimeString = addZero(serverTime.hours()) + ":" + addZero(serverTime.minutes());
|
|
|
|
|
2016-07-19 15:13:16 +09:00
|
|
|
// console.log("// scheduled for: (GMT): "+Telescope.settings.get('newsletterTime', defaultTime));
|
|
|
|
// console.log("// server offset (minutes): "+offsetInMinutes);
|
|
|
|
// console.log("// server scheduled time (minutes): "+serverTime.asMinutes());
|
|
|
|
// console.log("// server scheduled time: "+serverTimeString);
|
2016-06-28 17:33:30 +09:00
|
|
|
|
|
|
|
return schedule.on(serverTimeString).time();
|
2015-05-01 18:22:00 +02:00
|
|
|
};
|
2015-04-22 07:50:11 +09:00
|
|
|
|
|
|
|
Meteor.methods({
|
|
|
|
getNextJob: function () {
|
|
|
|
var nextJob = SyncedCron.nextScheduledAtDate('scheduleNewsletter');
|
|
|
|
console.log(nextJob);
|
|
|
|
return nextJob;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var addJob = function () {
|
|
|
|
SyncedCron.add({
|
|
|
|
name: 'scheduleNewsletter',
|
|
|
|
schedule: function(parser) {
|
|
|
|
// parser is a later.parse object
|
|
|
|
return getSchedule(parser);
|
|
|
|
},
|
|
|
|
job: function() {
|
2015-10-13 10:00:29 +09:00
|
|
|
// only schedule newsletter campaigns in production
|
2016-06-28 17:33:30 +09:00
|
|
|
if (process.env.NODE_ENV === "production" || Telescope.settings.get("enableNewsletterInDev", false)) {
|
|
|
|
console.log("// Scheduling newsletter…")
|
|
|
|
console.log(new Date());
|
2016-06-23 17:24:58 +09:00
|
|
|
Newsletter.scheduleNextWithMailChimp();
|
2015-10-13 10:00:29 +09:00
|
|
|
}
|
2015-04-22 07:50:11 +09:00
|
|
|
}
|
|
|
|
});
|
2015-05-01 18:22:00 +02:00
|
|
|
};
|
2016-04-05 11:03:53 +09:00
|
|
|
|
2015-04-22 07:50:11 +09:00
|
|
|
Meteor.startup(function () {
|
2016-03-30 09:10:12 +09:00
|
|
|
if (Telescope.settings.get('enableNewsletter', true) && Telescope.settings.get('mailChimpAPIKey') && Telescope.settings.get('mailChimpListId')) {
|
2015-04-22 07:50:11 +09:00
|
|
|
addJob();
|
|
|
|
}
|
|
|
|
});
|