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
	 syuilo
					syuilo