summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/admin
diff options
context:
space:
mode:
authorMarie <marie@kaifa.ch>2023-10-18 05:40:32 +0200
committerGitHub <noreply@github.com>2023-10-18 05:40:32 +0200
commit182bf7e7d6ac93f4744068bf3972081565fb8c30 (patch)
treee93086928d4c6f1c38d43ca957eb9f0ba1421ca3 /packages/backend/src/server/api/endpoints/admin
parentupd: display correct `approval_required` value on masto instance endpoint (diff)
parentadd: mark all media from user as NSFW (diff)
downloadsharkey-182bf7e7d6ac93f4744068bf3972081565fb8c30.tar.gz
sharkey-182bf7e7d6ac93f4744068bf3972081565fb8c30.tar.bz2
sharkey-182bf7e7d6ac93f4744068bf3972081565fb8c30.zip
Merge branch 'develop' into feature/approval
Diffstat (limited to 'packages/backend/src/server/api/endpoints/admin')
-rw-r--r--packages/backend/src/server/api/endpoints/admin/nsfw-user.ts42
-rw-r--r--packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts42
2 files changed, 84 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/admin/nsfw-user.ts b/packages/backend/src/server/api/endpoints/admin/nsfw-user.ts
new file mode 100644
index 0000000000..2dff0e8d09
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/nsfw-user.ts
@@ -0,0 +1,42 @@
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import type { UsersRepository, UserProfilesRepository } from '@/models/_.js';
+import { DI } from '@/di-symbols.js';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true,
+ requireModerator: true,
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ userId: { type: 'string', format: 'misskey:id' },
+ },
+ required: ['userId'],
+} as const;
+
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
+ constructor(
+ @Inject(DI.usersRepository)
+ private usersRepository: UsersRepository,
+
+ @Inject(DI.userProfilesRepository)
+ private userProfilesRepository: UserProfilesRepository,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ const user = await this.usersRepository.findOneBy({ id: ps.userId });
+
+ if (user == null) {
+ throw new Error('user not found');
+ }
+
+ await this.userProfilesRepository.update(user.id, {
+ alwaysMarkNsfw: true,
+ });
+ });
+ }
+}
diff --git a/packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts b/packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts
new file mode 100644
index 0000000000..9c414ed55c
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts
@@ -0,0 +1,42 @@
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import type { UsersRepository, UserProfilesRepository } from '@/models/_.js';
+import { DI } from '@/di-symbols.js';
+
+export const meta = {
+ tags: ['admin'],
+
+ requireCredential: true,
+ requireModerator: true,
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ userId: { type: 'string', format: 'misskey:id' },
+ },
+ required: ['userId'],
+} as const;
+
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
+ constructor(
+ @Inject(DI.usersRepository)
+ private usersRepository: UsersRepository,
+
+ @Inject(DI.userProfilesRepository)
+ private userProfilesRepository: UserProfilesRepository,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ const user = await this.usersRepository.findOneBy({ id: ps.userId });
+
+ if (user == null) {
+ throw new Error('user not found');
+ }
+
+ await this.userProfilesRepository.update(user.id, {
+ alwaysMarkNsfw: false,
+ });
+ });
+ }
+}