2022-03-24 15:20:40 +05:30
|
|
|
import { Field, RawValue } from '../../schemas/types';
|
2022-04-11 11:34:55 +05:30
|
|
|
import DatabaseCore from './core';
|
2022-03-25 15:42:39 +05:30
|
|
|
import { DatabaseManager } from './manager';
|
2022-03-24 15:20:40 +05:30
|
|
|
|
2022-03-23 11:46:13 +05:30
|
|
|
export interface GetQueryBuilderOptions {
|
2022-03-25 15:42:39 +05:30
|
|
|
offset?: number;
|
|
|
|
limit?: number;
|
|
|
|
groupBy?: string;
|
|
|
|
orderBy?: string;
|
|
|
|
order?: 'desc' | 'asc';
|
2022-03-23 11:46:13 +05:30
|
|
|
}
|
2022-03-24 15:20:40 +05:30
|
|
|
|
|
|
|
export type ColumnDiff = { added: Field[]; removed: string[] };
|
|
|
|
export type FieldValueMap = Record<
|
|
|
|
string,
|
|
|
|
RawValue | undefined | FieldValueMap[]
|
|
|
|
>;
|
2022-03-24 18:43:59 +05:30
|
|
|
|
|
|
|
export interface Patch {
|
|
|
|
name: string;
|
|
|
|
version: string;
|
|
|
|
patch: {
|
2022-03-25 15:42:39 +05:30
|
|
|
execute: (dm: DatabaseManager) => Promise<void>;
|
2022-03-24 18:43:59 +05:30
|
|
|
beforeMigrate?: boolean;
|
|
|
|
};
|
|
|
|
}
|
2022-03-25 15:42:39 +05:30
|
|
|
|
|
|
|
export type KnexColumnType =
|
|
|
|
| 'text'
|
|
|
|
| 'integer'
|
|
|
|
| 'float'
|
|
|
|
| 'boolean'
|
|
|
|
| 'date'
|
|
|
|
| 'datetime'
|
|
|
|
| 'time'
|
|
|
|
| 'binary';
|
2022-03-28 15:31:29 +05:30
|
|
|
|
|
|
|
// Returned by pragma table_info
|
|
|
|
export interface SqliteTableInfo {
|
|
|
|
pk: number;
|
|
|
|
cid: number;
|
|
|
|
name: string;
|
|
|
|
type: string;
|
|
|
|
notnull: number; // 0 | 1
|
|
|
|
dflt_value: string | null;
|
|
|
|
}
|
2022-04-11 11:34:55 +05:30
|
|
|
|
2022-04-18 16:59:20 +05:30
|
|
|
export type BespokeFunction = (db:DatabaseCore, ...args: unknown[]) => Promise<unknown>
|
|
|
|
export type SingleValue<T> = {
|
|
|
|
fieldname: string;
|
|
|
|
parent: string;
|
|
|
|
value: T;
|
|
|
|
}[];
|