yumechi-no-kuni/src/server/api/endpoints/i/notifications.ts

107 lines
2.4 KiB
TypeScript
Raw Normal View History

2016-12-28 16:49:51 -06:00
/**
* Module dependencies
*/
2017-03-08 12:50:09 -06:00
import $ from 'cafy';
2018-03-29 06:32:18 -05:00
import Notification from '../../../../models/notification';
import Mute from '../../../../models/mute';
import { pack } from '../../../../models/notification';
2016-12-28 16:49:51 -06:00
import getFriends from '../../common/get-friends';
import read from '../../common/read-notification';
2016-12-28 16:49:51 -06:00
/**
* Get notifications
*/
2017-03-03 13:28:38 -06:00
module.exports = (params, user) => new Promise(async (res, rej) => {
2016-12-28 16:49:51 -06:00
// Get 'following' parameter
2017-03-04 21:00:39 -06:00
const [following = false, followingError] =
2017-03-08 12:50:09 -06:00
$(params.following).optional.boolean().$;
2017-03-02 17:56:07 -06:00
if (followingError) return rej('invalid following param');
2016-12-28 16:49:51 -06:00
2018-03-29 00:48:47 -05:00
// Get 'markAsRead' parameter
const [markAsRead = true, markAsReadErr] = $(params.markAsRead).optional.boolean().$;
if (markAsReadErr) return rej('invalid markAsRead param');
2016-12-28 16:49:51 -06:00
// Get 'type' parameter
2017-03-08 12:50:09 -06:00
const [type, typeErr] = $(params.type).optional.array('string').unique().$;
2017-03-02 17:56:07 -06:00
if (typeErr) return rej('invalid type param');
2016-12-28 16:49:51 -06:00
// Get 'limit' parameter
2017-03-08 12:50:09 -06:00
const [limit = 10, limitErr] = $(params.limit).optional.number().range(1, 100).$;
2017-03-02 17:56:07 -06:00
if (limitErr) return rej('invalid limit param');
2016-12-28 16:49:51 -06:00
2018-03-29 00:48:47 -05:00
// Get 'sinceId' parameter
const [sinceId, sinceIdErr] = $(params.sinceId).optional.id().$;
if (sinceIdErr) return rej('invalid sinceId param');
2017-03-02 17:56:07 -06:00
2018-03-29 00:48:47 -05:00
// Get 'untilId' parameter
const [untilId, untilIdErr] = $(params.untilId).optional.id().$;
if (untilIdErr) return rej('invalid untilId param');
2016-12-28 16:49:51 -06:00
2018-03-29 00:48:47 -05:00
// Check if both of sinceId and untilId is specified
2017-12-20 11:20:02 -06:00
if (sinceId && untilId) {
2018-03-29 00:48:47 -05:00
return rej('cannot set sinceId and untilId');
2016-12-28 16:49:51 -06:00
}
2017-12-21 16:26:23 -06:00
const mute = await Mute.find({
2018-03-29 00:48:47 -05:00
muterId: user._id,
deletedAt: { $exists: false }
2017-12-21 16:26:23 -06:00
});
2016-12-28 16:49:51 -06:00
const query = {
2018-03-29 00:48:47 -05:00
notifieeId: user._id,
2017-12-21 16:26:23 -06:00
$and: [{
2018-03-29 00:48:47 -05:00
notifierId: {
$nin: mute.map(m => m.muteeId)
2017-12-21 16:26:23 -06:00
}
}]
2017-03-02 17:56:07 -06:00
} as any;
2016-12-28 16:49:51 -06:00
const sort = {
_id: -1
};
if (following) {
2017-12-21 16:26:23 -06:00
// ID list of the user itself and other users who the user follows
2016-12-28 16:49:51 -06:00
const followingIds = await getFriends(user._id);
2017-12-21 16:26:23 -06:00
query.$and.push({
2018-03-29 00:48:47 -05:00
notifierId: {
2017-12-21 16:26:23 -06:00
$in: followingIds
}
});
2016-12-28 16:49:51 -06:00
}
if (type) {
query.type = {
$in: type
};
}
2017-03-02 17:56:07 -06:00
if (sinceId) {
2016-12-28 16:49:51 -06:00
sort._id = 1;
query._id = {
2017-03-02 17:56:07 -06:00
$gt: sinceId
2016-12-28 16:49:51 -06:00
};
2017-12-20 11:20:02 -06:00
} else if (untilId) {
2016-12-28 16:49:51 -06:00
query._id = {
2017-12-20 11:20:02 -06:00
$lt: untilId
2016-12-28 16:49:51 -06:00
};
}
// Issue query
const notifications = await Notification
2017-01-16 20:11:22 -06:00
.find(query, {
2016-12-28 16:49:51 -06:00
limit: limit,
sort: sort
2017-01-16 20:11:22 -06:00
});
2016-12-28 16:49:51 -06:00
// Serialize
res(await Promise.all(notifications.map(async notification =>
2018-02-01 17:21:30 -06:00
await pack(notification))));
2016-12-28 16:49:51 -06:00
// Mark as read all
if (notifications.length > 0 && markAsRead) {
read(user._id, notifications);
2016-12-28 16:49:51 -06:00
}
});