Files
kami-parse-server/src/pushStatusHandler.js

121 lines
3.3 KiB
JavaScript
Raw Normal View History

import { md5Hash, newObjectId } from './cryptoUtils';
import { logger } from './logger';
2016-03-13 23:34:44 -04:00
export function flatten(array) {
return array.reduce((memo, element) => {
if (Array.isArray(element)) {
memo = memo.concat(flatten(element));
} else {
memo = memo.concat(element);
}
return memo;
}, []);
}
2016-03-13 23:34:44 -04:00
export default function pushStatusHandler(config) {
let initialPromise;
let pushStatus;
let objectId = newObjectId();
let collection = function() {
return config.database.adaptiveCollection('_PushStatus');
}
let setInitial = function(body = {}, where, options = {source: 'rest'}) {
let now = new Date();
let data = body.data || {};
2016-03-13 23:34:44 -04:00
let object = {
objectId,
pushTime: now.toISOString(),
_created_at: now,
2016-03-13 23:34:44 -04:00
query: JSON.stringify(where),
payload: body.data,
source: options.source,
title: options.title,
expiry: body.expiration_time,
status: "pending",
numSent: 0,
pushHash: md5Hash(JSON.stringify(data)),
// lockdown!
_wperm: [],
_rperm: []
2016-03-13 23:34:44 -04:00
}
initialPromise = collection().then((collection) => {
return collection.insertOne(object);
}).then((res) => {
pushStatus = {
objectId: object.objectId
};
2016-03-13 23:34:44 -04:00
return Promise.resolve(pushStatus);
})
2016-03-13 23:34:44 -04:00
return initialPromise;
}
let setRunning = function(installations) {
logger.verbose('sending push to %d installations', installations.length);
2016-03-13 23:34:44 -04:00
return initialPromise.then(() => {
return collection();
}).then((collection) => {
return collection.updateOne({status:"pending", objectId: pushStatus.objectId}, {$set: {status: "running"}});
});
2016-03-13 23:34:44 -04:00
}
let complete = function(results) {
let update = {
status: 'succeeded',
numSent: 0,
numFailed: 0,
};
if (Array.isArray(results)) {
results = flatten(results);
2016-03-13 23:34:44 -04:00
results.reduce((memo, result) => {
// Cannot handle that
if (!result.device || !result.device.deviceType) {
return memo;
}
let deviceType = result.device.deviceType;
if (result.transmitted)
{
memo.numSent++;
memo.sentPerType = memo.sentPerType || {};
memo.sentPerType[deviceType] = memo.sentPerType[deviceType] || 0;
memo.sentPerType[deviceType]++;
} else {
memo.numFailed++;
memo.failedPerType = memo.failedPerType || {};
memo.failedPerType[deviceType] = memo.failedPerType[deviceType] || 0;
memo.failedPerType[deviceType]++;
}
return memo;
}, update);
}
logger.verbose('sent push! %d success, %d failures', update.numSent, update.numFailed);
2016-03-13 23:34:44 -04:00
return initialPromise.then(() => {
return collection();
}).then((collection) => {
return collection.updateOne({status:"running", objectId: pushStatus.objectId}, {$set: update});
});
2016-03-13 23:34:44 -04:00
}
let fail = function(err) {
let update = {
errorMessage: JSON.stringify(err),
status: 'failed'
}
logger.error('error while sending push', err);
return initialPromise.then(() => {
return collection();
}).then((collection) => {
return collection.updateOne({objectId: pushStatus.objectId}, {$set: update});
});
}
2016-03-13 23:34:44 -04:00
return Object.freeze({
objectId,
2016-03-13 23:34:44 -04:00
setInitial,
setRunning,
complete,
fail
2016-03-13 23:34:44 -04:00
})
}