summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/users
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-01-01 17:45:49 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-01-01 17:45:49 +0900
commit969e9df889367159e64fcabadfd2150b1dfd685d (patch)
treebbc864061afa5f49dede6c404d48999bfe783fe2 /packages/backend/src/server/api/endpoints/users
parentclean up (diff)
downloadsharkey-969e9df889367159e64fcabadfd2150b1dfd685d.tar.gz
sharkey-969e9df889367159e64fcabadfd2150b1dfd685d.tar.bz2
sharkey-969e9df889367159e64fcabadfd2150b1dfd685d.zip
feat: add per user pv chart
Diffstat (limited to 'packages/backend/src/server/api/endpoints/users')
-rw-r--r--packages/backend/src/server/api/endpoints/users/show.ts10
1 files changed, 9 insertions, 1 deletions
diff --git a/packages/backend/src/server/api/endpoints/users/show.ts b/packages/backend/src/server/api/endpoints/users/show.ts
index 7932d5cd12..48a6bbf9bc 100644
--- a/packages/backend/src/server/api/endpoints/users/show.ts
+++ b/packages/backend/src/server/api/endpoints/users/show.ts
@@ -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,
});