TenantAtlas/apps/platform/.pnpm-store/v10/files/54/1f1c9d290dda470131743214df265695375395119dc9e7adabd7e9210bb0a4337ee571460d8242e45e0a2ec11eb04208d04d222acef6326a57b7f173707f9f
Ahmed Darrazi 9f74f7a658
Some checks failed
PR Fast Feedback / fast-feedback (pull_request) Failing after 51s
feat: compress governance operator outcomes
2026-04-19 14:15:11 +02:00

49 lines
1.4 KiB
Plaintext

import { entityKind } from "../entity.js";
import { DefaultLogger } from "../logger.js";
import {
createTableRelationsHelpers,
extractTablesRelationalConfig
} from "../relations.js";
import { BaseSQLiteDatabase } from "../sqlite-core/db.js";
import { SQLiteAsyncDialect } from "../sqlite-core/dialect.js";
import { LibSQLSession } from "./session.js";
class LibSQLDatabase extends BaseSQLiteDatabase {
static [entityKind] = "LibSQLDatabase";
async batch(batch) {
return this.session.batch(batch);
}
}
function construct(client, config = {}) {
const dialect = new SQLiteAsyncDialect({ casing: config.casing });
let logger;
if (config.logger === true) {
logger = new DefaultLogger();
} else if (config.logger !== false) {
logger = config.logger;
}
let schema;
if (config.schema) {
const tablesConfig = extractTablesRelationalConfig(
config.schema,
createTableRelationsHelpers
);
schema = {
fullSchema: config.schema,
schema: tablesConfig.tables,
tableNamesMap: tablesConfig.tableNamesMap
};
}
const session = new LibSQLSession(client, dialect, schema, { logger, cache: config.cache }, void 0);
const db = new LibSQLDatabase("async", dialect, session, schema);
db.$client = client;
db.$cache = config.cache;
if (db.$cache) {
db.$cache["invalidate"] = config.cache?.onMutate;
}
return db;
}
export {
LibSQLDatabase,
construct
};
//# sourceMappingURL=driver-core.js.map