summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/messaging/messages
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-02-15 13:06:06 +0900
committerGitHub <noreply@github.com>2023-02-15 13:06:06 +0900
commit8f2049bcd261c3fb10afdc8c15cf4edffe1baa71 (patch)
treedc5aa1cefc24d3f6eb36bb1723d7433f8a19e5a2 /packages/backend/src/server/api/endpoints/messaging/messages
parentMerge branch 'develop' of https://github.com/misskey-dev/misskey into develop (diff)
downloadmisskey-8f2049bcd261c3fb10afdc8c15cf4edffe1baa71.tar.gz
misskey-8f2049bcd261c3fb10afdc8c15cf4edffe1baa71.tar.bz2
misskey-8f2049bcd261c3fb10afdc8c15cf4edffe1baa71.zip
drop messaging (#9919)
* drop messaging (from backend) * wip
Diffstat (limited to 'packages/backend/src/server/api/endpoints/messaging/messages')
-rw-r--r--packages/backend/src/server/api/endpoints/messaging/messages/create.ts179
-rw-r--r--packages/backend/src/server/api/endpoints/messaging/messages/delete.ts61
-rw-r--r--packages/backend/src/server/api/endpoints/messaging/messages/read.ts61
3 files changed, 0 insertions, 301 deletions
diff --git a/packages/backend/src/server/api/endpoints/messaging/messages/create.ts b/packages/backend/src/server/api/endpoints/messaging/messages/create.ts
deleted file mode 100644
index e9ffc7a9eb..0000000000
--- a/packages/backend/src/server/api/endpoints/messaging/messages/create.ts
+++ /dev/null
@@ -1,179 +0,0 @@
-import { Inject, Injectable } from '@nestjs/common';
-import ms from 'ms';
-import { Endpoint } from '@/server/api/endpoint-base.js';
-import type { BlockingsRepository, UserGroupJoiningsRepository, DriveFilesRepository, UserGroupsRepository } from '@/models/index.js';
-import type { User } from '@/models/entities/User.js';
-import type { UserGroup } from '@/models/entities/UserGroup.js';
-import { GetterService } from '@/server/api/GetterService.js';
-import { MessagingService } from '@/core/MessagingService.js';
-import { DI } from '@/di-symbols.js';
-import { ApiError } from '../../../error.js';
-
-export const meta = {
- tags: ['messaging'],
-
- requireCredential: true,
-
- kind: 'write:messaging',
-
- limit: {
- duration: ms('1hour'),
- max: 120,
- },
-
- res: {
- type: 'object',
- optional: false, nullable: false,
- ref: 'MessagingMessage',
- },
-
- errors: {
- recipientIsYourself: {
- message: 'You can not send a message to yourself.',
- code: 'RECIPIENT_IS_YOURSELF',
- id: '17e2ba79-e22a-4cbc-bf91-d327643f4a7e',
- },
-
- noSuchUser: {
- message: 'No such user.',
- code: 'NO_SUCH_USER',
- id: '11795c64-40ea-4198-b06e-3c873ed9039d',
- },
-
- noSuchGroup: {
- message: 'No such group.',
- code: 'NO_SUCH_GROUP',
- id: 'c94e2a5d-06aa-4914-8fa6-6a42e73d6537',
- },
-
- groupAccessDenied: {
- message: 'You can not send messages to groups that you have not joined.',
- code: 'GROUP_ACCESS_DENIED',
- id: 'd96b3cca-5ad1-438b-ad8b-02f931308fbd',
- },
-
- noSuchFile: {
- message: 'No such file.',
- code: 'NO_SUCH_FILE',
- id: '4372b8e2-185d-4146-8749-2f68864a3e5f',
- },
-
- contentRequired: {
- message: 'Content required. You need to set text or fileId.',
- code: 'CONTENT_REQUIRED',
- id: '25587321-b0e6-449c-9239-f8925092942c',
- },
-
- youHaveBeenBlocked: {
- message: 'You cannot send a message because you have been blocked by this user.',
- code: 'YOU_HAVE_BEEN_BLOCKED',
- id: 'c15a5199-7422-4968-941a-2a462c478f7d',
- },
- },
-} as const;
-
-export const paramDef = {
- type: 'object',
- properties: {
- text: { type: 'string', nullable: true, maxLength: 3000 },
- fileId: { type: 'string', format: 'misskey:id' },
- },
- anyOf: [
- {
- properties: {
- userId: { type: 'string', format: 'misskey:id' },
- },
- required: ['userId'],
- },
- {
- properties: {
- groupId: { type: 'string', format: 'misskey:id' },
- },
- required: ['groupId'],
- },
- ],
-} as const;
-
-// eslint-disable-next-line import/no-default-export
-@Injectable()
-export default class extends Endpoint<typeof meta, typeof paramDef> {
- constructor(
- @Inject(DI.userGroupsRepository)
- private userGroupsRepository: UserGroupsRepository,
-
- @Inject(DI.userGroupJoiningsRepository)
- private userGroupJoiningsRepository: UserGroupJoiningsRepository,
-
- @Inject(DI.blockingsRepository)
- private blockingsRepository: BlockingsRepository,
-
- @Inject(DI.driveFilesRepository)
- private driveFilesRepository: DriveFilesRepository,
-
- private getterService: GetterService,
- private messagingService: MessagingService,
- ) {
- super(meta, paramDef, async (ps, me) => {
- let recipientUser: User | null;
- let recipientGroup: UserGroup | null;
-
- if (ps.userId != null) {
- // Myself
- if (ps.userId === me.id) {
- throw new ApiError(meta.errors.recipientIsYourself);
- }
-
- // Fetch recipient (user)
- recipientUser = await this.getterService.getUser(ps.userId).catch(err => {
- if (err.id === '15348ddd-432d-49c2-8a5a-8069753becff') throw new ApiError(meta.errors.noSuchUser);
- throw err;
- });
-
- // Check blocking
- const block = await this.blockingsRepository.findOneBy({
- blockerId: recipientUser.id,
- blockeeId: me.id,
- });
- if (block) {
- throw new ApiError(meta.errors.youHaveBeenBlocked);
- }
- } else if (ps.groupId != null) {
- // Fetch recipient (group)
- recipientGroup = await this.userGroupsRepository.findOneBy({ id: ps.groupId! });
-
- if (recipientGroup == null) {
- throw new ApiError(meta.errors.noSuchGroup);
- }
-
- // check joined
- const joining = await this.userGroupJoiningsRepository.findOneBy({
- userId: me.id,
- userGroupId: recipientGroup.id,
- });
-
- if (joining == null) {
- throw new ApiError(meta.errors.groupAccessDenied);
- }
- }
-
- let file = null;
- if (ps.fileId != null) {
- file = await this.driveFilesRepository.findOneBy({
- id: ps.fileId,
- userId: me.id,
- });
-
- if (file == null) {
- throw new ApiError(meta.errors.noSuchFile);
- }
- }
-
- // テキストが無いかつ添付ファイルも無かったらエラー
- if (ps.text == null && file == null) {
- throw new ApiError(meta.errors.contentRequired);
- }
-
- return await this.messagingService.createMessage(me, recipientUser, recipientGroup, ps.text, file);
- });
- }
-}
diff --git a/packages/backend/src/server/api/endpoints/messaging/messages/delete.ts b/packages/backend/src/server/api/endpoints/messaging/messages/delete.ts
deleted file mode 100644
index cd74f5f197..0000000000
--- a/packages/backend/src/server/api/endpoints/messaging/messages/delete.ts
+++ /dev/null
@@ -1,61 +0,0 @@
-import { Inject, Injectable } from '@nestjs/common';
-import ms from 'ms';
-import { Endpoint } from '@/server/api/endpoint-base.js';
-import type { MessagingMessagesRepository } from '@/models/index.js';
-import { MessagingService } from '@/core/MessagingService.js';
-import { DI } from '@/di-symbols.js';
-import { ApiError } from '../../../error.js';
-
-export const meta = {
- tags: ['messaging'],
-
- requireCredential: true,
-
- kind: 'write:messaging',
-
- limit: {
- duration: ms('1hour'),
- max: 300,
- minInterval: ms('1sec'),
- },
-
- errors: {
- noSuchMessage: {
- message: 'No such message.',
- code: 'NO_SUCH_MESSAGE',
- id: '54b5b326-7925-42cf-8019-130fda8b56af',
- },
- },
-} as const;
-
-export const paramDef = {
- type: 'object',
- properties: {
- messageId: { type: 'string', format: 'misskey:id' },
- },
- required: ['messageId'],
-} as const;
-
-// eslint-disable-next-line import/no-default-export
-@Injectable()
-export default class extends Endpoint<typeof meta, typeof paramDef> {
- constructor(
- @Inject(DI.messagingMessagesRepository)
- private messagingMessagesRepository: MessagingMessagesRepository,
-
- private messagingService: MessagingService,
- ) {
- super(meta, paramDef, async (ps, me) => {
- const message = await this.messagingMessagesRepository.findOneBy({
- id: ps.messageId,
- userId: me.id,
- });
-
- if (message == null) {
- throw new ApiError(meta.errors.noSuchMessage);
- }
-
- await this.messagingService.deleteMessage(message);
- });
- }
-}
diff --git a/packages/backend/src/server/api/endpoints/messaging/messages/read.ts b/packages/backend/src/server/api/endpoints/messaging/messages/read.ts
deleted file mode 100644
index bddb6d932d..0000000000
--- a/packages/backend/src/server/api/endpoints/messaging/messages/read.ts
+++ /dev/null
@@ -1,61 +0,0 @@
-import { Inject, Injectable } from '@nestjs/common';
-import { Endpoint } from '@/server/api/endpoint-base.js';
-import type { MessagingMessagesRepository } from '@/models/index.js';
-import { MessagingService } from '@/core/MessagingService.js';
-import { DI } from '@/di-symbols.js';
-import { ApiError } from '../../../error.js';
-
-export const meta = {
- tags: ['messaging'],
-
- requireCredential: true,
-
- kind: 'write:messaging',
-
- errors: {
- noSuchMessage: {
- message: 'No such message.',
- code: 'NO_SUCH_MESSAGE',
- id: '86d56a2f-a9c3-4afb-b13c-3e9bfef9aa14',
- },
- },
-} as const;
-
-export const paramDef = {
- type: 'object',
- properties: {
- messageId: { type: 'string', format: 'misskey:id' },
- },
- required: ['messageId'],
-} as const;
-
-// eslint-disable-next-line import/no-default-export
-@Injectable()
-export default class extends Endpoint<typeof meta, typeof paramDef> {
- constructor(
- @Inject(DI.messagingMessagesRepository)
- private messagingMessagesRepository: MessagingMessagesRepository,
-
- private messagingService: MessagingService,
- ) {
- super(meta, paramDef, async (ps, me) => {
- const message = await this.messagingMessagesRepository.findOneBy({ id: ps.messageId });
-
- if (message == null) {
- throw new ApiError(meta.errors.noSuchMessage);
- }
-
- if (message.recipientId) {
- await this.messagingService.readUserMessagingMessage(me.id, message.userId, [message.id]).catch(err => {
- if (err.id === 'e140a4bf-49ce-4fb6-b67c-b78dadf6b52f') throw new ApiError(meta.errors.noSuchMessage);
- throw err;
- });
- } else if (message.groupId) {
- await this.messagingService.readGroupMessagingMessage(me.id, message.groupId, [message.id]).catch(err => {
- if (err.id === '930a270c-714a-46b2-b776-ad27276dc569') throw new ApiError(meta.errors.noSuchMessage);
- throw err;
- });
- }
- });
- }
-}