api/notifications/readは配列で受け付けるように
This commit is contained in:
parent
6d1d7b5366
commit
c4503aa6b2
1 changed files with 14 additions and 27 deletions
|
@ -1,42 +1,29 @@
|
||||||
import $ from 'cafy';
|
import $ from 'cafy';
|
||||||
import { ID } from '@/misc/cafy-id';
|
import { ID } from '@/misc/cafy-id';
|
||||||
import { publishMainStream } from '../../../../services/stream';
|
|
||||||
import define from '../../define';
|
import define from '../../define';
|
||||||
import { Notifications } from '../../../../models';
|
|
||||||
import { readNotification } from '../../common/read-notification';
|
import { readNotification } from '../../common/read-notification';
|
||||||
import { ApiError } from '../../error';
|
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
|
desc: {
|
||||||
|
'ja-JP': '通知を既読にします。',
|
||||||
|
'en-US': 'Mark a notification as read.'
|
||||||
|
},
|
||||||
|
|
||||||
tags: ['notifications', 'account'],
|
tags: ['notifications', 'account'],
|
||||||
|
|
||||||
requireCredential: true as const,
|
requireCredential: true as const,
|
||||||
|
|
||||||
kind: 'write:notifications',
|
|
||||||
|
|
||||||
params: {
|
params: {
|
||||||
notificationId: {
|
notificationIds: {
|
||||||
validator: $.type(ID),
|
validator: $.arr($.type(ID)),
|
||||||
},
|
desc: {
|
||||||
|
'ja-JP': '対象の通知のIDの配列',
|
||||||
|
'en-US': 'Target notification IDs.'
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
errors: {
|
kind: 'write:notifications'
|
||||||
noSuchNotification: {
|
|
||||||
message: 'No such notification.',
|
|
||||||
code: 'NO_SUCH_NOTIFICATION',
|
|
||||||
id: 'efa929d5-05b5-47d1-beec-e6a4dbed011e'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export default define(meta, async (ps, user) => {
|
export default define(meta, async (ps, user) => readNotification(user.id, ps.notificationIds));
|
||||||
const notification = await Notifications.findOne({
|
|
||||||
notifieeId: user.id,
|
|
||||||
id: ps.notificationId,
|
|
||||||
});
|
|
||||||
|
|
||||||
if (notification == null) {
|
|
||||||
throw new ApiError(meta.errors.noSuchNotification);
|
|
||||||
}
|
|
||||||
|
|
||||||
readNotification(user.id, [notification.id]);
|
|
||||||
});
|
|
||||||
|
|
Loading…
Reference in a new issue