summaryrefslogtreecommitdiff
path: root/packages/backend/src
diff options
context:
space:
mode:
authormisskey-release-bot[bot] <157398866+misskey-release-bot[bot]@users.noreply.github.com>2025-06-16 02:33:18 +0000
committerGitHub <noreply@github.com>2025-06-16 02:33:18 +0000
commit830e2f0a5b5bada00bfbe036ef6e7ee8d84b83fd (patch)
treeb9ac1c4efb202a62fe34608fb3f42fd73297774b /packages/backend/src
parentMerge pull request #16134 from misskey-dev/develop (diff)
parentRelease: 2025.6.1 (diff)
downloadmisskey-830e2f0a5b5bada00bfbe036ef6e7ee8d84b83fd.tar.gz
misskey-830e2f0a5b5bada00bfbe036ef6e7ee8d84b83fd.tar.bz2
misskey-830e2f0a5b5bada00bfbe036ef6e7ee8d84b83fd.zip
Merge pull request #16152 from misskey-dev/develop
Release: 2025.6.1
Diffstat (limited to 'packages/backend/src')
-rw-r--r--packages/backend/src/core/ChatService.ts10
-rw-r--r--packages/backend/src/core/DriveService.ts6
-rw-r--r--packages/backend/src/server/ActivityPubServerService.ts27
-rw-r--r--packages/backend/src/server/api/endpoint-list.ts1
-rw-r--r--packages/backend/src/server/api/endpoints/chat/read-all.ts38
5 files changed, 73 insertions, 9 deletions
diff --git a/packages/backend/src/core/ChatService.ts b/packages/backend/src/core/ChatService.ts
index 4e81847a52..5cd336a097 100644
--- a/packages/backend/src/core/ChatService.ts
+++ b/packages/backend/src/core/ChatService.ts
@@ -332,6 +332,16 @@ export class ChatService {
}
@bindThis
+ public async readAllChatMessages(
+ readerId: MiUser['id'],
+ ): Promise<void> {
+ const redisPipeline = this.redisClient.pipeline();
+ // TODO: newUserChatMessageExists とか newRoomChatMessageExists も消したい(けどキーの列挙が必要になって面倒)
+ redisPipeline.del(`newChatMessagesExists:${readerId}`);
+ await redisPipeline.exec();
+ }
+
+ @bindThis
public findMessageById(messageId: MiChatMessage['id']) {
return this.chatMessagesRepository.findOneBy({ id: messageId });
}
diff --git a/packages/backend/src/core/DriveService.ts b/packages/backend/src/core/DriveService.ts
index 1945c58e5b..567bad2a2d 100644
--- a/packages/backend/src/core/DriveService.ts
+++ b/packages/backend/src/core/DriveService.ts
@@ -803,14 +803,14 @@ export class DriveService {
await Promise.all(promises);
}
- this.deletePostProcess(file, isExpired, deleter);
+ await this.deletePostProcess(file, isExpired, deleter);
}
@bindThis
private async deletePostProcess(file: MiDriveFile, isExpired = false, deleter?: MiUser) {
// リモートファイル期限切れ削除後は直リンクにする
if (isExpired && file.userHost !== null && file.uri != null) {
- this.driveFilesRepository.update(file.id, {
+ await this.driveFilesRepository.update(file.id, {
isLink: true,
url: file.uri,
thumbnailUrl: null,
@@ -822,7 +822,7 @@ export class DriveService {
webpublicAccessKey: 'webpublic-' + randomUUID(),
});
} else {
- this.driveFilesRepository.delete(file.id);
+ await this.driveFilesRepository.delete(file.id);
}
this.driveChart.update(file, false);
diff --git a/packages/backend/src/server/ActivityPubServerService.ts b/packages/backend/src/server/ActivityPubServerService.ts
index f7b22c44c4..a5fb5b82e3 100644
--- a/packages/backend/src/server/ActivityPubServerService.ts
+++ b/packages/backend/src/server/ActivityPubServerService.ts
@@ -482,9 +482,19 @@ export class ActivityPubServerService {
return true;
},
dbFallback: async (untilId, sinceId, limit) => {
- return await this.getUserNotesFromDb(sinceId, untilId, limit, user.id);
+ return await this.getUserNotesFromDb({
+ untilId,
+ sinceId,
+ limit,
+ userId: user.id,
+ });
},
- }) : await this.getUserNotesFromDb(sinceId ?? null, untilId ?? null, limit, user.id);
+ }) : await this.getUserNotesFromDb({
+ untilId: untilId ?? null,
+ sinceId: sinceId ?? null,
+ limit,
+ userId: user.id,
+ });
if (sinceId) notes.reverse();
@@ -523,16 +533,21 @@ export class ActivityPubServerService {
}
@bindThis
- private async getUserNotesFromDb(untilId: string | null, sinceId: string | null, limit: number, userId: MiUser['id']) {
- return await this.queryService.makePaginationQuery(this.notesRepository.createQueryBuilder('note'), sinceId, untilId)
- .andWhere('note.userId = :userId', { userId })
+ private async getUserNotesFromDb(ps: {
+ untilId: string | null,
+ sinceId: string | null,
+ limit: number,
+ userId: MiUser['id'],
+ }) {
+ return await this.queryService.makePaginationQuery(this.notesRepository.createQueryBuilder('note'), ps.sinceId, ps.untilId)
+ .andWhere('note.userId = :userId', { userId: ps.userId })
.andWhere(new Brackets(qb => {
qb
.where('note.visibility = \'public\'')
.orWhere('note.visibility = \'home\'');
}))
.andWhere('note.localOnly = FALSE')
- .limit(limit)
+ .limit(ps.limit)
.getMany();
}
diff --git a/packages/backend/src/server/api/endpoint-list.ts b/packages/backend/src/server/api/endpoint-list.ts
index 1fdd000fdf..092d296bd3 100644
--- a/packages/backend/src/server/api/endpoint-list.ts
+++ b/packages/backend/src/server/api/endpoint-list.ts
@@ -428,4 +428,5 @@ export * as 'chat/rooms/invitations/ignore' from './endpoints/chat/rooms/invitat
export * as 'chat/rooms/invitations/inbox' from './endpoints/chat/rooms/invitations/inbox.js';
export * as 'chat/rooms/invitations/outbox' from './endpoints/chat/rooms/invitations/outbox.js';
export * as 'chat/history' from './endpoints/chat/history.js';
+export * as 'chat/read-all' from './endpoints/chat/read-all.js';
export * as 'v2/admin/emoji/list' from './endpoints/v2/admin/emoji/list.js';
diff --git a/packages/backend/src/server/api/endpoints/chat/read-all.ts b/packages/backend/src/server/api/endpoints/chat/read-all.ts
new file mode 100644
index 0000000000..2ed9497eef
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/chat/read-all.ts
@@ -0,0 +1,38 @@
+/*
+ * SPDX-FileCopyrightText: syuilo and misskey-project
+ * SPDX-License-Identifier: AGPL-3.0-only
+ */
+
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import { DI } from '@/di-symbols.js';
+import { ChatService } from '@/core/ChatService.js';
+import { ApiError } from '@/server/api/error.js';
+
+export const meta = {
+ tags: ['chat'],
+
+ requireCredential: true,
+
+ kind: 'write:chat',
+
+ errors: {
+ },
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ },
+} as const;
+
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
+ constructor(
+ private chatService: ChatService,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ await this.chatService.readAllChatMessages(me.id);
+ });
+ }
+}