summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/drive.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/endpoints/drive.ts')
-rw-r--r--packages/backend/src/server/api/endpoints/drive.ts33
1 files changed, 21 insertions, 12 deletions
diff --git a/packages/backend/src/server/api/endpoints/drive.ts b/packages/backend/src/server/api/endpoints/drive.ts
index 82497adefa..6f40225f15 100644
--- a/packages/backend/src/server/api/endpoints/drive.ts
+++ b/packages/backend/src/server/api/endpoints/drive.ts
@@ -1,6 +1,7 @@
-import { fetchMeta } from '@/misc/fetch-meta.js';
-import { DriveFiles } from '@/models/index.js';
-import define from '../define.js';
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import { MetaService } from '@/core/MetaService.js';
+import { DriveFileEntityService } from '@/core/entities/DriveFileEntityService.js';
export const meta = {
tags: ['drive', 'account'],
@@ -32,14 +33,22 @@ export const paramDef = {
} as const;
// eslint-disable-next-line import/no-default-export
-export default define(meta, paramDef, async (ps, user) => {
- const instance = await fetchMeta(true);
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> {
+ constructor(
+ private metaService: MetaService,
+ private driveFileEntityService: DriveFileEntityService,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ const instance = await this.metaService.fetch(true);
- // Calculate drive usage
- const usage = await DriveFiles.calcDriveUsageOf(user.id);
+ // Calculate drive usage
+ const usage = await this.driveFileEntityService.calcDriveUsageOf(me.id);
- return {
- capacity: 1024 * 1024 * (user.driveCapacityOverrideMb || instance.localDriveCapacityMb),
- usage: usage,
- };
-});
+ return {
+ capacity: 1024 * 1024 * (me.driveCapacityOverrideMb ?? instance.localDriveCapacityMb),
+ usage: usage,
+ };
+ });
+ }
+}