/** * The types in this file will be used by the main db class (core.ts) in the * backend process and the the frontend db class (dbHandler.ts). * * DatabaseBase is an abstract class so that the function signatures * match on both ends. */ import { SchemaMap } from "schemas/types"; type UnknownMap = Record; export abstract class DatabaseBase { // Create abstract insert( schemaName: string, fieldValueMap: UnknownMap ): Promise; // Read abstract get( schemaName: string, name: string, fields?: string | string[] ): Promise; abstract getAll( schemaName: string, options: GetAllOptions ): Promise; abstract getSingleValues( ...fieldnames: ({ fieldname: string; parent?: string } | string)[] ): Promise<{ fieldname: string; parent: string; value: unknown }[]>; // Update abstract rename( schemaName: string, oldName: string, newName: string ): Promise; abstract update(schemaName: string, fieldValueMap: UnknownMap): Promise; // Delete abstract delete(schemaName: string, name: string): Promise; // Other abstract close(): Promise; abstract exists(schemaName: string, name?: string): Promise; } export type DatabaseMethod = keyof DatabaseBase; export interface GetAllOptions { fields?: string[]; filters?: QueryFilter; offset?: number; limit?: number; groupBy?: string; orderBy?: string; order?: 'asc' | 'desc'; } export type QueryFilter = Record; /** * DatabaseDemuxBase is an abstract class that ensures that the function signatures * match between the DatabaseManager and the DatabaseDemux. * * This allows testing the frontend code while directly plugging in the DatabaseManager * and bypassing all the API and IPC calls. */ export abstract class DatabaseDemuxBase { abstract getSchemaMap(): Promise | SchemaMap abstract createNewDatabase(dbPath: string, countryCode?: string): Promise abstract connectToDatabase(dbPath: string, countryCode?: string): Promise abstract call(method: DatabaseMethod, ...args: unknown[]): Promise abstract callBespoke(method: string, ...args: unknown[]): Promise }