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.
This commit is contained in:
Kunthawat
2026-03-10 21:28:23 +07:00
parent e98b9f2bff
commit b2e427791b
3282 changed files with 302503 additions and 435 deletions

View File

@@ -0,0 +1,47 @@
import { entityKind } from "../../entity.js";
import { NoopLogger } from "../../logger.js";
import { PgPreparedQuery, PgSession } from "../../pg-core/index.js";
import { fillPlaceholders } from "../../sql/sql.js";
class PrismaPgPreparedQuery extends PgPreparedQuery {
constructor(prisma, query, logger) {
super(query, void 0, void 0, void 0);
this.prisma = prisma;
this.logger = logger;
}
static [entityKind] = "PrismaPgPreparedQuery";
execute(placeholderValues) {
const params = fillPlaceholders(this.query.params, placeholderValues ?? {});
this.logger.logQuery(this.query.sql, params);
return this.prisma.$queryRawUnsafe(this.query.sql, ...params);
}
all() {
throw new Error("Method not implemented.");
}
isResponseInArrayMode() {
return false;
}
}
class PrismaPgSession extends PgSession {
constructor(dialect, prisma, options) {
super(dialect);
this.prisma = prisma;
this.options = options;
this.logger = options.logger ?? new NoopLogger();
}
static [entityKind] = "PrismaPgSession";
logger;
execute(query) {
return this.prepareQuery(this.dialect.sqlToQuery(query)).execute();
}
prepareQuery(query) {
return new PrismaPgPreparedQuery(this.prisma, query, this.logger);
}
transaction(_transaction, _config) {
throw new Error("Method not implemented.");
}
}
export {
PrismaPgPreparedQuery,
PrismaPgSession
};
//# sourceMappingURL=session.js.map