summaryrefslogtreecommitdiff
path: root/packages/backend/src/core/RoleService.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-04-12 11:40:08 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-04-12 11:40:08 +0900
commit5d56799070006923701dcdaaa61d69c00e034209 (patch)
tree945500d9ab955197da70ee5d9e8c478ddb9767e1 /packages/backend/src/core/RoleService.ts
parentenhance: カスタム絵文字関連の変更 (#9794) (diff)
downloadsharkey-5d56799070006923701dcdaaa61d69c00e034209.tar.gz
sharkey-5d56799070006923701dcdaaa61d69c00e034209.tar.bz2
sharkey-5d56799070006923701dcdaaa61d69c00e034209.zip
feat: role timeline
Resolve #10581
Diffstat (limited to 'packages/backend/src/core/RoleService.ts')
-rw-r--r--packages/backend/src/core/RoleService.ts23
1 files changed, 23 insertions, 0 deletions
diff --git a/packages/backend/src/core/RoleService.ts b/packages/backend/src/core/RoleService.ts
index 77645e3f06..2a4271aa98 100644
--- a/packages/backend/src/core/RoleService.ts
+++ b/packages/backend/src/core/RoleService.ts
@@ -13,6 +13,7 @@ import { UserEntityService } from '@/core/entities/UserEntityService.js';
import { StreamMessages } from '@/server/api/stream/types.js';
import { IdService } from '@/core/IdService.js';
import { GlobalEventService } from '@/core/GlobalEventService.js';
+import type { Packed } from '@/misc/json-schema';
import type { OnApplicationShutdown } from '@nestjs/common';
export type RolePolicies = {
@@ -64,6 +65,9 @@ export class RoleService implements OnApplicationShutdown {
public static NotAssignedError = class extends Error {};
constructor(
+ @Inject(DI.redis)
+ private redisClient: Redis.Redis,
+
@Inject(DI.redisForSub)
private redisForSub: Redis.Redis,
@@ -399,6 +403,25 @@ export class RoleService implements OnApplicationShutdown {
}
@bindThis
+ public async addNoteToRoleTimeline(note: Packed<'Note'>): Promise<void> {
+ const roles = await this.getUserRoles(note.userId);
+
+ const redisPipeline = this.redisClient.pipeline();
+
+ for (const role of roles) {
+ redisPipeline.xadd(
+ `roleTimeline:${role.id}`,
+ 'MAXLEN', '~', '1000',
+ '*',
+ 'note', note.id);
+
+ this.globalEventService.publishRoleTimelineStream(role.id, 'note', note);
+ }
+
+ redisPipeline.exec();
+ }
+
+ @bindThis
public onApplicationShutdown(signal?: string | undefined) {
this.redisForSub.off('message', this.onMessage);
}