summaryrefslogtreecommitdiff
path: root/src/services/chart/charts/classes/per-user-notes.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2021-11-12 02:02:25 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2021-11-12 02:02:25 +0900
commit0e4a111f81cceed275d9bec2695f6e401fb654d8 (patch)
tree40874799472fa07416f17b50a398ac33b7771905 /src/services/chart/charts/classes/per-user-notes.ts
parentupdate deps (diff)
downloadmisskey-0e4a111f81cceed275d9bec2695f6e401fb654d8.tar.gz
misskey-0e4a111f81cceed275d9bec2695f6e401fb654d8.tar.bz2
misskey-0e4a111f81cceed275d9bec2695f6e401fb654d8.zip
refactoring
Resolve #7779
Diffstat (limited to 'src/services/chart/charts/classes/per-user-notes.ts')
-rw-r--r--src/services/chart/charts/classes/per-user-notes.ts72
1 files changed, 0 insertions, 72 deletions
diff --git a/src/services/chart/charts/classes/per-user-notes.ts b/src/services/chart/charts/classes/per-user-notes.ts
deleted file mode 100644
index 0e808766f5..0000000000
--- a/src/services/chart/charts/classes/per-user-notes.ts
+++ /dev/null
@@ -1,72 +0,0 @@
-import autobind from 'autobind-decorator';
-import Chart, { Obj, DeepPartial } from '../../core';
-import { User } from '@/models/entities/user';
-import { SchemaType } from '@/misc/schema';
-import { Notes } from '@/models/index';
-import { Note } from '@/models/entities/note';
-import { name, schema } from '../schemas/per-user-notes';
-
-type PerUserNotesLog = SchemaType<typeof schema>;
-
-export default class PerUserNotesChart extends Chart<PerUserNotesLog> {
- constructor() {
- super(name, schema, true);
- }
-
- @autobind
- protected genNewLog(latest: PerUserNotesLog): DeepPartial<PerUserNotesLog> {
- return {
- total: latest.total,
- };
- }
-
- @autobind
- protected aggregate(logs: PerUserNotesLog[]): PerUserNotesLog {
- return {
- total: logs[0].total,
- inc: logs.reduce((a, b) => a + b.inc, 0),
- dec: logs.reduce((a, b) => a + b.dec, 0),
- diffs: {
- reply: logs.reduce((a, b) => a + b.diffs.reply, 0),
- renote: logs.reduce((a, b) => a + b.diffs.renote, 0),
- normal: logs.reduce((a, b) => a + b.diffs.normal, 0),
- },
- };
- }
-
- @autobind
- protected async fetchActual(group: string): Promise<DeepPartial<PerUserNotesLog>> {
- const [count] = await Promise.all([
- Notes.count({ userId: group }),
- ]);
-
- return {
- total: count,
- };
- }
-
- @autobind
- public async update(user: { id: User['id'] }, note: Note, isAdditional: boolean) {
- const update: Obj = {
- diffs: {}
- };
-
- update.total = isAdditional ? 1 : -1;
-
- if (isAdditional) {
- update.inc = 1;
- } else {
- update.dec = 1;
- }
-
- if (note.replyId != null) {
- update.diffs.reply = isAdditional ? 1 : -1;
- } else if (note.renoteId != null) {
- update.diffs.renote = isAdditional ? 1 : -1;
- } else {
- update.diffs.normal = isAdditional ? 1 : -1;
- }
-
- await this.inc(update, user.id);
- }
-}