2019-01-28 23:36:24 -06:00
|
|
|
import * as push from 'web-push';
|
2022-02-26 20:07:39 -06:00
|
|
|
import config from '@/config/index.js';
|
|
|
|
import { SwSubscriptions } from '@/models/index.js';
|
|
|
|
import { fetchMeta } from '@/misc/fetch-meta.js';
|
|
|
|
import { Packed } from '@/misc/schema.js';
|
|
|
|
import { getNoteSummary } from '@/misc/get-note-summary.js';
|
2017-11-20 12:40:09 -06:00
|
|
|
|
2020-05-22 23:19:31 -05:00
|
|
|
type notificationType = 'notification' | 'unreadMessagingMessage';
|
2021-09-22 08:35:55 -05:00
|
|
|
type notificationBody = Packed<'Notification'> | Packed<'MessagingMessage'>;
|
2020-05-22 23:19:31 -05:00
|
|
|
|
2021-12-24 11:01:35 -06:00
|
|
|
// プッシュメッセージサーバーには文字数制限があるため、内容を削減します
|
|
|
|
function truncateNotification(notification: Packed<'Notification'>): any {
|
|
|
|
if (notification.note) {
|
|
|
|
return {
|
|
|
|
...notification,
|
|
|
|
note: {
|
|
|
|
...notification.note,
|
|
|
|
// textをgetNoteSummaryしたものに置き換える
|
|
|
|
text: getNoteSummary(notification.type === 'renote' ? notification.note.renote as Packed<'Note'> : notification.note),
|
|
|
|
...{
|
|
|
|
cw: undefined,
|
|
|
|
reply: undefined,
|
|
|
|
renote: undefined,
|
|
|
|
user: undefined as any, // 通知を受け取ったユーザーである場合が多いのでこれも捨てる
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return notification;
|
|
|
|
}
|
|
|
|
|
2020-05-22 23:19:31 -05:00
|
|
|
export default async function(userId: string, type: notificationType, body: notificationBody) {
|
2019-04-12 11:43:22 -05:00
|
|
|
const meta = await fetchMeta();
|
2018-12-19 13:08:13 -06:00
|
|
|
|
2019-04-12 11:43:22 -05:00
|
|
|
if (!meta.enableServiceWorker || meta.swPublicKey == null || meta.swPrivateKey == null) return;
|
2017-11-20 12:40:09 -06:00
|
|
|
|
2019-04-12 11:43:22 -05:00
|
|
|
// アプリケーションの連絡先と、サーバーサイドの鍵ペアの情報を登録
|
|
|
|
push.setVapidDetails(config.url,
|
|
|
|
meta.swPublicKey,
|
|
|
|
meta.swPrivateKey);
|
2017-11-20 16:19:02 -06:00
|
|
|
|
2017-11-20 12:40:09 -06:00
|
|
|
// Fetch
|
2019-04-07 07:50:36 -05:00
|
|
|
const subscriptions = await SwSubscriptions.find({
|
2021-12-09 08:58:30 -06:00
|
|
|
userId: userId,
|
2017-11-20 12:40:09 -06:00
|
|
|
});
|
|
|
|
|
2018-12-11 05:36:55 -06:00
|
|
|
for (const subscription of subscriptions) {
|
2017-11-20 12:40:09 -06:00
|
|
|
const pushSubscription = {
|
|
|
|
endpoint: subscription.endpoint,
|
|
|
|
keys: {
|
|
|
|
auth: subscription.auth,
|
2021-12-09 08:58:30 -06:00
|
|
|
p256dh: subscription.publickey,
|
|
|
|
},
|
2017-11-20 12:40:09 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
push.sendNotification(pushSubscription, JSON.stringify({
|
2021-12-24 11:01:35 -06:00
|
|
|
type,
|
|
|
|
body: type === 'notification' ? truncateNotification(body as Packed<'Notification'>) : body,
|
|
|
|
userId,
|
2019-10-13 11:53:28 -05:00
|
|
|
}), {
|
2021-12-09 08:58:30 -06:00
|
|
|
proxy: config.proxy,
|
2019-10-13 11:53:28 -05:00
|
|
|
}).catch((err: any) => {
|
2019-02-03 03:16:57 -06:00
|
|
|
//swLogger.info(err.statusCode);
|
|
|
|
//swLogger.info(err.headers);
|
|
|
|
//swLogger.info(err.body);
|
2017-11-20 12:40:09 -06:00
|
|
|
|
2020-04-03 18:46:54 -05:00
|
|
|
if (err.statusCode === 410) {
|
2019-04-07 07:50:36 -05:00
|
|
|
SwSubscriptions.delete({
|
2018-03-29 00:48:47 -05:00
|
|
|
userId: userId,
|
2017-11-20 12:40:09 -06:00
|
|
|
endpoint: subscription.endpoint,
|
|
|
|
auth: subscription.auth,
|
2021-12-09 08:58:30 -06:00
|
|
|
publickey: subscription.publickey,
|
2017-11-20 12:40:09 -06:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2018-12-11 05:36:55 -06:00
|
|
|
}
|
2017-11-20 12:40:09 -06:00
|
|
|
}
|