TenantAtlas/apps/platform/.pnpm-store/v10/files/70/5be2349fb3fc7dfacb96d9e2b76d8f1ed57682cea0fee392d792bb1bf7d10285eef606a34c53902369b7cc113aab0276b20d498b554822ae38e02cc19f4dfb
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

57 lines
1.8 KiB
Plaintext

import { is } from "../entity.js";
import { SQL } from "../sql/sql.js";
import { Subquery } from "../subquery.js";
import { Table } from "../table.js";
import { IndexBuilder } from "./indexes.js";
import { PrimaryKeyBuilder } from "./primary-keys.js";
import { SingleStoreTable } from "./table.js";
import { UniqueConstraintBuilder } from "./unique-constraint.js";
function extractUsedTable(table) {
if (is(table, SingleStoreTable)) {
return [`${table[Table.Symbol.BaseName]}`];
}
if (is(table, Subquery)) {
return table._.usedTables ?? [];
}
if (is(table, SQL)) {
return table.usedTables ?? [];
}
return [];
}
function getTableConfig(table) {
const columns = Object.values(table[SingleStoreTable.Symbol.Columns]);
const indexes = [];
const primaryKeys = [];
const uniqueConstraints = [];
const name = table[Table.Symbol.Name];
const schema = table[Table.Symbol.Schema];
const baseName = table[Table.Symbol.BaseName];
const extraConfigBuilder = table[SingleStoreTable.Symbol.ExtraConfigBuilder];
if (extraConfigBuilder !== void 0) {
const extraConfig = extraConfigBuilder(table[SingleStoreTable.Symbol.Columns]);
const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);
for (const builder of Object.values(extraValues)) {
if (is(builder, IndexBuilder)) {
indexes.push(builder.build(table));
} else if (is(builder, UniqueConstraintBuilder)) {
uniqueConstraints.push(builder.build(table));
} else if (is(builder, PrimaryKeyBuilder)) {
primaryKeys.push(builder.build(table));
}
}
}
return {
columns,
indexes,
primaryKeys,
uniqueConstraints,
name,
schema,
baseName
};
}
export {
extractUsedTable,
getTableConfig
};
//# sourceMappingURL=utils.js.map