diff options
| author | Marie <marie@kaifa.ch> | 2023-10-18 05:40:32 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-10-18 05:40:32 +0200 |
| commit | 182bf7e7d6ac93f4744068bf3972081565fb8c30 (patch) | |
| tree | e93086928d4c6f1c38d43ca957eb9f0ba1421ca3 /packages/backend/src/server/api/endpoints/admin | |
| parent | upd: display correct `approval_required` value on masto instance endpoint (diff) | |
| parent | add: mark all media from user as NSFW (diff) | |
| download | sharkey-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.ts | 42 | ||||
| -rw-r--r-- | packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts | 42 |
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, + }); + }); + } +} |