summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/messaging/messages/delete.ts
diff options
context:
space:
mode:
authorAya Morisawa <AyaMorisawa4869@gmail.com>2018-12-27 01:24:57 +0900
committerAya Morisawa <AyaMorisawa4869@gmail.com>2018-12-27 01:26:03 +0900
commit21f8dbf2deb0d766496c3503f036d07705da4238 (patch)
treea97518ef3a92dcd6d2907c1719d9ea6c168bb8b8 /src/server/api/endpoints/messaging/messages/delete.ts
parent Feature to show only my posts in the user page (#3753) (diff)
downloadsharkey-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.ts54
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();
+}));