123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- import async from "async";
- import CoreClass from "../core";
- let DBModule;
- let UtilsModule;
- let IOModule;
- class _ActivitiesModule extends CoreClass {
-
- constructor() {
- super("activities");
-
- }
-
- initialize() {
- return new Promise(resolve => {
- DBModule = this.moduleManager.modules.db;
- UtilsModule = this.moduleManager.modules.utils;
- IOModule = this.moduleManager.modules.io;
- resolve();
- });
- }
-
-
- ADD_ACTIVITY(payload) {
- return new Promise((resolve, reject) => {
- async.waterfall(
- [
- next => {
- DBModule.runJob("GET_MODEL", { modelName: "activity" }, this)
- .then(res => next(null, res))
- .catch(next);
- },
- (ActivityModel, next) => {
- const activity = new ActivityModel({
- userId: payload.userId,
- activityType: payload.activityType,
- payload: payload.payload
- });
- activity.save((err, activity) => {
- if (err) return next(err);
- return next(null, activity);
- });
- },
- (activity, next) => {
- IOModule.runJob(
- "SOCKETS_FROM_USER",
- {
- userId: activity.userId
- },
- this
- )
- .then(response => {
- response.sockets.forEach(socket => {
- socket.emit("event:activity.create", activity);
- });
- next();
- })
- .catch(next);
- }
- ],
- async (err, activity) => {
- if (err) {
- err = await UtilsModule.runJob(
- "GET_ERROR",
- {
- error: err
- },
- this
- );
- reject(new Error(err));
- } else {
- resolve({ activity });
- }
- }
- );
- });
- }
- }
- export default new _ActivitiesModule();
|