- 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.
17 lines
935 B
TypeScript
17 lines
935 B
TypeScript
import type { ColumnType } from 'kysely';
|
|
import type { InferInsertModel, InferSelectModel, MapColumnName, Table } from "../table.js";
|
|
import type { Simplify } from "../utils.js";
|
|
export type Kyselify<T extends Table> = Simplify<{
|
|
[Key in keyof T['_']['columns'] & string as MapColumnName<Key, T['_']['columns'][Key], true>]: ColumnType<InferSelectModel<T, {
|
|
dbColumnNames: true;
|
|
}>[MapColumnName<Key, T['_']['columns'][Key], true>], MapColumnName<Key, T['_']['columns'][Key], true> extends keyof InferInsertModel<T, {
|
|
dbColumnNames: true;
|
|
}> ? InferInsertModel<T, {
|
|
dbColumnNames: true;
|
|
}>[MapColumnName<Key, T['_']['columns'][Key], true>] : never, MapColumnName<Key, T['_']['columns'][Key], true> extends keyof InferInsertModel<T, {
|
|
dbColumnNames: true;
|
|
}> ? InferInsertModel<T, {
|
|
dbColumnNames: true;
|
|
}>[MapColumnName<Key, T['_']['columns'][Key], true>] : never>;
|
|
}>;
|