summaryrefslogtreecommitdiff
path: root/packages/backend/src/core/UserMutingService.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-04-05 10:21:10 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-04-05 10:21:10 +0900
commitf44504097c360fc84179161abee47b79a936b455 (patch)
treeaec17f0837ccad89754fae24c044ba0b8d7e8def /packages/backend/src/core/UserMutingService.ts
parentenhance(backend): チャンネルの既読管理を削除 (diff)
downloadsharkey-f44504097c360fc84179161abee47b79a936b455.tar.gz
sharkey-f44504097c360fc84179161abee47b79a936b455.tar.bz2
sharkey-f44504097c360fc84179161abee47b79a936b455.zip
enhance(backend): improve cache
Diffstat (limited to 'packages/backend/src/core/UserMutingService.ts')
-rw-r--r--packages/backend/src/core/UserMutingService.ts31
1 files changed, 22 insertions, 9 deletions
diff --git a/packages/backend/src/core/UserMutingService.ts b/packages/backend/src/core/UserMutingService.ts
index e98f11709f..657b5764b9 100644
--- a/packages/backend/src/core/UserMutingService.ts
+++ b/packages/backend/src/core/UserMutingService.ts
@@ -1,34 +1,47 @@
import { Inject, Injectable } from '@nestjs/common';
-import type { UsersRepository, MutingsRepository } from '@/models/index.js';
+import { In } from 'typeorm';
+import type { MutingsRepository, Muting } from '@/models/index.js';
import { IdService } from '@/core/IdService.js';
-import { QueueService } from '@/core/QueueService.js';
-import { GlobalEventService } from '@/core/GlobalEventService.js';
import type { User } from '@/models/entities/User.js';
import { DI } from '@/di-symbols.js';
import { bindThis } from '@/decorators.js';
+import { CacheService } from '@/core/CacheService';
@Injectable()
export class UserMutingService {
constructor(
- @Inject(DI.usersRepository)
- private usersRepository: UsersRepository,
-
@Inject(DI.mutingsRepository)
private mutingsRepository: MutingsRepository,
private idService: IdService,
- private queueService: QueueService,
- private globalEventService: GlobalEventService,
+ private cacheService: CacheService,
) {
}
@bindThis
- public async mute(user: User, target: User): Promise<void> {
+ public async mute(user: User, target: User, expiresAt: Date | null = null): Promise<void> {
await this.mutingsRepository.insert({
id: this.idService.genId(),
createdAt: new Date(),
+ expiresAt: expiresAt ?? null,
muterId: user.id,
muteeId: target.id,
});
+
+ this.cacheService.userMutingsCache.refresh(user.id);
+ }
+
+ @bindThis
+ public async unmute(mutings: Muting[]): Promise<void> {
+ if (mutings.length === 0) return;
+
+ await this.mutingsRepository.delete({
+ id: In(mutings.map(m => m.id)),
+ });
+
+ const muterIds = [...new Set(mutings.map(m => m.muterId))];
+ for (const muterId of muterIds) {
+ this.cacheService.userMutingsCache.refresh(muterId);
+ }
}
}