summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/app
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
parentUpdate ROADMAP.md (diff)
downloadsharkey-b75184ec8e3436200bacdcd832e3324702553d20.tar.gz
sharkey-b75184ec8e3436200bacdcd832e3324702553d20.tar.bz2
sharkey-b75184ec8e3436200bacdcd832e3324702553d20.zip
なんかもうめっちゃ変えた
Diffstat (limited to 'packages/backend/src/server/api/endpoints/app')
-rw-r--r--packages/backend/src/server/api/endpoints/app/create.ts64
-rw-r--r--packages/backend/src/server/api/endpoints/app/show.ts41
2 files changed, 66 insertions, 39 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,
+ });
+ });
+ }
+}
diff --git a/packages/backend/src/server/api/endpoints/app/show.ts b/packages/backend/src/server/api/endpoints/app/show.ts
index 451969d971..f94fed5344 100644
--- a/packages/backend/src/server/api/endpoints/app/show.ts
+++ b/packages/backend/src/server/api/endpoints/app/show.ts
@@ -1,6 +1,9 @@
-import define from '../../define.js';
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import { AppsRepository } from '@/models/index.js';
+import { AppEntityService } from '@/core/entities/AppEntityService.js';
+import { DI } from '@/di-symbols.js';
import { ApiError } from '../../error.js';
-import { Apps } from '@/models/index.js';
export const meta = {
tags: ['app'],
@@ -29,18 +32,28 @@ export const paramDef = {
} as const;
// eslint-disable-next-line import/no-default-export
-export default define(meta, paramDef, async (ps, user, token) => {
- const isSecure = user != null && token == null;
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> {
+ constructor(
+ @Inject(DI.appsRepository)
+ private appsRepository: AppsRepository,
- // Lookup app
- const ap = await Apps.findOneBy({ id: ps.appId });
+ private appEntityService: AppEntityService,
+ ) {
+ super(meta, paramDef, async (ps, user, token) => {
+ const isSecure = user != null && token == null;
- if (ap == null) {
- throw new ApiError(meta.errors.noSuchApp);
- }
+ // Lookup app
+ const ap = await this.appsRepository.findOneBy({ id: ps.appId });
+
+ if (ap == null) {
+ throw new ApiError(meta.errors.noSuchApp);
+ }
- return await Apps.pack(ap, user, {
- detail: true,
- includeSecret: isSecure && (ap.userId === user!.id),
- });
-});
+ return await this.appEntityService.pack(ap, user, {
+ detail: true,
+ includeSecret: isSecure && (ap.userId === user!.id),
+ });
+ });
+ }
+}