TenantAtlas/apps/platform/.pnpm-store/v10/files/9a/a1953e6883a44ca895127c05a0aa19f71d3b9d01f55de2d1ef64bf36ecbbbf64eb8fd4580758b1e219cf54cca40d19bef4ca3552073ff3f6f6130d02388219
ahmido 1fec9c6f9d
Some checks failed
Main Confidence / confidence (push) Failing after 45s
feat: compress governance operator outcomes (#253)
## Summary
- introduce surface-aware compressed governance outcomes and reuse the shared truth/explanation seams for operator-first summaries
- apply the compressed outcome hierarchy across baseline, evidence, review, review-pack, canonical review/evidence, and artifact-oriented operation-run surfaces
- expand spec 214 fixtures and Pest coverage, and fix tenant-panel route assertions by generating explicit tenant-panel URLs in the affected Filament tests

## Validation
- `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent`
- focused governance compression suite from `specs/214-governance-outcome-compression/quickstart.md` passed (`68` tests, `445` assertions)
- `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Filament/InventoryItemResourceTest.php tests/Feature/Filament/BackupSetUiEnforcementTest.php tests/Feature/Filament/RestoreRunUiEnforcementTest.php` passed (`18` tests, `81` assertions)

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #253
2026-04-19 12:30:36 +00:00

132 lines
4.1 KiB
Plaintext

import { neon, types } from "@neondatabase/serverless";
import { entityKind } from "../entity.js";
import { DefaultLogger } from "../logger.js";
import { PgDatabase } from "../pg-core/db.js";
import { PgDialect } from "../pg-core/dialect.js";
import { createTableRelationsHelpers, extractTablesRelationalConfig } from "../relations.js";
import { isConfig } from "../utils.js";
import { NeonHttpSession } from "./session.js";
class NeonHttpDriver {
constructor(client, dialect, options = {}) {
this.client = client;
this.dialect = dialect;
this.options = options;
this.initMappers();
}
static [entityKind] = "NeonHttpDriver";
createSession(schema) {
return new NeonHttpSession(this.client, this.dialect, schema, {
logger: this.options.logger,
cache: this.options.cache
});
}
initMappers() {
types.setTypeParser(types.builtins.TIMESTAMPTZ, (val) => val);
types.setTypeParser(types.builtins.TIMESTAMP, (val) => val);
types.setTypeParser(types.builtins.DATE, (val) => val);
types.setTypeParser(types.builtins.INTERVAL, (val) => val);
types.setTypeParser(1231, (val) => val);
types.setTypeParser(1115, (val) => val);
types.setTypeParser(1185, (val) => val);
types.setTypeParser(1187, (val) => val);
types.setTypeParser(1182, (val) => val);
}
}
function wrap(target, token, cb, deep) {
return new Proxy(target, {
get(target2, p) {
const element = target2[p];
if (typeof element !== "function" && (typeof element !== "object" || element === null)) return element;
if (deep) return wrap(element, token, cb);
if (p === "query") return wrap(element, token, cb, true);
return new Proxy(element, {
apply(target3, thisArg, argArray) {
const res = target3.call(thisArg, ...argArray);
if (typeof res === "object" && res !== null && "setToken" in res && typeof res.setToken === "function") {
res.setToken(token);
}
return cb(target3, p, res);
}
});
}
});
}
class NeonHttpDatabase extends PgDatabase {
static [entityKind] = "NeonHttpDatabase";
$withAuth(token) {
this.authToken = token;
return wrap(this, token, (target, p, res) => {
if (p === "with") {
return wrap(res, token, (_, __, res2) => res2);
}
return res;
});
}
async batch(batch) {
return this.session.batch(batch);
}
}
function construct(client, config = {}) {
const dialect = new PgDialect({ 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 driver = new NeonHttpDriver(client, dialect, { logger, cache: config.cache });
const session = driver.createSession(schema);
const db = new NeonHttpDatabase(
dialect,
session,
schema
);
db.$client = client;
db.$cache = config.cache;
if (db.$cache) {
db.$cache["invalidate"] = config.cache?.onMutate;
}
return db;
}
function drizzle(...params) {
if (typeof params[0] === "string") {
const instance = neon(params[0]);
return construct(instance, params[1]);
}
if (isConfig(params[0])) {
const { connection, client, ...drizzleConfig } = params[0];
if (client) return construct(client, drizzleConfig);
if (typeof connection === "object") {
const { connectionString, ...options } = connection;
const instance2 = neon(connectionString, options);
return construct(instance2, drizzleConfig);
}
const instance = neon(connection);
return construct(instance, drizzleConfig);
}
return construct(params[0], params[1]);
}
((drizzle2) => {
function mock(config) {
return construct({}, config);
}
drizzle2.mock = mock;
})(drizzle || (drizzle = {}));
export {
NeonHttpDatabase,
NeonHttpDriver,
drizzle
};
//# sourceMappingURL=driver.js.map