ensl_gathers/lib/gather/gather_pool.js

116 lines
2.6 KiB
JavaScript
Raw Normal View History

2016-03-19 13:31:30 +00:00
"use strict"
/*
* Implements a pool of concurrent gathers
* (no longer a singleton class, should rename)
*
*/
const _ = require("lodash");
const Gather = require("./gather");
const winston = require("winston");
const mongoose = require("mongoose");
const ArchivedGather = mongoose.model("ArchivedGather");
const InvitationalGather = require("./invitational_gather");
2016-03-19 13:31:30 +00:00
let gatherCallbacks = {};
let archiveUpdatedCallback = () => {};
const GatherPool = new Map();
const GATHER_CONFIGS = [
{
2016-04-01 12:32:46 +00:00
type: "classic",
name: "Classic Gather",
description: "No Requirements"
2016-03-19 13:31:30 +00:00
}
2016-11-07 09:51:32 +00:00
// {
2017-07-02 13:48:00 +00:00
// type: "invitational",
// name: "Invitational Gather",
// description: "Join on ensl.org/teams/949",
// // Grant invite if on list
// membershipTest: function (user) {
// return InvitationalGather.list.some(m => m.id === user.id);
// }
// }
// {
2016-11-07 09:51:32 +00:00
// type: "casual",
// name: "Casual Gather",
// description: "No Requirements",
// teamSize: 7
// }
2016-03-19 13:31:30 +00:00
];
GATHER_CONFIGS.forEach(config => {
const gatherManager = {
type: config.type,
name: config.name,
registerCallback: function (type, method) {
if (this.gatherCallbacks[type]) {
this.gatherCallbacks[type].push(method);
} else {
this.gatherCallbacks[type] = [method];
}
},
onArchiveUpdate: function (callback) {
archiveUpdatedCallback = callback;
},
restart: function () {
this.previousGather = undefined;
this.current = undefined;
return newGather();
},
reset: function () {
return newGather();
},
current: Gather(),
previous: undefined,
gatherCallbacks: {}
};
gatherManager.gatherCallbacks['onDone'] = [function () {
rotateGather();
}];
const newGather = () => {
const newGatherConfig = _.clone(config);
newGatherConfig.onEvent = function () {
gatherManager.gatherCallbacks['onEvent'].forEach(cb => {
cb.apply(this, [].slice.call(arguments))
});
};
newGatherConfig.onDone = function () {
gatherManager.gatherCallbacks['onDone'].forEach(cb => {
cb.apply(this, [].slice.call(arguments))
});
};
return gatherManager.current = Gather(newGatherConfig);
};
const archiveGather = gather => {
ArchivedGather.archive(gather, (error, result) => {
if (error) return winston.error(error);
if (archiveUpdatedCallback
&& typeof archiveUpdatedCallback === 'function') {
archiveUpdatedCallback();
}
});
};
const rotateGather = () => {
if (gatherManager.current) {
gatherManager.previous = gatherManager.current;
archiveGather(gatherManager.previous);
}
return newGather();
};
GatherPool.set(config.type, gatherManager)
});
// Register initial callback to reset gather when state is `done`
module.exports = GatherPool;