sharkey/src/common/notify.ts

51 lines
1.4 KiB
TypeScript
Raw Normal View History

2016-12-29 07:49:51 +09:00
import * as mongo from 'mongodb';
2018-04-01 19:43:26 +09:00
import Notification from '../models/notification';
import Mute from '../models/mute';
import event from './event';
import { pack } from '../models/notification';
2016-12-29 07:49:51 +09:00
export default (
notifiee: mongo.ObjectID,
notifier: mongo.ObjectID,
type: string,
2017-03-05 12:09:34 +09:00
content?: any
2016-12-29 07:49:51 +09:00
) => new Promise<any>(async (resolve, reject) => {
if (notifiee.equals(notifier)) {
return resolve();
}
// Create notification
2017-01-18 05:28:12 +09:00
const notification = await Notification.insert(Object.assign({
2018-03-29 14:48:47 +09:00
createdAt: new Date(),
notifieeId: notifiee,
notifierId: notifier,
2016-12-29 07:49:51 +09:00
type: type,
2018-03-29 14:48:47 +09:00
isRead: false
2016-12-29 07:49:51 +09:00
}, content));
resolve(notification);
// Publish notification event
event(notifiee, 'notification',
2018-02-02 08:21:30 +09:00
await pack(notification));
2017-11-20 09:09:11 +09:00
// 3秒経っても(今回作成した)通知が既読にならなかったら「未読の通知がありますよ」イベントを発行する
setTimeout(async () => {
2018-03-29 14:48:47 +09:00
const fresh = await Notification.findOne({ _id: notification._id }, { isRead: true });
if (!fresh.isRead) {
2017-12-22 07:38:57 +09:00
//#region ただしミュートしているユーザーからの通知なら無視
const mute = await Mute.find({
2018-03-29 14:48:47 +09:00
muterId: notifiee,
deletedAt: { $exists: false }
2017-12-22 07:38:57 +09:00
});
2018-03-29 14:48:47 +09:00
const mutedUserIds = mute.map(m => m.muteeId.toString());
2017-12-22 07:43:56 +09:00
if (mutedUserIds.indexOf(notifier.toString()) != -1) {
2017-12-22 07:38:57 +09:00
return;
}
//#endregion
2018-02-02 08:21:30 +09:00
event(notifiee, 'unread_notification', await pack(notification));
2017-11-20 09:09:11 +09:00
}
}, 3000);
2016-12-29 07:49:51 +09:00
});