@agenticmail/enterprise 0.5.78 → 0.5.80
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-7MILGDAA.js +2191 -0
- package/dist/chunk-7RNT4O5T.js +15198 -0
- package/dist/chunk-AGFOJCSB.js +2191 -0
- package/dist/chunk-F4GSFCM3.js +898 -0
- package/dist/chunk-GWUIYH7I.js +15035 -0
- package/dist/chunk-PZA7YOJE.js +898 -0
- package/dist/chunk-Q3V7VZFQ.js +2191 -0
- package/dist/chunk-RRFB6G6M.js +15198 -0
- package/dist/chunk-VX3VFMVB.js +409 -0
- package/dist/chunk-WRPZCOWC.js +898 -0
- package/dist/cli.js +1 -1
- package/dist/dashboard/pages/agent-detail.js +313 -1
- package/dist/index.js +3 -3
- package/dist/pw-ai-KPETTB25.js +2212 -0
- package/dist/routes-PDHMCIXU.js +6676 -0
- package/dist/runtime-7HW4GX5L.js +48 -0
- package/dist/runtime-GYVO3NF3.js +47 -0
- package/dist/runtime-XXDCZZIK.js +48 -0
- package/dist/server-FMP4BFGW.js +12 -0
- package/dist/server-JRHDUNII.js +12 -0
- package/dist/server-VNW6G4GB.js +12 -0
- package/dist/setup-AANLREEL.js +20 -0
- package/dist/setup-O5FPRLK4.js +20 -0
- package/dist/setup-S4Z4PPIJ.js +20 -0
- package/package.json +15 -2
- package/src/agent-tools/common.ts +25 -0
- package/src/agent-tools/index.ts +4 -0
- package/src/agent-tools/schema/typebox.ts +25 -0
- package/src/agent-tools/tools/browser-tool.schema.ts +112 -0
- package/src/agent-tools/tools/browser-tool.ts +388 -0
- package/src/agent-tools/tools/gateway.ts +126 -0
- package/src/agent-tools/tools/nodes-utils.ts +80 -0
- package/src/browser/bridge-auth-registry.ts +34 -0
- package/src/browser/bridge-server.ts +93 -0
- package/src/browser/cdp.helpers.ts +180 -0
- package/src/browser/cdp.ts +466 -0
- package/src/browser/chrome.executables.ts +625 -0
- package/src/browser/chrome.profile-decoration.ts +198 -0
- package/src/browser/chrome.ts +349 -0
- package/src/browser/client-actions-core.ts +259 -0
- package/src/browser/client-actions-observe.ts +184 -0
- package/src/browser/client-actions-state.ts +284 -0
- package/src/browser/client-actions-types.ts +16 -0
- package/src/browser/client-actions-url.ts +11 -0
- package/src/browser/client-actions.ts +4 -0
- package/src/browser/client-fetch.ts +253 -0
- package/src/browser/client.ts +337 -0
- package/src/browser/config.ts +296 -0
- package/src/browser/constants.ts +8 -0
- package/src/browser/control-auth.ts +94 -0
- package/src/browser/control-service.ts +81 -0
- package/src/browser/csrf.ts +87 -0
- package/src/browser/enterprise-compat.ts +518 -0
- package/src/browser/extension-relay.ts +834 -0
- package/src/browser/http-auth.ts +63 -0
- package/src/browser/navigation-guard.ts +50 -0
- package/src/browser/paths.ts +49 -0
- package/src/browser/profiles-service.ts +187 -0
- package/src/browser/profiles.ts +113 -0
- package/src/browser/proxy-files.ts +41 -0
- package/src/browser/pw-ai-module.ts +52 -0
- package/src/browser/pw-ai-state.ts +9 -0
- package/src/browser/pw-ai.ts +65 -0
- package/src/browser/pw-role-snapshot.ts +434 -0
- package/src/browser/pw-session.ts +810 -0
- package/src/browser/pw-tools-core.activity.ts +68 -0
- package/src/browser/pw-tools-core.downloads.ts +281 -0
- package/src/browser/pw-tools-core.interactions.ts +646 -0
- package/src/browser/pw-tools-core.responses.ts +124 -0
- package/src/browser/pw-tools-core.shared.ts +70 -0
- package/src/browser/pw-tools-core.snapshot.ts +213 -0
- package/src/browser/pw-tools-core.state.ts +209 -0
- package/src/browser/pw-tools-core.storage.ts +128 -0
- package/src/browser/pw-tools-core.trace.ts +37 -0
- package/src/browser/pw-tools-core.ts +8 -0
- package/src/browser/resolved-config-refresh.ts +59 -0
- package/src/browser/routes/agent.act.shared.ts +52 -0
- package/src/browser/routes/agent.act.ts +575 -0
- package/src/browser/routes/agent.debug.ts +149 -0
- package/src/browser/routes/agent.shared.ts +143 -0
- package/src/browser/routes/agent.snapshot.ts +333 -0
- package/src/browser/routes/agent.storage.ts +451 -0
- package/src/browser/routes/agent.ts +13 -0
- package/src/browser/routes/basic.ts +202 -0
- package/src/browser/routes/dispatcher.ts +126 -0
- package/src/browser/routes/index.ts +11 -0
- package/src/browser/routes/path-output.ts +1 -0
- package/src/browser/routes/tabs.ts +217 -0
- package/src/browser/routes/types.ts +26 -0
- package/src/browser/routes/utils.ts +73 -0
- package/src/browser/screenshot.ts +54 -0
- package/src/browser/server-context.ts +688 -0
- package/src/browser/server-context.types.ts +65 -0
- package/src/browser/server-lifecycle.ts +48 -0
- package/src/browser/server-middleware.ts +37 -0
- package/src/browser/server.ts +110 -0
- package/src/browser/target-id.ts +30 -0
- package/src/browser/trash.ts +21 -0
- package/src/dashboard/pages/agent-detail.js +313 -1
- package/src/engine/agent-routes.ts +46 -0
- package/src/security/external-content.ts +299 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { ensurePageState, getPageForTargetId } from "./pw-session.js";
|
|
2
|
+
|
|
3
|
+
export async function cookiesGetViaPlaywright(opts: {
|
|
4
|
+
cdpUrl: string;
|
|
5
|
+
targetId?: string;
|
|
6
|
+
}): Promise<{ cookies: unknown[] }> {
|
|
7
|
+
const page = await getPageForTargetId(opts);
|
|
8
|
+
ensurePageState(page);
|
|
9
|
+
const cookies = await page.context().cookies();
|
|
10
|
+
return { cookies };
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export async function cookiesSetViaPlaywright(opts: {
|
|
14
|
+
cdpUrl: string;
|
|
15
|
+
targetId?: string;
|
|
16
|
+
cookie: {
|
|
17
|
+
name: string;
|
|
18
|
+
value: string;
|
|
19
|
+
url?: string;
|
|
20
|
+
domain?: string;
|
|
21
|
+
path?: string;
|
|
22
|
+
expires?: number;
|
|
23
|
+
httpOnly?: boolean;
|
|
24
|
+
secure?: boolean;
|
|
25
|
+
sameSite?: "Lax" | "None" | "Strict";
|
|
26
|
+
};
|
|
27
|
+
}): Promise<void> {
|
|
28
|
+
const page = await getPageForTargetId(opts);
|
|
29
|
+
ensurePageState(page);
|
|
30
|
+
const cookie = opts.cookie;
|
|
31
|
+
if (!cookie.name || cookie.value === undefined) {
|
|
32
|
+
throw new Error("cookie name and value are required");
|
|
33
|
+
}
|
|
34
|
+
const hasUrl = typeof cookie.url === "string" && cookie.url.trim();
|
|
35
|
+
const hasDomainPath =
|
|
36
|
+
typeof cookie.domain === "string" &&
|
|
37
|
+
cookie.domain.trim() &&
|
|
38
|
+
typeof cookie.path === "string" &&
|
|
39
|
+
cookie.path.trim();
|
|
40
|
+
if (!hasUrl && !hasDomainPath) {
|
|
41
|
+
throw new Error("cookie requires url, or domain+path");
|
|
42
|
+
}
|
|
43
|
+
await page.context().addCookies([cookie]);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export async function cookiesClearViaPlaywright(opts: {
|
|
47
|
+
cdpUrl: string;
|
|
48
|
+
targetId?: string;
|
|
49
|
+
}): Promise<void> {
|
|
50
|
+
const page = await getPageForTargetId(opts);
|
|
51
|
+
ensurePageState(page);
|
|
52
|
+
await page.context().clearCookies();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
type StorageKind = "local" | "session";
|
|
56
|
+
|
|
57
|
+
export async function storageGetViaPlaywright(opts: {
|
|
58
|
+
cdpUrl: string;
|
|
59
|
+
targetId?: string;
|
|
60
|
+
kind: StorageKind;
|
|
61
|
+
key?: string;
|
|
62
|
+
}): Promise<{ values: Record<string, string> }> {
|
|
63
|
+
const page = await getPageForTargetId(opts);
|
|
64
|
+
ensurePageState(page);
|
|
65
|
+
const kind = opts.kind;
|
|
66
|
+
const key = typeof opts.key === "string" ? opts.key : undefined;
|
|
67
|
+
const values = await page.evaluate(
|
|
68
|
+
({ kind: kind2, key: key2 }) => {
|
|
69
|
+
const store = kind2 === "session" ? window.sessionStorage : window.localStorage;
|
|
70
|
+
if (key2) {
|
|
71
|
+
const value = store.getItem(key2);
|
|
72
|
+
return value === null ? {} : { [key2]: value };
|
|
73
|
+
}
|
|
74
|
+
const out: Record<string, string> = {};
|
|
75
|
+
for (let i = 0; i < store.length; i += 1) {
|
|
76
|
+
const k = store.key(i);
|
|
77
|
+
if (!k) {
|
|
78
|
+
continue;
|
|
79
|
+
}
|
|
80
|
+
const v = store.getItem(k);
|
|
81
|
+
if (v !== null) {
|
|
82
|
+
out[k] = v;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return out;
|
|
86
|
+
},
|
|
87
|
+
{ kind, key },
|
|
88
|
+
);
|
|
89
|
+
return { values: values ?? {} };
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export async function storageSetViaPlaywright(opts: {
|
|
93
|
+
cdpUrl: string;
|
|
94
|
+
targetId?: string;
|
|
95
|
+
kind: StorageKind;
|
|
96
|
+
key: string;
|
|
97
|
+
value: string;
|
|
98
|
+
}): Promise<void> {
|
|
99
|
+
const page = await getPageForTargetId(opts);
|
|
100
|
+
ensurePageState(page);
|
|
101
|
+
const key = String(opts.key ?? "");
|
|
102
|
+
if (!key) {
|
|
103
|
+
throw new Error("key is required");
|
|
104
|
+
}
|
|
105
|
+
await page.evaluate(
|
|
106
|
+
({ kind, key: k, value }) => {
|
|
107
|
+
const store = kind === "session" ? window.sessionStorage : window.localStorage;
|
|
108
|
+
store.setItem(k, value);
|
|
109
|
+
},
|
|
110
|
+
{ kind: opts.kind, key, value: String(opts.value ?? "") },
|
|
111
|
+
);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
export async function storageClearViaPlaywright(opts: {
|
|
115
|
+
cdpUrl: string;
|
|
116
|
+
targetId?: string;
|
|
117
|
+
kind: StorageKind;
|
|
118
|
+
}): Promise<void> {
|
|
119
|
+
const page = await getPageForTargetId(opts);
|
|
120
|
+
ensurePageState(page);
|
|
121
|
+
await page.evaluate(
|
|
122
|
+
({ kind }) => {
|
|
123
|
+
const store = kind === "session" ? window.sessionStorage : window.localStorage;
|
|
124
|
+
store.clear();
|
|
125
|
+
},
|
|
126
|
+
{ kind: opts.kind },
|
|
127
|
+
);
|
|
128
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ensureContextState, getPageForTargetId } from "./pw-session.js";
|
|
2
|
+
|
|
3
|
+
export async function traceStartViaPlaywright(opts: {
|
|
4
|
+
cdpUrl: string;
|
|
5
|
+
targetId?: string;
|
|
6
|
+
screenshots?: boolean;
|
|
7
|
+
snapshots?: boolean;
|
|
8
|
+
sources?: boolean;
|
|
9
|
+
}): Promise<void> {
|
|
10
|
+
const page = await getPageForTargetId(opts);
|
|
11
|
+
const context = page.context();
|
|
12
|
+
const ctxState = ensureContextState(context);
|
|
13
|
+
if (ctxState.traceActive) {
|
|
14
|
+
throw new Error("Trace already running. Stop the current trace before starting a new one.");
|
|
15
|
+
}
|
|
16
|
+
await context.tracing.start({
|
|
17
|
+
screenshots: opts.screenshots ?? true,
|
|
18
|
+
snapshots: opts.snapshots ?? true,
|
|
19
|
+
sources: opts.sources ?? false,
|
|
20
|
+
});
|
|
21
|
+
ctxState.traceActive = true;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export async function traceStopViaPlaywright(opts: {
|
|
25
|
+
cdpUrl: string;
|
|
26
|
+
targetId?: string;
|
|
27
|
+
path: string;
|
|
28
|
+
}): Promise<void> {
|
|
29
|
+
const page = await getPageForTargetId(opts);
|
|
30
|
+
const context = page.context();
|
|
31
|
+
const ctxState = ensureContextState(context);
|
|
32
|
+
if (!ctxState.traceActive) {
|
|
33
|
+
throw new Error("No active trace. Start a trace before stopping it.");
|
|
34
|
+
}
|
|
35
|
+
await context.tracing.stop({ path: opts.path });
|
|
36
|
+
ctxState.traceActive = false;
|
|
37
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from "./pw-tools-core.activity.js";
|
|
2
|
+
export * from "./pw-tools-core.downloads.js";
|
|
3
|
+
export * from "./pw-tools-core.interactions.js";
|
|
4
|
+
export * from "./pw-tools-core.responses.js";
|
|
5
|
+
export * from "./pw-tools-core.snapshot.js";
|
|
6
|
+
export * from "./pw-tools-core.state.js";
|
|
7
|
+
export * from "./pw-tools-core.storage.js";
|
|
8
|
+
export * from "./pw-tools-core.trace.js";
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
|
|
2
|
+
import { resolveBrowserConfig, resolveProfile, type ResolvedBrowserProfile } from "./config.js";
|
|
3
|
+
import type { BrowserServerState } from "./server-context.types.js";
|
|
4
|
+
import { createConfigIO, loadConfig } from "./enterprise-compat.js";
|
|
5
|
+
|
|
6
|
+
function applyResolvedConfig(
|
|
7
|
+
current: BrowserServerState,
|
|
8
|
+
freshResolved: BrowserServerState["resolved"],
|
|
9
|
+
) {
|
|
10
|
+
current.resolved = freshResolved;
|
|
11
|
+
for (const [name, runtime] of current.profiles) {
|
|
12
|
+
const nextProfile = resolveProfile(freshResolved, name);
|
|
13
|
+
if (nextProfile) {
|
|
14
|
+
runtime.profile = nextProfile;
|
|
15
|
+
continue;
|
|
16
|
+
}
|
|
17
|
+
if (!runtime.running) {
|
|
18
|
+
current.profiles.delete(name);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export function refreshResolvedBrowserConfigFromDisk(params: {
|
|
24
|
+
current: BrowserServerState;
|
|
25
|
+
refreshConfigFromDisk: boolean;
|
|
26
|
+
mode: "cached" | "fresh";
|
|
27
|
+
}) {
|
|
28
|
+
if (!params.refreshConfigFromDisk) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const cfg = params.mode === "fresh" ? createConfigIO().loadConfig() : loadConfig();
|
|
32
|
+
const freshResolved = resolveBrowserConfig(cfg.browser, cfg);
|
|
33
|
+
applyResolvedConfig(params.current, freshResolved);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export function resolveBrowserProfileWithHotReload(params: {
|
|
37
|
+
current: BrowserServerState;
|
|
38
|
+
refreshConfigFromDisk: boolean;
|
|
39
|
+
name: string;
|
|
40
|
+
}): ResolvedBrowserProfile | null {
|
|
41
|
+
refreshResolvedBrowserConfigFromDisk({
|
|
42
|
+
current: params.current,
|
|
43
|
+
refreshConfigFromDisk: params.refreshConfigFromDisk,
|
|
44
|
+
mode: "cached",
|
|
45
|
+
});
|
|
46
|
+
let profile = resolveProfile(params.current.resolved, params.name);
|
|
47
|
+
if (profile) {
|
|
48
|
+
return profile;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Hot-reload: profile missing; retry with a fresh disk read without flushing the global cache.
|
|
52
|
+
refreshResolvedBrowserConfigFromDisk({
|
|
53
|
+
current: params.current,
|
|
54
|
+
refreshConfigFromDisk: params.refreshConfigFromDisk,
|
|
55
|
+
mode: "fresh",
|
|
56
|
+
});
|
|
57
|
+
profile = resolveProfile(params.current.resolved, params.name);
|
|
58
|
+
return profile;
|
|
59
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export const ACT_KINDS = [
|
|
2
|
+
"click",
|
|
3
|
+
"close",
|
|
4
|
+
"drag",
|
|
5
|
+
"evaluate",
|
|
6
|
+
"fill",
|
|
7
|
+
"hover",
|
|
8
|
+
"scrollIntoView",
|
|
9
|
+
"press",
|
|
10
|
+
"resize",
|
|
11
|
+
"select",
|
|
12
|
+
"type",
|
|
13
|
+
"wait",
|
|
14
|
+
] as const;
|
|
15
|
+
|
|
16
|
+
export type ActKind = (typeof ACT_KINDS)[number];
|
|
17
|
+
|
|
18
|
+
export function isActKind(value: unknown): value is ActKind {
|
|
19
|
+
if (typeof value !== "string") {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
return (ACT_KINDS as readonly string[]).includes(value);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export type ClickButton = "left" | "right" | "middle";
|
|
26
|
+
export type ClickModifier = "Alt" | "Control" | "ControlOrMeta" | "Meta" | "Shift";
|
|
27
|
+
|
|
28
|
+
const ALLOWED_CLICK_MODIFIERS = new Set<ClickModifier>([
|
|
29
|
+
"Alt",
|
|
30
|
+
"Control",
|
|
31
|
+
"ControlOrMeta",
|
|
32
|
+
"Meta",
|
|
33
|
+
"Shift",
|
|
34
|
+
]);
|
|
35
|
+
|
|
36
|
+
export function parseClickButton(raw: string): ClickButton | undefined {
|
|
37
|
+
if (raw === "left" || raw === "right" || raw === "middle") {
|
|
38
|
+
return raw;
|
|
39
|
+
}
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function parseClickModifiers(raw: string[]): {
|
|
44
|
+
modifiers?: ClickModifier[];
|
|
45
|
+
error?: string;
|
|
46
|
+
} {
|
|
47
|
+
const invalid = raw.filter((m) => !ALLOWED_CLICK_MODIFIERS.has(m as ClickModifier));
|
|
48
|
+
if (invalid.length) {
|
|
49
|
+
return { error: "modifiers must be Alt|Control|ControlOrMeta|Meta|Shift" };
|
|
50
|
+
}
|
|
51
|
+
return { modifiers: raw.length ? (raw as ClickModifier[]) : undefined };
|
|
52
|
+
}
|