summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/app/create.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-09-18 03:27:08 +0900
committerGitHub <noreply@github.com>2022-09-18 03:27:08 +0900
commitb75184ec8e3436200bacdcd832e3324702553d20 (patch)
tree8b7e316f29e95df921db57289c8b8da476d18f07 /packages/backend/src/server/api/endpoints/app/create.ts
parentUpdate ROADMAP.md (diff)
downloadmisskey-b75184ec8e3436200bacdcd832e3324702553d20.tar.gz
misskey-b75184ec8e3436200bacdcd832e3324702553d20.tar.bz2
misskey-b75184ec8e3436200bacdcd832e3324702553d20.zip
なんかもうめっちゃ変えた
Diffstat (limited to 'packages/backend/src/server/api/endpoints/app/create.ts')
-rw-r--r--packages/backend/src/server/api/endpoints/app/create.ts64
1 files changed, 39 insertions, 25 deletions
diff --git a/packages/backend/src/server/api/endpoints/app/create.ts b/packages/backend/src/server/api/endpoints/app/create.ts
index a0a7350822..f52d18f7fe 100644
--- a/packages/backend/src/server/api/endpoints/app/create.ts
+++ b/packages/backend/src/server/api/endpoints/app/create.ts
@@ -1,8 +1,11 @@
-import define from '../../define.js';
-import { Apps } from '@/models/index.js';
-import { genId } from '@/misc/gen-id.js';
-import { unique } from '@/prelude/array.js';
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import { AppsRepository } from '@/models/index.js';
+import { IdService } from '@/core/IdService.js';
+import { unique } from '@/misc/prelude/array.js';
import { secureRndstr } from '@/misc/secure-rndstr.js';
+import { AppEntityService } from '@/core/entities/AppEntityService.js';
+import { DI } from '@/di-symbols.js';
export const meta = {
tags: ['app'],
@@ -30,27 +33,38 @@ export const paramDef = {
} as const;
// eslint-disable-next-line import/no-default-export
-export default define(meta, paramDef, async (ps, user) => {
- // Generate secret
- const secret = secureRndstr(32, true);
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> {
+ constructor(
+ @Inject(DI.appsRepository)
+ private appsRepository: AppsRepository,
- // for backward compatibility
- const permission = unique(ps.permission.map(v => v.replace(/^(.+)(\/|-)(read|write)$/, '$3:$1')));
+ private appEntityService: AppEntityService,
+ private idService: IdService,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ // Generate secret
+ const secret = secureRndstr(32, true);
- // Create account
- const app = await Apps.insert({
- id: genId(),
- createdAt: new Date(),
- userId: user ? user.id : null,
- name: ps.name,
- description: ps.description,
- permission,
- callbackUrl: ps.callbackUrl,
- secret: secret,
- }).then(x => Apps.findOneByOrFail(x.identifiers[0]));
+ // for backward compatibility
+ const permission = unique(ps.permission.map(v => v.replace(/^(.+)(\/|-)(read|write)$/, '$3:$1')));
- return await Apps.pack(app, null, {
- detail: true,
- includeSecret: true,
- });
-});
+ // Create account
+ const app = await this.appsRepository.insert({
+ id: this.idService.genId(),
+ createdAt: new Date(),
+ userId: me ? me.id : null,
+ name: ps.name,
+ description: ps.description,
+ permission,
+ callbackUrl: ps.callbackUrl,
+ secret: secret,
+ }).then(x => this.appsRepository.findOneByOrFail(x.identifiers[0]));
+
+ return await this.appEntityService.pack(app, null, {
+ detail: true,
+ includeSecret: true,
+ });
+ });
+ }
+}