server: rewrite drive usage queries in raw SQL
This commit is contained in:
parent
61a2db49df
commit
eaa11647f0
1 changed files with 12 additions and 38 deletions
|
@ -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(
|
||||||
|
|
Loading…
Reference in a new issue