server: rewrite drive usage queries in raw SQL

This commit is contained in:
Johann150 2022-12-23 13:54:12 +01:00
parent 61a2db49df
commit eaa11647f0
Signed by: Johann150
GPG key ID: 9EE6577A2A06F8F1

View file

@ -61,50 +61,24 @@ export const DriveFileRepository = db.getRepository(DriveFile).extend({
return thumbnail ? (file.thumbnailUrl || (isImage ? (file.webpublicUrl || file.url) : null)) : (file.webpublicUrl || file.url); return thumbnail ? (file.thumbnailUrl || (isImage ? (file.webpublicUrl || file.url) : null)) : (file.webpublicUrl || file.url);
}, },
async calcDriveUsageOf(user: User['id'] | { id: User['id'] }): Promise<number> { calcDriveUsageOf(id: User['id']): Promise<number> {
const id = typeof user === 'object' ? user.id : user; return db.query('SELECT SUM(size) AS sum FROM drive_file WHERE "userId" = $1 AND NOT "isLink"', [id])
.then(res => res[0].sum as number ?? 0);
const { sum } = await this
.createQueryBuilder('file')
.where('file.userId = :id', { id })
.andWhere('file.isLink = FALSE')
.select('SUM(file.size)', 'sum')
.getRawOne();
return parseInt(sum, 10) || 0;
}, },
async calcDriveUsageOfHost(host: string): Promise<number> { calcDriveUsageOfHost(host: string): Promise<number> {
const { sum } = await this return db.query('SELECT SUM(size) AS sum FROM drive_file WHERE "userHost" = $1 AND NOT "isLink"', [toPuny(host)])
.createQueryBuilder('file') .then(res => res[0].sum as number ?? 0);
.where('file.userHost = :host', { host: toPuny(host) })
.andWhere('file.isLink = FALSE')
.select('SUM(file.size)', 'sum')
.getRawOne();
return parseInt(sum, 10) || 0;
}, },
async calcDriveUsageOfLocal(): Promise<number> { calcDriveUsageOfLocal(): Promise<number> {
const { sum } = await this return db.query('SELECT SUM(size) AS sum FROM drive_file WHERE "userHost" IS NULL AND NOT "isLink"')
.createQueryBuilder('file') .then(res => res[0].sum as number ?? 0);
.where('file.userHost IS NULL')
.andWhere('file.isLink = FALSE')
.select('SUM(file.size)', 'sum')
.getRawOne();
return parseInt(sum, 10) || 0;
}, },
async calcDriveUsageOfRemote(): Promise<number> { calcDriveUsageOfRemote(): Promise<number> {
const { sum } = await this return db.query('SELECT SUM(size) AS sum FROM drive_file WHERE "userHost" IS NOT NULL AND NOT "isLink"')
.createQueryBuilder('file') .then(res => res[0].sum as number ?? 0);
.where('file.userHost IS NOT NULL')
.andWhere('file.isLink = FALSE')
.select('SUM(file.size)', 'sum')
.getRawOne();
return parseInt(sum, 10) || 0;
}, },
async pack( async pack(