TenantAtlas/apps/platform/.pnpm-store/v10/files/33/949bc0674cbb9d8531657e529ac5989a5c9401abc39a631957cbd2bb3ed3de516a9c89fe1abf60d93368c22eae602375d6d2744eb42466e132a59eb71cf1c8
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

457 lines
19 KiB
Plaintext

"use strict";
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var pageDispatcher_exports = {};
__export(pageDispatcher_exports, {
BindingCallDispatcher: () => BindingCallDispatcher,
PageDispatcher: () => PageDispatcher,
WorkerDispatcher: () => WorkerDispatcher
});
module.exports = __toCommonJS(pageDispatcher_exports);
var import_page = require("../page");
var import_dispatcher = require("./dispatcher");
var import_errors = require("../errors");
var import_artifactDispatcher = require("./artifactDispatcher");
var import_elementHandlerDispatcher = require("./elementHandlerDispatcher");
var import_frameDispatcher = require("./frameDispatcher");
var import_jsHandleDispatcher = require("./jsHandleDispatcher");
var import_networkDispatchers = require("./networkDispatchers");
var import_networkDispatchers2 = require("./networkDispatchers");
var import_networkDispatchers3 = require("./networkDispatchers");
var import_webSocketRouteDispatcher = require("./webSocketRouteDispatcher");
var import_disposableDispatcher = require("./disposableDispatcher");
var import_instrumentation = require("../instrumentation");
var import_urlMatch = require("../../utils/isomorphic/urlMatch");
var import_recorder = require("../recorder");
var import_disposable = require("../disposable");
var import_videoRecorder = require("../videoRecorder");
class PageDispatcher extends import_dispatcher.Dispatcher {
constructor(parentScope, page) {
const mainFrame = import_frameDispatcher.FrameDispatcher.from(parentScope, page.mainFrame());
super(parentScope, page, "Page", {
mainFrame,
viewportSize: page.emulatedSize()?.viewport,
isClosed: page.isClosed(),
opener: PageDispatcher.fromNullable(parentScope, page.opener()),
video: page.video ? createVideoDispatcher(parentScope, page.video) : void 0
});
this._type_EventTarget = true;
this._type_Page = true;
this._subscriptions = /* @__PURE__ */ new Set();
this._webSocketInterceptionPatterns = [];
this._disposables = [];
this._interceptionUrlMatchers = [];
this._locatorHandlers = /* @__PURE__ */ new Set();
this._jsCoverageActive = false;
this._cssCoverageActive = false;
this.adopt(mainFrame);
this._page = page;
this._requestInterceptor = (route, request) => {
const matchesSome = this._interceptionUrlMatchers.some((urlMatch) => (0, import_urlMatch.urlMatches)(this._page.browserContext._options.baseURL, request.url(), urlMatch));
if (!matchesSome) {
route.continue({ isFallback: true }).catch(() => {
});
return;
}
this._dispatchEvent("route", { route: new import_networkDispatchers3.RouteDispatcher(import_networkDispatchers.RequestDispatcher.from(this.parentScope(), request), route) });
};
this.addObjectListener(import_page.Page.Events.Close, () => {
this._dispatchEvent("close");
this._dispose();
});
this.addObjectListener(import_page.Page.Events.Crash, () => this._dispatchEvent("crash"));
this.addObjectListener(import_page.Page.Events.Download, (download) => {
this._dispatchEvent("download", { url: download.url, suggestedFilename: download.suggestedFilename(), artifact: import_artifactDispatcher.ArtifactDispatcher.from(parentScope, download.artifact) });
});
this.addObjectListener(import_page.Page.Events.EmulatedSizeChanged, () => this._dispatchEvent("viewportSizeChanged", { viewportSize: page.emulatedSize()?.viewport }));
this.addObjectListener(import_page.Page.Events.FileChooser, (fileChooser) => this._dispatchEvent("fileChooser", {
element: import_elementHandlerDispatcher.ElementHandleDispatcher.from(mainFrame, fileChooser.element()),
isMultiple: fileChooser.isMultiple()
}));
this.addObjectListener(import_page.Page.Events.FrameAttached, (frame) => this._onFrameAttached(frame));
this.addObjectListener(import_page.Page.Events.FrameDetached, (frame) => this._onFrameDetached(frame));
this.addObjectListener(import_page.Page.Events.LocatorHandlerTriggered, (uid) => this._dispatchEvent("locatorHandlerTriggered", { uid }));
this.addObjectListener(import_page.Page.Events.WebSocket, (webSocket) => this._dispatchEvent("webSocket", { webSocket: new import_networkDispatchers3.WebSocketDispatcher(this, webSocket) }));
this.addObjectListener(import_page.Page.Events.Worker, (worker) => this._dispatchEvent("worker", { worker: new WorkerDispatcher(this, worker) }));
const frames = page.frameManager.frames();
for (let i = 1; i < frames.length; i++)
this._onFrameAttached(frames[i]);
}
static from(parentScope, page) {
return PageDispatcher.fromNullable(parentScope, page);
}
static fromNullable(parentScope, page) {
if (!page)
return void 0;
const result = parentScope.connection.existingDispatcher(page);
return result || new PageDispatcher(parentScope, page);
}
page() {
return this._page;
}
async exposeBinding(params, progress) {
const binding = await this._page.exposeBinding(progress, params.name, !!params.needsHandle, (source, ...args) => {
if (this._disposed)
return;
const binding2 = new BindingCallDispatcher(this, params.name, !!params.needsHandle, source, args);
this._dispatchEvent("bindingCall", { binding: binding2 });
return binding2.promise();
});
this._disposables.push(binding);
return { disposable: new import_disposableDispatcher.DisposableDispatcher(this, binding) };
}
async setExtraHTTPHeaders(params, progress) {
await this._page.setExtraHTTPHeaders(progress, params.headers);
}
async reload(params, progress) {
return { response: import_networkDispatchers2.ResponseDispatcher.fromNullable(this.parentScope(), await this._page.reload(progress, params)) };
}
async goBack(params, progress) {
return { response: import_networkDispatchers2.ResponseDispatcher.fromNullable(this.parentScope(), await this._page.goBack(progress, params)) };
}
async goForward(params, progress) {
return { response: import_networkDispatchers2.ResponseDispatcher.fromNullable(this.parentScope(), await this._page.goForward(progress, params)) };
}
async requestGC(params, progress) {
await progress.race(this._page.requestGC());
}
async registerLocatorHandler(params, progress) {
const uid = this._page.registerLocatorHandler(params.selector, params.noWaitAfter);
this._locatorHandlers.add(uid);
return { uid };
}
async resolveLocatorHandlerNoReply(params, progress) {
this._page.resolveLocatorHandler(params.uid, params.remove);
}
async unregisterLocatorHandler(params, progress) {
this._page.unregisterLocatorHandler(params.uid);
this._locatorHandlers.delete(params.uid);
}
async emulateMedia(params, progress) {
await this._page.emulateMedia(progress, {
media: params.media,
colorScheme: params.colorScheme,
reducedMotion: params.reducedMotion,
forcedColors: params.forcedColors,
contrast: params.contrast
});
}
async setViewportSize(params, progress) {
await this._page.setViewportSize(progress, params.viewportSize);
}
async addInitScript(params, progress) {
const initScript = await this._page.addInitScript(params.source);
this._disposables.push(initScript);
return { disposable: new import_disposableDispatcher.DisposableDispatcher(this, initScript) };
}
async setNetworkInterceptionPatterns(params, progress) {
const hadMatchers = this._interceptionUrlMatchers.length > 0;
if (!params.patterns.length) {
if (hadMatchers)
await this._page.removeRequestInterceptor(this._requestInterceptor);
this._interceptionUrlMatchers = [];
} else {
this._interceptionUrlMatchers = params.patterns.map(import_urlMatch.deserializeURLMatch);
if (!hadMatchers)
await this._page.addRequestInterceptor(progress, this._requestInterceptor);
}
}
async setWebSocketInterceptionPatterns(params, progress) {
this._webSocketInterceptionPatterns = params.patterns;
if (params.patterns.length && !this._routeWebSocketInitScript)
this._routeWebSocketInitScript = await import_webSocketRouteDispatcher.WebSocketRouteDispatcher.install(progress, this.connection, this._page);
}
async expectScreenshot(params, progress) {
const mask = (params.mask || []).map(({ frame, selector }) => ({
frame: frame._object,
selector
}));
const locator = params.locator ? {
frame: params.locator.frame._object,
selector: params.locator.selector
} : void 0;
return await this._page.expectScreenshot(progress, {
...params,
locator,
mask
});
}
async screenshot(params, progress) {
const mask = (params.mask || []).map(({ frame, selector }) => ({
frame: frame._object,
selector
}));
return { binary: await this._page.screenshot(progress, { ...params, mask }) };
}
async close(params, progress) {
if (!params.runBeforeUnload)
progress.metadata.potentiallyClosesScope = true;
await this._page.close(params);
}
async updateSubscription(params, progress) {
if (params.event === "fileChooser")
await this._page.setFileChooserInterceptedBy(params.enabled, this);
if (params.enabled)
this._subscriptions.add(params.event);
else
this._subscriptions.delete(params.event);
}
async keyboardDown(params, progress) {
await this._page.keyboard.apiDown(progress, params.key);
}
async keyboardUp(params, progress) {
await this._page.keyboard.apiUp(progress, params.key);
}
async keyboardInsertText(params, progress) {
await this._page.keyboard.apiInsertText(progress, params.text);
}
async keyboardType(params, progress) {
await this._page.keyboard.apiType(progress, params.text, params);
}
async keyboardPress(params, progress) {
await this._page.keyboard.apiPress(progress, params.key, params);
}
async clearConsoleMessages(params, progress) {
this._page.clearConsoleMessages();
}
async consoleMessages(params, progress) {
this._subscriptions.add("console");
return { messages: this._page.consoleMessages(params.filter).map((message) => this.parentScope().serializeConsoleMessage(message, this)) };
}
async clearPageErrors(params, progress) {
this._page.clearPageErrors();
}
async pageErrors(params, progress) {
return { errors: this._page.pageErrors(params.filter).map((error) => (0, import_errors.serializeError)(error)) };
}
async mouseMove(params, progress) {
await this._page.mouse.apiMove(progress, params.x, params.y, params);
}
async mouseDown(params, progress) {
await this._page.mouse.apiDown(progress, params);
}
async mouseUp(params, progress) {
await this._page.mouse.apiUp(progress, params);
}
async mouseClick(params, progress) {
await this._page.mouse.apiClick(progress, params.x, params.y, params);
}
async mouseWheel(params, progress) {
await this._page.mouse.apiWheel(progress, params.deltaX, params.deltaY);
}
async touchscreenTap(params, progress) {
progress.metadata.point = { x: params.x, y: params.y };
await this._page.touchscreen.apiTap(progress, params.x, params.y);
}
async pdf(params, progress) {
if (!this._page.pdf)
throw new Error("PDF generation is only supported for Headless Chromium");
const buffer = await progress.race(this._page.pdf(params));
return { pdf: buffer };
}
async requests(params, progress) {
this._subscriptions.add("request");
return { requests: this._page.networkRequests().map((request) => import_networkDispatchers.RequestDispatcher.from(this.parentScope(), request)) };
}
async bringToFront(params, progress) {
await progress.race(this._page.bringToFront());
}
async pickLocator(params, progress) {
const recorder = await import_recorder.Recorder.forContext(this._page.browserContext, { omitCallTracking: true, hideToolbar: true });
const selector = await recorder.pickLocator(progress, this._page);
return { selector };
}
async cancelPickLocator(params, progress) {
const recorder = await import_recorder.Recorder.existingForContext(this._page.browserContext);
await recorder?.setMode("none");
}
async screencastShowOverlay(params) {
const id = await this._page.overlay.show(params.html, params.duration);
return { id };
}
async screencastRemoveOverlay(params) {
await this._page.overlay.remove(params.id);
}
async screencastChapter(params) {
await this._page.overlay.chapter(params);
}
async screencastSetOverlayVisible(params) {
await this._page.overlay.setVisible(params.visible);
}
async screencastShowActions(params) {
this._page.screencast.showActions({ duration: params.duration, position: params.position, fontSize: params.fontSize });
}
async screencastHideActions() {
this._page.screencast.hideActions();
}
async screencastStart(params, progress) {
if (this._screencastClient || this._videoRecorder)
throw new Error("Screencast is already running");
if (params.sendFrames) {
this._screencastClient = {
onFrame: (frame) => {
this._dispatchEvent("screencastFrame", { data: frame.buffer });
},
dispose: () => {
},
size: params.size,
quality: params.quality
};
this._page.screencast.addClient(this._screencastClient);
}
let artifact;
if (params.record) {
this._videoRecorder = new import_videoRecorder.VideoRecorder(this._page.screencast);
artifact = this._videoRecorder.start(params);
}
return { artifact: artifact ? createVideoDispatcher(this.parentScope(), artifact) : void 0 };
}
async screencastStop(params, progress) {
if (this._videoRecorder) {
await this._videoRecorder.stop();
this._videoRecorder = void 0;
}
const client = this._screencastClient;
this._screencastClient = void 0;
if (client)
this._page.screencast.removeClient(client);
}
async startJSCoverage(params, progress) {
const coverage = this._page.coverage;
await coverage.startJSCoverage(progress, params);
this._jsCoverageActive = true;
}
async stopJSCoverage(params, progress) {
this._jsCoverageActive = false;
const coverage = this._page.coverage;
return await coverage.stopJSCoverage();
}
async startCSSCoverage(params, progress) {
const coverage = this._page.coverage;
await coverage.startCSSCoverage(progress, params);
this._cssCoverageActive = true;
}
async stopCSSCoverage(params, progress) {
this._cssCoverageActive = false;
const coverage = this._page.coverage;
return await coverage.stopCSSCoverage();
}
_onFrameAttached(frame) {
this._dispatchEvent("frameAttached", { frame: import_frameDispatcher.FrameDispatcher.from(this.parentScope(), frame) });
}
_onFrameDetached(frame) {
this._dispatchEvent("frameDetached", { frame: import_frameDispatcher.FrameDispatcher.from(this.parentScope(), frame) });
}
_onDispose() {
if (this._page.isClosedOrClosingOrCrashed())
return;
this._interceptionUrlMatchers = [];
this._page.removeRequestInterceptor(this._requestInterceptor).catch(() => {
});
(0, import_disposable.disposeAll)(this._disposables).catch(() => {
});
if (this._routeWebSocketInitScript)
import_webSocketRouteDispatcher.WebSocketRouteDispatcher.uninstall(this.connection, this._page, this._routeWebSocketInitScript).catch(() => {
});
this._routeWebSocketInitScript = void 0;
for (const uid of this._locatorHandlers)
this._page.unregisterLocatorHandler(uid);
this._locatorHandlers.clear();
this._page.setFileChooserInterceptedBy(false, this).catch(() => {
});
if (this._jsCoverageActive)
this._page.coverage.stopJSCoverage().catch(() => {
});
this._jsCoverageActive = false;
if (this._cssCoverageActive)
this._page.coverage.stopCSSCoverage().catch(() => {
});
this._cssCoverageActive = false;
this.screencastStop({}, void 0).catch(() => {
});
}
async setDockTile(params) {
await this._page.setDockTile(params.image);
}
}
class WorkerDispatcher extends import_dispatcher.Dispatcher {
constructor(scope, worker) {
super(scope, worker, "Worker", {
url: worker.url
});
this._type_Worker = true;
this._type_EventTarget = true;
this._subscriptions = /* @__PURE__ */ new Set();
this.addObjectListener(import_page.Worker.Events.Close, () => this._dispatchEvent("close"));
}
static fromNullable(scope, worker) {
if (!worker)
return void 0;
const result = scope.connection.existingDispatcher(worker);
return result || new WorkerDispatcher(scope, worker);
}
async evaluateExpression(params, progress) {
return { value: (0, import_jsHandleDispatcher.serializeResult)(await progress.race(this._object.evaluateExpression(params.expression, params.isFunction, (0, import_jsHandleDispatcher.parseArgument)(params.arg)))) };
}
async evaluateExpressionHandle(params, progress) {
return { handle: import_jsHandleDispatcher.JSHandleDispatcher.fromJSHandle(this, await progress.race(this._object.evaluateExpressionHandle(params.expression, params.isFunction, (0, import_jsHandleDispatcher.parseArgument)(params.arg)))) };
}
async updateSubscription(params, progress) {
if (params.enabled)
this._subscriptions.add(params.event);
else
this._subscriptions.delete(params.event);
}
}
class BindingCallDispatcher extends import_dispatcher.Dispatcher {
constructor(scope, name, needsHandle, source, args) {
const frameDispatcher = import_frameDispatcher.FrameDispatcher.from(scope.parentScope(), source.frame);
super(scope, new import_instrumentation.SdkObject(scope._object, "bindingCall"), "BindingCall", {
frame: frameDispatcher,
name,
args: needsHandle ? void 0 : args.map(import_jsHandleDispatcher.serializeResult),
handle: needsHandle ? import_elementHandlerDispatcher.ElementHandleDispatcher.fromJSOrElementHandle(frameDispatcher, args[0]) : void 0
});
this._type_BindingCall = true;
this._promise = new Promise((resolve, reject) => {
this._resolve = resolve;
this._reject = reject;
});
}
promise() {
return this._promise;
}
async resolve(params, progress) {
this._resolve((0, import_jsHandleDispatcher.parseArgument)(params.result));
this._dispose();
}
async reject(params, progress) {
this._reject((0, import_errors.parseError)(params.error));
this._dispose();
}
}
function createVideoDispatcher(parentScope, video) {
return import_artifactDispatcher.ArtifactDispatcher.from(parentScope.parentScope(), video);
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
BindingCallDispatcher,
PageDispatcher,
WorkerDispatcher
});