2022-03-31 12:48:32 +05:30
|
|
|
/**
|
|
|
|
* 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
|
2022-04-18 10:37:36 +05:30
|
|
|
* match on both ends i.e. DatabaseCore and DatabaseHandler.
|
2022-03-31 12:48:32 +05:30
|
|
|
*/
|
|
|
|
|
2022-04-11 15:11:49 +05:30
|
|
|
import { SchemaMap } from 'schemas/types';
|
2022-04-07 19:08:17 +05:30
|
|
|
|
2022-03-31 12:48:32 +05:30
|
|
|
type UnknownMap = Record<string, unknown>;
|
|
|
|
export abstract class DatabaseBase {
|
|
|
|
// Create
|
|
|
|
abstract insert(
|
|
|
|
schemaName: string,
|
|
|
|
fieldValueMap: UnknownMap
|
|
|
|
): Promise<UnknownMap>;
|
|
|
|
|
|
|
|
// Read
|
|
|
|
abstract get(
|
|
|
|
schemaName: string,
|
|
|
|
name: string,
|
|
|
|
fields?: string | string[]
|
|
|
|
): Promise<UnknownMap>;
|
|
|
|
|
|
|
|
abstract getAll(
|
|
|
|
schemaName: string,
|
|
|
|
options: GetAllOptions
|
|
|
|
): Promise<UnknownMap[]>;
|
|
|
|
|
|
|
|
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<void>;
|
|
|
|
|
|
|
|
abstract update(schemaName: string, fieldValueMap: UnknownMap): Promise<void>;
|
|
|
|
|
|
|
|
// Delete
|
|
|
|
abstract delete(schemaName: string, name: string): Promise<void>;
|
2022-11-02 19:37:54 +05:30
|
|
|
|
|
|
|
abstract deleteAll(schemaName:string, filters:QueryFilter): Promise<number>;
|
2022-03-31 12:48:32 +05:30
|
|
|
|
|
|
|
// Other
|
|
|
|
abstract close(): Promise<void>;
|
|
|
|
|
|
|
|
abstract exists(schemaName: string, name?: string): Promise<boolean>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type DatabaseMethod = keyof DatabaseBase;
|
|
|
|
|
|
|
|
export interface GetAllOptions {
|
|
|
|
fields?: string[];
|
|
|
|
filters?: QueryFilter;
|
|
|
|
offset?: number;
|
|
|
|
limit?: number;
|
2023-01-05 11:14:05 +05:30
|
|
|
groupBy?: string | string[];
|
|
|
|
orderBy?: string | string[];
|
2022-03-31 12:48:32 +05:30
|
|
|
order?: 'asc' | 'desc';
|
|
|
|
}
|
|
|
|
|
2022-04-11 15:11:49 +05:30
|
|
|
export type QueryFilter = Record<
|
|
|
|
string,
|
2022-11-01 18:51:21 +05:30
|
|
|
boolean | string | null | (string | number | (string | number | null)[])[]
|
2022-04-11 15:11:49 +05:30
|
|
|
>;
|
2022-04-07 19:08:17 +05:30
|
|
|
|
|
|
|
/**
|
|
|
|
* DatabaseDemuxBase is an abstract class that ensures that the function signatures
|
|
|
|
* match between the DatabaseManager and the DatabaseDemux.
|
2022-04-11 15:11:49 +05:30
|
|
|
*
|
2022-04-07 19:08:17 +05:30
|
|
|
* This allows testing the frontend code while directly plugging in the DatabaseManager
|
|
|
|
* and bypassing all the API and IPC calls.
|
|
|
|
*/
|
|
|
|
export abstract class DatabaseDemuxBase {
|
2022-04-11 15:11:49 +05:30
|
|
|
abstract getSchemaMap(): Promise<SchemaMap> | SchemaMap;
|
2022-04-07 19:08:17 +05:30
|
|
|
|
2022-04-11 15:11:49 +05:30
|
|
|
abstract createNewDatabase(
|
|
|
|
dbPath: string,
|
2022-04-18 12:12:56 +05:30
|
|
|
countryCode: string
|
|
|
|
): Promise<string>;
|
2022-04-11 15:11:49 +05:30
|
|
|
|
|
|
|
abstract connectToDatabase(
|
|
|
|
dbPath: string,
|
|
|
|
countryCode?: string
|
2022-04-18 12:12:56 +05:30
|
|
|
): Promise<string>;
|
2022-04-07 19:08:17 +05:30
|
|
|
|
2022-04-11 15:11:49 +05:30
|
|
|
abstract call(method: DatabaseMethod, ...args: unknown[]): Promise<unknown>;
|
2022-04-07 19:08:17 +05:30
|
|
|
|
2022-04-11 15:11:49 +05:30
|
|
|
abstract callBespoke(method: string, ...args: unknown[]): Promise<unknown>;
|
2022-04-07 19:08:17 +05:30
|
|
|
}
|