summaryrefslogtreecommitdiff
path: root/src/models/repositories/notification.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2020-03-28 18:07:41 +0900
committersyuilo <syuilotan@yahoo.co.jp>2020-03-28 18:07:41 +0900
commit614a1d74ddf388dcb82f69722c96696ad530602d (patch)
treefaf2d14d1d82ea321080ebb677d8c402460c9a5b /src/models/repositories/notification.ts
parentAdd i/apps private API (diff)
downloadmisskey-614a1d74ddf388dcb82f69722c96696ad530602d.tar.gz
misskey-614a1d74ddf388dcb82f69722c96696ad530602d.tar.bz2
misskey-614a1d74ddf388dcb82f69722c96696ad530602d.zip
Resolve #6192
Diffstat (limited to 'src/models/repositories/notification.ts')
-rw-r--r--src/models/repositories/notification.ts10
1 files changed, 8 insertions, 2 deletions
diff --git a/src/models/repositories/notification.ts b/src/models/repositories/notification.ts
index f020714f80..a8978cc01b 100644
--- a/src/models/repositories/notification.ts
+++ b/src/models/repositories/notification.ts
@@ -1,5 +1,5 @@
import { EntityRepository, Repository } from 'typeorm';
-import { Users, Notes, UserGroupInvitations } from '..';
+import { Users, Notes, UserGroupInvitations, AccessTokens } from '..';
import { Notification } from '../entities/notification';
import { ensure } from '../../prelude/ensure';
import { awaitAll } from '../../prelude/await-all';
@@ -13,13 +13,14 @@ export class NotificationRepository extends Repository<Notification> {
src: Notification['id'] | Notification,
): Promise<PackedNotification> {
const notification = typeof src === 'object' ? src : await this.findOne(src).then(ensure);
+ const token = notification.appAccessTokenId ? await AccessTokens.findOne(notification.appAccessTokenId).then(ensure) : null;
return await awaitAll({
id: notification.id,
createdAt: notification.createdAt.toISOString(),
type: notification.type,
userId: notification.notifierId,
- user: Users.pack(notification.notifier || notification.notifierId),
+ user: notification.notifierId ? Users.pack(notification.notifier || notification.notifierId) : null,
...(notification.type === 'mention' ? {
note: Notes.pack(notification.note || notification.noteId!, notification.notifieeId),
} : {}),
@@ -43,6 +44,11 @@ export class NotificationRepository extends Repository<Notification> {
...(notification.type === 'groupInvited' ? {
invitation: UserGroupInvitations.pack(notification.userGroupInvitationId!),
} : {}),
+ ...(notification.type === 'app' ? {
+ body: notification.customBody,
+ header: notification.customHeader || token!.name,
+ icon: notification.customIcon || token!.iconUrl,
+ } : {}),
});
}