egirlskey/src/push-sw.ts

62 lines
1.4 KiB
TypeScript
Raw Normal View History

import * as push from 'web-push';
2017-11-20 18:40:09 +00:00
import * as mongo from 'mongodb';
2018-07-07 10:19:00 +00:00
import Subscription from './models/sw-subscription';
import config from './config';
2018-12-19 19:08:13 +00:00
import fetchMeta from './misc/fetch-meta';
import { IMeta } from './models/meta';
2017-11-20 18:40:09 +00:00
2018-12-19 19:08:13 +00: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 18:40:09 +00:00
2018-06-18 05:28:43 +00:00
export default async function(userId: mongo.ObjectID | string, type: string, body?: any) {
2018-12-19 19:08:13 +00:00
if (!meta.enableServiceWorker) return;
2017-11-20 22:19:02 +00:00
2017-11-20 18:40:09 +00:00
if (typeof userId === 'string') {
userId = new mongo.ObjectID(userId);
}
// Fetch
const subscriptions = await Subscription.find({
2018-03-29 05:48:47 +00:00
userId: userId
2017-11-20 18:40:09 +00:00
});
for (const subscription of subscriptions) {
2017-11-20 18:40:09 +00:00
const pushSubscription = {
endpoint: subscription.endpoint,
keys: {
auth: subscription.auth,
p256dh: subscription.publickey
}
};
push.sendNotification(pushSubscription, JSON.stringify({
type, body
2018-06-18 05:28:43 +00:00
})).catch((err: any) => {
//swLogger.info(err.statusCode);
//swLogger.info(err.headers);
//swLogger.info(err.body);
2017-11-20 18:40:09 +00:00
if (err.statusCode == 410) {
Subscription.remove({
2018-03-29 05:48:47 +00:00
userId: userId,
2017-11-20 18:40:09 +00:00
endpoint: subscription.endpoint,
auth: subscription.auth,
publickey: subscription.publickey
});
}
});
}
2017-11-20 18:40:09 +00:00
}