misskey/src/publishers/push-sw.ts

53 lines
1.2 KiB
TypeScript
Raw Normal View History

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