summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/app/show.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/endpoints/app/show.ts')
-rw-r--r--packages/backend/src/server/api/endpoints/app/show.ts41
1 files changed, 27 insertions, 14 deletions
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),
+ });
+ });
+ }
+}