summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/admin/show-user.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/endpoints/admin/show-user.ts')
-rw-r--r--packages/backend/src/server/api/endpoints/admin/show-user.ts112
1 files changed, 64 insertions, 48 deletions
diff --git a/packages/backend/src/server/api/endpoints/admin/show-user.ts b/packages/backend/src/server/api/endpoints/admin/show-user.ts
index 0d866b3113..b50564210b 100644
--- a/packages/backend/src/server/api/endpoints/admin/show-user.ts
+++ b/packages/backend/src/server/api/endpoints/admin/show-user.ts
@@ -1,5 +1,7 @@
-import { Signins, UserProfiles, Users } from '@/models/index.js';
-import define from '../../define.js';
+import { Inject, Injectable } from '@nestjs/common';
+import { UsersRepository, SigninsRepository, UserProfilesRepository } from '@/models/index.js';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import { DI } from '@/di-symbols.js';
export const meta = {
tags: ['admin'],
@@ -22,55 +24,69 @@ export const paramDef = {
} as const;
// eslint-disable-next-line import/no-default-export
-export default define(meta, paramDef, async (ps, me) => {
- const [user, profile] = await Promise.all([
- Users.findOneBy({ id: ps.userId }),
- UserProfiles.findOneBy({ userId: ps.userId }),
- ]);
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> {
+ constructor(
+ @Inject(DI.usersRepository)
+ private usersRepository: UsersRepository,
- if (user == null || profile == null) {
- throw new Error('user not found');
- }
+ @Inject(DI.userProfilesRepository)
+ private userProfilesRepository: UserProfilesRepository,
- const _me = await Users.findOneByOrFail({ id: me.id });
- if ((_me.isModerator && !_me.isAdmin) && user.isAdmin) {
- throw new Error('cannot show info of admin');
- }
+ @Inject(DI.signinsRepository)
+ private signinsRepository: SigninsRepository,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ const [user, profile] = await Promise.all([
+ this.usersRepository.findOneBy({ id: ps.userId }),
+ this.userProfilesRepository.findOneBy({ userId: ps.userId }),
+ ]);
- if (!_me.isAdmin) {
- return {
- isModerator: user.isModerator,
- isSilenced: user.isSilenced,
- isSuspended: user.isSuspended,
- };
- }
+ if (user == null || profile == null) {
+ throw new Error('user not found');
+ }
- const maskedKeys = ['accessToken', 'accessTokenSecret', 'refreshToken'];
- Object.keys(profile.integrations).forEach(integration => {
- maskedKeys.forEach(key => profile.integrations[integration][key] = '<MASKED>');
- });
+ const _me = await this.usersRepository.findOneByOrFail({ id: me.id });
+ if ((_me.isModerator && !_me.isAdmin) && user.isAdmin) {
+ throw new Error('cannot show info of admin');
+ }
- const signins = await Signins.findBy({ userId: user.id });
+ if (!_me.isAdmin) {
+ return {
+ isModerator: user.isModerator,
+ isSilenced: user.isSilenced,
+ isSuspended: user.isSuspended,
+ };
+ }
- return {
- email: profile.email,
- emailVerified: profile.emailVerified,
- autoAcceptFollowed: profile.autoAcceptFollowed,
- noCrawle: profile.noCrawle,
- alwaysMarkNsfw: profile.alwaysMarkNsfw,
- autoSensitive: profile.autoSensitive,
- carefulBot: profile.carefulBot,
- injectFeaturedNote: profile.injectFeaturedNote,
- receiveAnnouncementEmail: profile.receiveAnnouncementEmail,
- integrations: profile.integrations,
- mutedWords: profile.mutedWords,
- mutedInstances: profile.mutedInstances,
- mutingNotificationTypes: profile.mutingNotificationTypes,
- isModerator: user.isModerator,
- isSilenced: user.isSilenced,
- isSuspended: user.isSuspended,
- lastActiveDate: user.lastActiveDate,
- moderationNote: profile.moderationNote,
- signins,
- };
-});
+ const maskedKeys = ['accessToken', 'accessTokenSecret', 'refreshToken'];
+ Object.keys(profile.integrations).forEach(integration => {
+ maskedKeys.forEach(key => profile.integrations[integration][key] = '<MASKED>');
+ });
+
+ const signins = await this.signinsRepository.findBy({ userId: user.id });
+
+ return {
+ email: profile.email,
+ emailVerified: profile.emailVerified,
+ autoAcceptFollowed: profile.autoAcceptFollowed,
+ noCrawle: profile.noCrawle,
+ alwaysMarkNsfw: profile.alwaysMarkNsfw,
+ autoSensitive: profile.autoSensitive,
+ carefulBot: profile.carefulBot,
+ injectFeaturedNote: profile.injectFeaturedNote,
+ receiveAnnouncementEmail: profile.receiveAnnouncementEmail,
+ integrations: profile.integrations,
+ mutedWords: profile.mutedWords,
+ mutedInstances: profile.mutedInstances,
+ mutingNotificationTypes: profile.mutingNotificationTypes,
+ isModerator: user.isModerator,
+ isSilenced: user.isSilenced,
+ isSuspended: user.isSuspended,
+ lastActiveDate: user.lastActiveDate,
+ moderationNote: profile.moderationNote,
+ signins,
+ };
+ });
+ }
+}