diff options
| author | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-12-27 01:24:57 +0900 |
|---|---|---|
| committer | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-12-27 01:26:03 +0900 |
| commit | 21f8dbf2deb0d766496c3503f036d07705da4238 (patch) | |
| tree | a97518ef3a92dcd6d2907c1719d9ea6c168bb8b8 /src/server/api/endpoints/messaging/messages/delete.ts | |
| parent | Feature to show only my posts in the user page (#3753) (diff) | |
| download | sharkey-21f8dbf2deb0d766496c3503f036d07705da4238.tar.gz sharkey-21f8dbf2deb0d766496c3503f036d07705da4238.tar.bz2 sharkey-21f8dbf2deb0d766496c3503f036d07705da4238.zip | |
Resolve #3248
Co-authored-by: syuilo <syuilotan@yahoo.co.jp>
Diffstat (limited to 'src/server/api/endpoints/messaging/messages/delete.ts')
| -rw-r--r-- | src/server/api/endpoints/messaging/messages/delete.ts | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/server/api/endpoints/messaging/messages/delete.ts b/src/server/api/endpoints/messaging/messages/delete.ts new file mode 100644 index 0000000000..dc9bb51b91 --- /dev/null +++ b/src/server/api/endpoints/messaging/messages/delete.ts @@ -0,0 +1,54 @@ + +import $ from 'cafy'; import ID, { transform } from '../../../../../misc/cafy-id'; +import Message from '../../../../../models/messaging-message'; +import define from '../../../define'; +import { publishMessagingStream } from '../../../../../stream'; +const ms = require('ms'); + +export const meta = { + stability: 'stable', + + desc: { + 'ja-JP': '指定したメッセージを削除します。', + 'en-US': 'Delete a message.' + }, + + requireCredential: true, + + kind: 'messaging-write', + + limit: { + duration: ms('1hour'), + max: 300, + minInterval: ms('1sec') + }, + + params: { + messageId: { + validator: $.type(ID), + transform: transform, + desc: { + 'ja-JP': '対象のメッセージのID', + 'en-US': 'Target message ID.' + } + } + } +}; + +export default define(meta, (ps, user) => new Promise(async (res, rej) => { + const message = await Message.findOne({ + _id: ps.messageId, + userId: user._id + }); + + if (message === null) { + return rej('message not found'); + } + + await Message.remove({ _id: message._id }); + + publishMessagingStream(message.userId, message.recipientId, 'deleted', message._id); + publishMessagingStream(message.recipientId, message.userId, 'deleted', message._id); + + res(); +})); |