cherrypick/src/push-sw.ts

53 lines
1.2 KiB
TypeScript
Raw Normal View History

2017-11-21 03:40:09 +09:00
const push = require('web-push');
import * as mongo from 'mongodb';
2018-07-07 19:19:00 +09:00
import Subscription from './models/sw-subscription';
import config from './config';
2017-11-21 03:40:09 +09:00
2017-11-21 07:19:02 +09:00
if (config.sw) {
// アプリケーションの連絡先と、サーバーサイドの鍵ペアの情報を登録
push.setVapidDetails(
config.url,
config.sw.public_key,
config.sw.private_key);
2017-11-21 07:19:02 +09:00
}
2017-11-21 03:40:09 +09:00
2018-06-18 14:28:43 +09:00
export default async function(userId: mongo.ObjectID | string, type: string, body?: any) {
2017-11-21 07:19:02 +09:00
if (!config.sw) return;
2017-11-21 03:40:09 +09:00
if (typeof userId === 'string') {
userId = new mongo.ObjectID(userId);
}
// Fetch
const subscriptions = await Subscription.find({
2018-03-29 14:48:47 +09:00
userId: userId
2017-11-21 03:40:09 +09:00
});
subscriptions.forEach(subscription => {
const pushSubscription = {
endpoint: subscription.endpoint,
keys: {
auth: subscription.auth,
p256dh: subscription.publickey
}
};
push.sendNotification(pushSubscription, JSON.stringify({
type, body
2018-06-18 14:28:43 +09:00
})).catch((err: any) => {
2017-11-21 03:40:09 +09:00
//console.log(err.statusCode);
//console.log(err.headers);
//console.log(err.body);
if (err.statusCode == 410) {
Subscription.remove({
2018-03-29 14:48:47 +09:00
userId: userId,
2017-11-21 03:40:09 +09:00
endpoint: subscription.endpoint,
auth: subscription.auth,
publickey: subscription.publickey
});
}
});
});
}