diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2021-10-31 20:21:50 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2021-10-31 20:21:50 +0900 |
| commit | 54631026de9edb28c842f612a37511f82f1f749e (patch) | |
| tree | 885c7f28b9756899faf3a99842d008be8953903e /src/server/api/endpoints/notes/thread-muting/delete.ts | |
| parent | Merge branch 'develop' (diff) | |
| parent | 12.95.0 (diff) | |
| download | misskey-54631026de9edb28c842f612a37511f82f1f749e.tar.gz misskey-54631026de9edb28c842f612a37511f82f1f749e.tar.bz2 misskey-54631026de9edb28c842f612a37511f82f1f749e.zip | |
Merge branch 'develop'
Diffstat (limited to 'src/server/api/endpoints/notes/thread-muting/delete.ts')
| -rw-r--r-- | src/server/api/endpoints/notes/thread-muting/delete.ts | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/server/api/endpoints/notes/thread-muting/delete.ts b/src/server/api/endpoints/notes/thread-muting/delete.ts new file mode 100644 index 0000000000..05d5691870 --- /dev/null +++ b/src/server/api/endpoints/notes/thread-muting/delete.ts @@ -0,0 +1,40 @@ +import $ from 'cafy'; +import { ID } from '@/misc/cafy-id'; +import define from '../../../define'; +import { getNote } from '../../../common/getters'; +import { ApiError } from '../../../error'; +import { NoteThreadMutings } from '@/models'; + +export const meta = { + tags: ['notes'], + + requireCredential: true as const, + + kind: 'write:account', + + params: { + noteId: { + validator: $.type(ID), + } + }, + + errors: { + noSuchNote: { + message: 'No such note.', + code: 'NO_SUCH_NOTE', + id: 'bddd57ac-ceb3-b29d-4334-86ea5fae481a' + } + } +}; + +export default define(meta, async (ps, user) => { + const note = await getNote(ps.noteId).catch(e => { + if (e.id === '9725d0ce-ba28-4dde-95a7-2cbb2c15de24') throw new ApiError(meta.errors.noSuchNote); + throw e; + }); + + await NoteThreadMutings.delete({ + threadId: note.threadId || note.id, + userId: user.id, + }); +}); |