Files
dealplustech/dealplustech-astro/node_modules/drizzle-orm/mysql-proxy/driver.js
Kunthawat b2e427791b feat: Add complete PDPA compliance pages
- Admin dashboard (/admin/consent-logs) with password auth
- Consent API (/api/consent) with SQLite + IP hashing
- Privacy Policy (Thai) - PDPA Section 36 compliant
- Terms & Conditions (Thai) - 9 standard clauses
- .env.example template with Umami placeholder

All pages preserve current design system.
2026-03-10 21:28:23 +07:00

40 lines
1.2 KiB
JavaScript

import { entityKind } from "../entity.js";
import { DefaultLogger } from "../logger.js";
import { MySqlDatabase } from "../mysql-core/db.js";
import { MySqlDialect } from "../mysql-core/dialect.js";
import {
createTableRelationsHelpers,
extractTablesRelationalConfig
} from "../relations.js";
import { MySqlRemoteSession } from "./session.js";
class MySqlRemoteDatabase extends MySqlDatabase {
static [entityKind] = "MySqlRemoteDatabase";
}
function drizzle(callback, config = {}) {
const dialect = new MySqlDialect({ 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 MySqlRemoteSession(callback, dialect, schema, { logger });
return new MySqlRemoteDatabase(dialect, session, schema, "default");
}
export {
MySqlRemoteDatabase,
drizzle
};
//# sourceMappingURL=driver.js.map