feat: add per user pv chart
This commit is contained in:
		@@ -99,6 +99,7 @@ import * as ep___charts_notes from './endpoints/charts/notes.js';
 | 
			
		||||
import * as ep___charts_user_drive from './endpoints/charts/user/drive.js';
 | 
			
		||||
import * as ep___charts_user_following from './endpoints/charts/user/following.js';
 | 
			
		||||
import * as ep___charts_user_notes from './endpoints/charts/user/notes.js';
 | 
			
		||||
import * as ep___charts_user_pv from './endpoints/charts/user/pv.js';
 | 
			
		||||
import * as ep___charts_user_reactions from './endpoints/charts/user/reactions.js';
 | 
			
		||||
import * as ep___charts_users from './endpoints/charts/users.js';
 | 
			
		||||
import * as ep___clips_addNote from './endpoints/clips/add-note.js';
 | 
			
		||||
@@ -419,6 +420,7 @@ const $charts_notes: Provider = { provide: 'ep:charts/notes', useClass: ep___cha
 | 
			
		||||
const $charts_user_drive: Provider = { provide: 'ep:charts/user/drive', useClass: ep___charts_user_drive.default };
 | 
			
		||||
const $charts_user_following: Provider = { provide: 'ep:charts/user/following', useClass: ep___charts_user_following.default };
 | 
			
		||||
const $charts_user_notes: Provider = { provide: 'ep:charts/user/notes', useClass: ep___charts_user_notes.default };
 | 
			
		||||
const $charts_user_pv: Provider = { provide: 'ep:charts/user/pv', useClass: ep___charts_user_pv.default };
 | 
			
		||||
const $charts_user_reactions: Provider = { provide: 'ep:charts/user/reactions', useClass: ep___charts_user_reactions.default };
 | 
			
		||||
const $charts_users: Provider = { provide: 'ep:charts/users', useClass: ep___charts_users.default };
 | 
			
		||||
const $clips_addNote: Provider = { provide: 'ep:clips/add-note', useClass: ep___clips_addNote.default };
 | 
			
		||||
@@ -743,6 +745,7 @@ const $retention: Provider = { provide: 'ep:retention', useClass: ep___retention
 | 
			
		||||
		$charts_user_drive,
 | 
			
		||||
		$charts_user_following,
 | 
			
		||||
		$charts_user_notes,
 | 
			
		||||
		$charts_user_pv,
 | 
			
		||||
		$charts_user_reactions,
 | 
			
		||||
		$charts_users,
 | 
			
		||||
		$clips_addNote,
 | 
			
		||||
@@ -1061,6 +1064,7 @@ const $retention: Provider = { provide: 'ep:retention', useClass: ep___retention
 | 
			
		||||
		$charts_user_drive,
 | 
			
		||||
		$charts_user_following,
 | 
			
		||||
		$charts_user_notes,
 | 
			
		||||
		$charts_user_pv,
 | 
			
		||||
		$charts_user_reactions,
 | 
			
		||||
		$charts_users,
 | 
			
		||||
		$clips_addNote,
 | 
			
		||||
 
 | 
			
		||||
@@ -98,6 +98,7 @@ import * as ep___charts_notes from './endpoints/charts/notes.js';
 | 
			
		||||
import * as ep___charts_user_drive from './endpoints/charts/user/drive.js';
 | 
			
		||||
import * as ep___charts_user_following from './endpoints/charts/user/following.js';
 | 
			
		||||
import * as ep___charts_user_notes from './endpoints/charts/user/notes.js';
 | 
			
		||||
import * as ep___charts_user_pv from './endpoints/charts/user/pv.js';
 | 
			
		||||
import * as ep___charts_user_reactions from './endpoints/charts/user/reactions.js';
 | 
			
		||||
import * as ep___charts_users from './endpoints/charts/users.js';
 | 
			
		||||
import * as ep___clips_addNote from './endpoints/clips/add-note.js';
 | 
			
		||||
@@ -416,6 +417,7 @@ const eps = [
 | 
			
		||||
	['charts/user/drive', ep___charts_user_drive],
 | 
			
		||||
	['charts/user/following', ep___charts_user_following],
 | 
			
		||||
	['charts/user/notes', ep___charts_user_notes],
 | 
			
		||||
	['charts/user/pv', ep___charts_user_pv],
 | 
			
		||||
	['charts/user/reactions', ep___charts_user_reactions],
 | 
			
		||||
	['charts/users', ep___charts_users],
 | 
			
		||||
	['clips/add-note', ep___clips_addNote],
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										37
									
								
								packages/backend/src/server/api/endpoints/charts/user/pv.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								packages/backend/src/server/api/endpoints/charts/user/pv.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,37 @@
 | 
			
		||||
import { Inject, Injectable } from '@nestjs/common';
 | 
			
		||||
import { getJsonSchema } from '@/core/chart/core.js';
 | 
			
		||||
import { Endpoint } from '@/server/api/endpoint-base.js';
 | 
			
		||||
import PerUserPvChart from '@/core/chart/charts/per-user-pv.js';
 | 
			
		||||
import { schema } from '@/core/chart/charts/entities/per-user-notes.js';
 | 
			
		||||
 | 
			
		||||
export const meta = {
 | 
			
		||||
	tags: ['charts', 'users'],
 | 
			
		||||
 | 
			
		||||
	res: getJsonSchema(schema),
 | 
			
		||||
 | 
			
		||||
	allowGet: true,
 | 
			
		||||
	cacheSec: 60 * 60,
 | 
			
		||||
} as const;
 | 
			
		||||
 | 
			
		||||
export const paramDef = {
 | 
			
		||||
	type: 'object',
 | 
			
		||||
	properties: {
 | 
			
		||||
		span: { type: 'string', enum: ['day', 'hour'] },
 | 
			
		||||
		limit: { type: 'integer', minimum: 1, maximum: 500, default: 30 },
 | 
			
		||||
		offset: { type: 'integer', nullable: true, default: null },
 | 
			
		||||
		userId: { type: 'string', format: 'misskey:id' },
 | 
			
		||||
	},
 | 
			
		||||
	required: ['span', 'userId'],
 | 
			
		||||
} as const;
 | 
			
		||||
 | 
			
		||||
// eslint-disable-next-line import/no-default-export
 | 
			
		||||
@Injectable()
 | 
			
		||||
export default class extends Endpoint<typeof meta, typeof paramDef> {
 | 
			
		||||
	constructor(
 | 
			
		||||
		private perUserPvChart: PerUserPvChart,
 | 
			
		||||
	) {
 | 
			
		||||
		super(meta, paramDef, async (ps, me) => {
 | 
			
		||||
			return await this.perUserPvChart.getChart(ps.span, ps.limit, ps.offset ? new Date(ps.offset) : null, ps.userId);
 | 
			
		||||
		});
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
@@ -6,6 +6,7 @@ import { Endpoint } from '@/server/api/endpoint-base.js';
 | 
			
		||||
import { UserEntityService } from '@/core/entities/UserEntityService.js';
 | 
			
		||||
import { RemoteUserResolveService } from '@/core/RemoteUserResolveService.js';
 | 
			
		||||
import { DI } from '@/di-symbols.js';
 | 
			
		||||
import PerUserPvChart from '@/core/chart/charts/per-user-pv.js';
 | 
			
		||||
import { ApiError } from '../../error.js';
 | 
			
		||||
import { ApiLoggerService } from '../../ApiLoggerService.js';
 | 
			
		||||
import type { FindOptionsWhere } from 'typeorm';
 | 
			
		||||
@@ -90,9 +91,10 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
 | 
			
		||||
 | 
			
		||||
		private userEntityService: UserEntityService,
 | 
			
		||||
		private remoteUserResolveService: RemoteUserResolveService,
 | 
			
		||||
		private perUserPvChart: PerUserPvChart,
 | 
			
		||||
		private apiLoggerService: ApiLoggerService,
 | 
			
		||||
	) {
 | 
			
		||||
		super(meta, paramDef, async (ps, me) => {
 | 
			
		||||
		super(meta, paramDef, async (ps, me, _1, _2, _3, ip) => {
 | 
			
		||||
			let user;
 | 
			
		||||
 | 
			
		||||
			const isAdminOrModerator = me && (me.isAdmin || me.isModerator);
 | 
			
		||||
@@ -137,6 +139,12 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
 | 
			
		||||
					throw new ApiError(meta.errors.noSuchUser);
 | 
			
		||||
				}
 | 
			
		||||
 | 
			
		||||
				if (me == null && ip != null) {
 | 
			
		||||
					this.perUserPvChart.commitByVisitor(user, ip);
 | 
			
		||||
				} else if (me && me.id !== user.id) {
 | 
			
		||||
					this.perUserPvChart.commitByUser(user, me.id);
 | 
			
		||||
				}
 | 
			
		||||
 | 
			
		||||
				return await this.userEntityService.pack(user, me, {
 | 
			
		||||
					detail: true,
 | 
			
		||||
				});
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user