mirror of
https://github.com/immich-app/immich.git
synced 2026-03-01 18:19:10 +03:00
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { Injectable } from '@nestjs/common';
|
|
import { Insertable, Kysely } from 'kysely';
|
|
import { InjectKysely } from 'nestjs-kysely';
|
|
import { readFile } from 'node:fs/promises';
|
|
import { GenerateSql } from 'src/decorators';
|
|
import { DB } from 'src/schema';
|
|
import { SystemMetadataTable } from 'src/schema/tables/system-metadata.table';
|
|
import { SystemMetadata } from 'src/types';
|
|
|
|
type Upsert = Insertable<SystemMetadataTable>;
|
|
|
|
@Injectable()
|
|
export class SystemMetadataRepository {
|
|
constructor(@InjectKysely() private db: Kysely<DB>) {}
|
|
|
|
@GenerateSql({ params: ['metadata_key'] })
|
|
async get<T extends keyof SystemMetadata>(key: T): Promise<SystemMetadata[T] | null> {
|
|
const metadata = await this.db
|
|
.selectFrom('system_metadata')
|
|
.select('value')
|
|
.where('key', '=', key)
|
|
.executeTakeFirst();
|
|
|
|
if (!metadata) {
|
|
return null;
|
|
}
|
|
return metadata.value as SystemMetadata[T];
|
|
}
|
|
|
|
async set<T extends keyof SystemMetadata>(key: T, value: SystemMetadata[T]): Promise<void> {
|
|
await this.db
|
|
.insertInto('system_metadata')
|
|
.values({ key, value } as Upsert)
|
|
.onConflict((oc) => oc.columns(['key']).doUpdateSet({ value } as Upsert))
|
|
.execute();
|
|
}
|
|
|
|
@GenerateSql({ params: ['metadata_key'] })
|
|
async delete<T extends keyof SystemMetadata>(key: T): Promise<void> {
|
|
await this.db.deleteFrom('system_metadata').where('key', '=', key).execute();
|
|
}
|
|
|
|
readFile(filename: string): Promise<string> {
|
|
return readFile(filename, { encoding: 'utf8' });
|
|
}
|
|
}
|