misskey/src/services/push-notification.ts

62 lines
1.4 KiB
TypeScript
Raw Normal View History

import * as push from 'web-push';
2017-11-20 19:40:09 +01:00
import * as mongo from 'mongodb';
2019-02-05 06:14:23 +01:00
import Subscription from '../models/sw-subscription';
import config from '../config';
import fetchMeta from '../misc/fetch-meta';
import { IMeta } from '../models/meta';
2017-11-20 19:40:09 +01:00
2018-12-19 20:08:13 +01:00
let meta: IMeta = null;
setInterval(() => {
fetchMeta().then(m => {
meta = m;
if (meta.enableServiceWorker) {
// アプリケーションの連絡先と、サーバーサイドの鍵ペアの情報を登録
push.setVapidDetails(config.url,
meta.swPublicKey,
meta.swPrivateKey);
}
});
}, 3000);
2017-11-20 19:40:09 +01:00
2018-06-18 07:28:43 +02:00
export default async function(userId: mongo.ObjectID | string, type: string, body?: any) {
2018-12-19 20:08:13 +01:00
if (!meta.enableServiceWorker) return;
2017-11-20 23:19:02 +01:00
2017-11-20 19:40:09 +01:00
if (typeof userId === 'string') {
userId = new mongo.ObjectID(userId);
}
// Fetch
const subscriptions = await Subscription.find({
2018-03-29 07:48:47 +02:00
userId: userId
2017-11-20 19:40:09 +01:00
});
for (const subscription of subscriptions) {
2017-11-20 19:40:09 +01:00
const pushSubscription = {
endpoint: subscription.endpoint,
keys: {
auth: subscription.auth,
p256dh: subscription.publickey
}
};
push.sendNotification(pushSubscription, JSON.stringify({
type, body
2018-06-18 07:28:43 +02:00
})).catch((err: any) => {
//swLogger.info(err.statusCode);
//swLogger.info(err.headers);
//swLogger.info(err.body);
2017-11-20 19:40:09 +01:00
if (err.statusCode == 410) {
Subscription.remove({
2018-03-29 07:48:47 +02:00
userId: userId,
2017-11-20 19:40:09 +01:00
endpoint: subscription.endpoint,
auth: subscription.auth,
publickey: subscription.publickey
});
}
});
}
2017-11-20 19:40:09 +01:00
}