diff options
| author | syuilo <4439005+syuilo@users.noreply.github.com> | 2025-05-09 17:44:35 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-05-09 17:44:35 +0900 |
| commit | ebf291084f9490f0345a488592e2b4cd2ffb9d91 (patch) | |
| tree | 243df153ec60c16e495f344e9643bf0fc7668230 /packages/backend/src/server/api/endpoints/notes | |
| parent | Feat: No websocket mode (#15851) (diff) | |
| download | misskey-ebf291084f9490f0345a488592e2b4cd2ffb9d91.tar.gz misskey-ebf291084f9490f0345a488592e2b4cd2ffb9d91.tar.bz2 misskey-ebf291084f9490f0345a488592e2b4cd2ffb9d91.zip | |
Feat: UGCの公開範囲設定機能 (#15938)
* wip
* Update CHANGELOG.md
* wip
* wip
* Update show.ts
Diffstat (limited to 'packages/backend/src/server/api/endpoints/notes')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/notes/show.ts | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/packages/backend/src/server/api/endpoints/notes/show.ts b/packages/backend/src/server/api/endpoints/notes/show.ts index 11839bce36..b93c73b0c5 100644 --- a/packages/backend/src/server/api/endpoints/notes/show.ts +++ b/packages/backend/src/server/api/endpoints/notes/show.ts @@ -3,10 +3,12 @@ * SPDX-License-Identifier: AGPL-3.0-only */ -import { Injectable } from '@nestjs/common'; +import { Inject, Injectable } from '@nestjs/common'; import { Endpoint } from '@/server/api/endpoint-base.js'; import { NoteEntityService } from '@/core/entities/NoteEntityService.js'; import { GetterService } from '@/server/api/GetterService.js'; +import { DI } from '@/di-symbols.js'; +import { MiMeta } from '@/models/Meta.js'; import { ApiError } from '../../error.js'; export const meta = { @@ -46,6 +48,9 @@ export const paramDef = { @Injectable() export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export constructor( + @Inject(DI.meta) + private serverSettings: MiMeta, + private noteEntityService: NoteEntityService, private getterService: GetterService, ) { @@ -59,6 +64,14 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- throw new ApiError(meta.errors.signinRequired); } + if (this.serverSettings.ugcVisibilityForVisitor === 'none' && me == null) { + throw new ApiError(meta.errors.signinRequired); + } + + if (this.serverSettings.ugcVisibilityForVisitor === 'local' && note.userHost != null && me == null) { + throw new ApiError(meta.errors.signinRequired); + } + return await this.noteEntityService.pack(note, me, { detail: true, }); |