diff options
| author | Mar0xy <marie@kaifa.ch> | 2023-09-25 04:55:11 +0200 |
|---|---|---|
| committer | Mar0xy <marie@kaifa.ch> | 2023-09-25 04:55:11 +0200 |
| commit | 871407ce531ba00336a373e0d7e1ffbd74949c5d (patch) | |
| tree | a7cd6effe7102fddc217b65c298707c8c1ef55b8 /packages/backend/src/server/api/endpoints | |
| parent | chore: remove createdAt in favour of created_at (diff) | |
| download | sharkey-871407ce531ba00336a373e0d7e1ffbd74949c5d.tar.gz sharkey-871407ce531ba00336a373e0d7e1ffbd74949c5d.tar.bz2 sharkey-871407ce531ba00336a373e0d7e1ffbd74949c5d.zip | |
upd: add new endpoint to mk api, add preferences to masto api
Diffstat (limited to 'packages/backend/src/server/api/endpoints')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/i/registry/get-unsecure.ts | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/i/registry/get-unsecure.ts b/packages/backend/src/server/api/endpoints/i/registry/get-unsecure.ts new file mode 100644 index 0000000000..b3effbb82e --- /dev/null +++ b/packages/backend/src/server/api/endpoints/i/registry/get-unsecure.ts @@ -0,0 +1,55 @@ +import { Inject, Injectable } from '@nestjs/common'; +import { Endpoint } from '@/server/api/endpoint-base.js'; +import type { RegistryItemsRepository } from '@/models/_.js'; +import { DI } from '@/di-symbols.js'; +import { ApiError } from '../../../error.js'; + +export const meta = { + requireCredential: true, + + secure: false, + + errors: { + noSuchKey: { + message: 'No such key.', + code: 'NO_SUCH_KEY', + id: 'ac3ed68a-62f0-422b-a7bc-d5e09e8f6a6a', + }, + }, +} as const; + +export const paramDef = { + type: 'object', + properties: { + key: { type: 'string' }, + scope: { type: 'array', default: [], items: { + type: 'string', pattern: /^[a-zA-Z0-9_]+$/.toString().slice(1, -1), + } }, + }, + required: ['key'], +} as const; + +@Injectable() +export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export + constructor( + @Inject(DI.registryItemsRepository) + private registryItemsRepository: RegistryItemsRepository, + ) { + super(meta, paramDef, async (ps, me) => { + if (ps.key !== "reactions" && ps.key !== "defaultNoteVisibility") return; + const query = this.registryItemsRepository.createQueryBuilder('item') + .where('item.domain IS NULL') + .andWhere('item.userId = :userId', { userId: me.id }) + .andWhere('item.key = :key', { key: ps.key }) + .andWhere('item.scope = :scope', { scope: ps.scope }); + + const item = await query.getOne(); + + if (item == null) { + throw new ApiError(meta.errors.noSuchKey); + } + + return item.value; + }); + } +}
\ No newline at end of file |