agentmb 0.1.0
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/INSTALL.md +154 -0
- package/README.md +228 -0
- package/dist/audit/logger.d.ts +25 -0
- package/dist/audit/logger.d.ts.map +1 -0
- package/dist/audit/logger.js +56 -0
- package/dist/audit/logger.js.map +1 -0
- package/dist/browser/actions.d.ts +111 -0
- package/dist/browser/actions.d.ts.map +1 -0
- package/dist/browser/actions.js +291 -0
- package/dist/browser/actions.js.map +1 -0
- package/dist/browser/manager.d.ts +51 -0
- package/dist/browser/manager.d.ts.map +1 -0
- package/dist/browser/manager.js +233 -0
- package/dist/browser/manager.js.map +1 -0
- package/dist/cli/client.d.ts +13 -0
- package/dist/cli/client.d.ts.map +1 -0
- package/dist/cli/client.js +109 -0
- package/dist/cli/client.js.map +1 -0
- package/dist/cli/commands/actions.d.ts +3 -0
- package/dist/cli/commands/actions.d.ts.map +1 -0
- package/dist/cli/commands/actions.js +349 -0
- package/dist/cli/commands/actions.js.map +1 -0
- package/dist/cli/commands/pages.d.ts +3 -0
- package/dist/cli/commands/pages.d.ts.map +1 -0
- package/dist/cli/commands/pages.js +107 -0
- package/dist/cli/commands/pages.js.map +1 -0
- package/dist/cli/commands/route.d.ts +3 -0
- package/dist/cli/commands/route.d.ts.map +1 -0
- package/dist/cli/commands/route.js +72 -0
- package/dist/cli/commands/route.js.map +1 -0
- package/dist/cli/commands/session.d.ts +3 -0
- package/dist/cli/commands/session.d.ts.map +1 -0
- package/dist/cli/commands/session.js +57 -0
- package/dist/cli/commands/session.js.map +1 -0
- package/dist/cli/commands/start.d.ts +8 -0
- package/dist/cli/commands/start.d.ts.map +1 -0
- package/dist/cli/commands/start.js +66 -0
- package/dist/cli/commands/start.js.map +1 -0
- package/dist/cli/commands/status.d.ts +6 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +25 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/stop.d.ts +6 -0
- package/dist/cli/commands/stop.d.ts.map +1 -0
- package/dist/cli/commands/stop.js +53 -0
- package/dist/cli/commands/stop.js.map +1 -0
- package/dist/cli/commands/trace.d.ts +3 -0
- package/dist/cli/commands/trace.d.ts.map +1 -0
- package/dist/cli/commands/trace.js +43 -0
- package/dist/cli/commands/trace.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +44 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/daemon/config.d.ts +25 -0
- package/dist/daemon/config.d.ts.map +1 -0
- package/dist/daemon/config.js +35 -0
- package/dist/daemon/config.js.map +1 -0
- package/dist/daemon/index.d.ts +7 -0
- package/dist/daemon/index.d.ts.map +1 -0
- package/dist/daemon/index.js +84 -0
- package/dist/daemon/index.js.map +1 -0
- package/dist/daemon/routes/actions.d.ts +5 -0
- package/dist/daemon/routes/actions.d.ts.map +1 -0
- package/dist/daemon/routes/actions.js +425 -0
- package/dist/daemon/routes/actions.js.map +1 -0
- package/dist/daemon/routes/sessions.d.ts +5 -0
- package/dist/daemon/routes/sessions.d.ts.map +1 -0
- package/dist/daemon/routes/sessions.js +507 -0
- package/dist/daemon/routes/sessions.js.map +1 -0
- package/dist/daemon/server.d.ts +6 -0
- package/dist/daemon/server.d.ts.map +1 -0
- package/dist/daemon/server.js +66 -0
- package/dist/daemon/server.js.map +1 -0
- package/dist/daemon/session.d.ts +52 -0
- package/dist/daemon/session.d.ts.map +1 -0
- package/dist/daemon/session.js +191 -0
- package/dist/daemon/session.js.map +1 -0
- package/dist/daemon/types.d.ts +17 -0
- package/dist/daemon/types.d.ts.map +1 -0
- package/dist/daemon/types.js +3 -0
- package/dist/daemon/types.js.map +1 -0
- package/dist/policy/engine.d.ts +43 -0
- package/dist/policy/engine.d.ts.map +1 -0
- package/dist/policy/engine.js +234 -0
- package/dist/policy/engine.js.map +1 -0
- package/dist/policy/types.d.ts +40 -0
- package/dist/policy/types.d.ts.map +1 -0
- package/dist/policy/types.js +53 -0
- package/dist/policy/types.js.map +1 -0
- package/package.json +61 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.cliPort = cliPort;
|
|
7
|
+
exports.cliApiBase = cliApiBase;
|
|
8
|
+
exports.apiPost = apiPost;
|
|
9
|
+
exports.apiGet = apiGet;
|
|
10
|
+
exports.apiDelete = apiDelete;
|
|
11
|
+
exports.apiDeleteWithBody = apiDeleteWithBody;
|
|
12
|
+
/**
|
|
13
|
+
* Shared HTTP client for CLI commands.
|
|
14
|
+
* Reads AGENTMB_PORT env var (default 19315) and optional AGENTMB_API_TOKEN.
|
|
15
|
+
*/
|
|
16
|
+
const http_1 = __importDefault(require("http"));
|
|
17
|
+
function cliPort() {
|
|
18
|
+
return parseInt(process.env.AGENTMB_PORT ?? '19315');
|
|
19
|
+
}
|
|
20
|
+
function cliApiBase() {
|
|
21
|
+
return `http://127.0.0.1:${cliPort()}`;
|
|
22
|
+
}
|
|
23
|
+
function buildHeaders() {
|
|
24
|
+
const headers = { 'content-type': 'application/json' };
|
|
25
|
+
const token = process.env.AGENTMB_API_TOKEN;
|
|
26
|
+
if (token)
|
|
27
|
+
headers['x-api-token'] = token;
|
|
28
|
+
return headers;
|
|
29
|
+
}
|
|
30
|
+
/** Headers for requests with no body (DELETE). Omits content-type to avoid Fastify 400. */
|
|
31
|
+
function buildNoBodyHeaders() {
|
|
32
|
+
const headers = {};
|
|
33
|
+
const token = process.env.AGENTMB_API_TOKEN;
|
|
34
|
+
if (token)
|
|
35
|
+
headers['x-api-token'] = token;
|
|
36
|
+
return headers;
|
|
37
|
+
}
|
|
38
|
+
function apiPost(path, body) {
|
|
39
|
+
return new Promise((resolve, reject) => {
|
|
40
|
+
const payload = JSON.stringify(body);
|
|
41
|
+
const req = http_1.default.request(cliApiBase() + path, { method: 'POST', headers: buildHeaders() }, (res) => {
|
|
42
|
+
let data = '';
|
|
43
|
+
res.on('data', (c) => (data += c));
|
|
44
|
+
res.on('end', () => {
|
|
45
|
+
try {
|
|
46
|
+
resolve(JSON.parse(data));
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
resolve({ raw: data });
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
req.on('error', reject);
|
|
54
|
+
req.write(payload);
|
|
55
|
+
req.end();
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
function apiGet(path) {
|
|
59
|
+
return new Promise((resolve, reject) => {
|
|
60
|
+
// Pass URL as string + headers in options (spread of URL loses prototype getters)
|
|
61
|
+
const req = http_1.default.get(cliApiBase() + path, { headers: buildHeaders() }, (res) => {
|
|
62
|
+
let data = '';
|
|
63
|
+
res.on('data', (c) => (data += c));
|
|
64
|
+
res.on('end', () => {
|
|
65
|
+
try {
|
|
66
|
+
resolve(JSON.parse(data));
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
resolve({ raw: data });
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
req.on('error', reject);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
function apiDelete(path) {
|
|
77
|
+
return new Promise((resolve, reject) => {
|
|
78
|
+
const req = http_1.default.request(cliApiBase() + path, { method: 'DELETE', headers: buildNoBodyHeaders() }, (res) => {
|
|
79
|
+
res.resume();
|
|
80
|
+
res.on('end', () => resolve({ statusCode: res.statusCode ?? 0 }));
|
|
81
|
+
});
|
|
82
|
+
req.on('error', reject);
|
|
83
|
+
req.end();
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
/** DELETE with a JSON body (e.g. for route removal that requires a pattern). */
|
|
87
|
+
function apiDeleteWithBody(path, body) {
|
|
88
|
+
return new Promise((resolve, reject) => {
|
|
89
|
+
const payload = JSON.stringify(body);
|
|
90
|
+
const req = http_1.default.request(cliApiBase() + path, { method: 'DELETE', headers: buildHeaders() }, (res) => {
|
|
91
|
+
let data = '';
|
|
92
|
+
res.on('data', (c) => (data += c));
|
|
93
|
+
res.on('end', () => {
|
|
94
|
+
let parsed = {};
|
|
95
|
+
try {
|
|
96
|
+
parsed = JSON.parse(data);
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
parsed = {};
|
|
100
|
+
}
|
|
101
|
+
resolve({ statusCode: res.statusCode ?? 0, data: parsed });
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
req.on('error', reject);
|
|
105
|
+
req.write(payload);
|
|
106
|
+
req.end();
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/cli/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actions.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/actions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAenC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA+QrD"}
|
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.actionCommands = actionCommands;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const readline_1 = __importDefault(require("readline"));
|
|
10
|
+
const client_1 = require("../client");
|
|
11
|
+
function printDiagnostics(res) {
|
|
12
|
+
console.error('Error:', res.error);
|
|
13
|
+
if (res.url)
|
|
14
|
+
console.error(' url:', res.url);
|
|
15
|
+
if (res.title)
|
|
16
|
+
console.error(' title:', res.title);
|
|
17
|
+
if (res.readyState)
|
|
18
|
+
console.error(' readyState:', res.readyState);
|
|
19
|
+
if (res.elapsedMs != null)
|
|
20
|
+
console.error(' elapsedMs:', res.elapsedMs);
|
|
21
|
+
if (res.stack)
|
|
22
|
+
console.error(' stack:', res.stack);
|
|
23
|
+
}
|
|
24
|
+
function actionCommands(program) {
|
|
25
|
+
program
|
|
26
|
+
.command('navigate <session-id> <url>')
|
|
27
|
+
.description('Navigate to URL')
|
|
28
|
+
.option('--wait-until <event>', 'Wait until event (load|networkidle|commit)', 'load')
|
|
29
|
+
.action(async (sessionId, url, opts) => {
|
|
30
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/navigate`, {
|
|
31
|
+
url,
|
|
32
|
+
wait_until: opts.waitUntil,
|
|
33
|
+
});
|
|
34
|
+
if (res.error) {
|
|
35
|
+
console.error('Error:', res.error);
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
console.log(`Navigated to: ${res.url} (${res.duration_ms}ms)`);
|
|
39
|
+
console.log(`Title: ${res.title}`);
|
|
40
|
+
});
|
|
41
|
+
program
|
|
42
|
+
.command('screenshot <session-id>')
|
|
43
|
+
.description('Capture screenshot')
|
|
44
|
+
.option('-o, --out <file>', 'Output file path', './screenshot.png')
|
|
45
|
+
.option('--full-page', 'Capture full page')
|
|
46
|
+
.option('--format <fmt>', 'Format: png|jpeg', 'png')
|
|
47
|
+
.action(async (sessionId, opts) => {
|
|
48
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/screenshot`, {
|
|
49
|
+
format: opts.format,
|
|
50
|
+
full_page: opts.fullPage,
|
|
51
|
+
});
|
|
52
|
+
if (res.error) {
|
|
53
|
+
printDiagnostics(res);
|
|
54
|
+
process.exit(1);
|
|
55
|
+
}
|
|
56
|
+
const buf = Buffer.from(res.data, 'base64');
|
|
57
|
+
fs_1.default.writeFileSync(opts.out, buf);
|
|
58
|
+
console.log(`✓ Screenshot saved to ${opts.out} (${(buf.length / 1024).toFixed(1)}KB, ${res.duration_ms}ms)`);
|
|
59
|
+
});
|
|
60
|
+
program
|
|
61
|
+
.command('eval <session-id> <expression>')
|
|
62
|
+
.description('Evaluate JavaScript expression in browser')
|
|
63
|
+
.action(async (sessionId, expression) => {
|
|
64
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/eval`, { expression });
|
|
65
|
+
if (res.error) {
|
|
66
|
+
printDiagnostics(res);
|
|
67
|
+
process.exit(1);
|
|
68
|
+
}
|
|
69
|
+
console.log(JSON.stringify(res.result, null, 2));
|
|
70
|
+
});
|
|
71
|
+
program
|
|
72
|
+
.command('extract <session-id> <selector>')
|
|
73
|
+
.description('Extract text/attributes from elements matching selector')
|
|
74
|
+
.option('--attr <name>', 'Extract attribute value instead of text content')
|
|
75
|
+
.action(async (sessionId, selector, opts) => {
|
|
76
|
+
const body = { selector };
|
|
77
|
+
if (opts.attr)
|
|
78
|
+
body.attribute = opts.attr;
|
|
79
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/extract`, body);
|
|
80
|
+
if (res.error) {
|
|
81
|
+
printDiagnostics(res);
|
|
82
|
+
process.exit(1);
|
|
83
|
+
}
|
|
84
|
+
console.log(`Found ${res.count} element(s) matching "${selector}":`);
|
|
85
|
+
for (const item of res.items) {
|
|
86
|
+
console.log(' ', JSON.stringify(item));
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
program
|
|
90
|
+
.command('click <session-id> <selector>')
|
|
91
|
+
.description('Click an element')
|
|
92
|
+
.action(async (sessionId, selector) => {
|
|
93
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/click`, { selector });
|
|
94
|
+
if (res.error) {
|
|
95
|
+
console.error('Error:', res.error);
|
|
96
|
+
process.exit(1);
|
|
97
|
+
}
|
|
98
|
+
console.log(`✓ Clicked "${selector}" (${res.duration_ms}ms)`);
|
|
99
|
+
});
|
|
100
|
+
program
|
|
101
|
+
.command('fill <session-id> <selector> <value>')
|
|
102
|
+
.description('Fill a form field')
|
|
103
|
+
.action(async (sessionId, selector, value) => {
|
|
104
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/fill`, { selector, value });
|
|
105
|
+
if (res.error) {
|
|
106
|
+
console.error('Error:', res.error);
|
|
107
|
+
process.exit(1);
|
|
108
|
+
}
|
|
109
|
+
console.log(`✓ Filled "${selector}" (${res.duration_ms}ms)`);
|
|
110
|
+
});
|
|
111
|
+
program
|
|
112
|
+
.command('logs <session-id>')
|
|
113
|
+
.description('Show audit logs for a session')
|
|
114
|
+
.option('--tail <n>', 'Last N entries', '20')
|
|
115
|
+
.action(async (sessionId, opts) => {
|
|
116
|
+
const res = await (0, client_1.apiGet)(`/api/v1/sessions/${sessionId}/logs?tail=${opts.tail}`);
|
|
117
|
+
if (!Array.isArray(res)) {
|
|
118
|
+
console.log(JSON.stringify(res, null, 2));
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
for (const entry of res) {
|
|
122
|
+
console.log(`[${entry.ts}] ${entry.action ?? entry.type} ${entry.url ?? ''} ${entry.result?.status ?? ''} ${entry.result?.duration_ms ?? ''}ms`);
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
program
|
|
126
|
+
.command('login <session-id>')
|
|
127
|
+
.description('Interactive login handoff: switch to headed, wait for you to log in, then restore headless automation')
|
|
128
|
+
.action(async (sessionId) => {
|
|
129
|
+
const start = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/handoff/start`, {});
|
|
130
|
+
if (start.error) {
|
|
131
|
+
console.error('Error:', start.error);
|
|
132
|
+
process.exit(1);
|
|
133
|
+
}
|
|
134
|
+
console.log(`Browser is now visible for session ${sessionId}.`);
|
|
135
|
+
console.log('Log in manually in the browser window.');
|
|
136
|
+
console.log('Press Enter here when done to return to headless automation...');
|
|
137
|
+
const rl = readline_1.default.createInterface({ input: process.stdin, output: process.stdout });
|
|
138
|
+
await new Promise((resolve) => rl.question('', () => { rl.close(); resolve(); }));
|
|
139
|
+
const complete = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/handoff/complete`, {});
|
|
140
|
+
if (complete.error) {
|
|
141
|
+
console.error('Error:', complete.error);
|
|
142
|
+
process.exit(1);
|
|
143
|
+
}
|
|
144
|
+
console.log(`✓ Session ${sessionId} returned to headless mode. Automation can resume.`);
|
|
145
|
+
});
|
|
146
|
+
program
|
|
147
|
+
.command('type <session-id> <selector> <text>')
|
|
148
|
+
.description('Type text into an element character by character')
|
|
149
|
+
.option('--delay-ms <ms>', 'Delay between keystrokes (ms)', '0')
|
|
150
|
+
.action(async (sessionId, selector, text, opts) => {
|
|
151
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/type`, { selector, text, delay_ms: parseInt(opts.delayMs) });
|
|
152
|
+
if (res.error) {
|
|
153
|
+
printDiagnostics(res);
|
|
154
|
+
process.exit(1);
|
|
155
|
+
}
|
|
156
|
+
console.log(`✓ Typed into "${selector}" (${res.duration_ms}ms)`);
|
|
157
|
+
});
|
|
158
|
+
program
|
|
159
|
+
.command('press <session-id> <selector> <key>')
|
|
160
|
+
.description('Press a key or combo (e.g. Enter, Tab, Control+a)')
|
|
161
|
+
.action(async (sessionId, selector, key) => {
|
|
162
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/press`, { selector, key });
|
|
163
|
+
if (res.error) {
|
|
164
|
+
printDiagnostics(res);
|
|
165
|
+
process.exit(1);
|
|
166
|
+
}
|
|
167
|
+
console.log(`✓ Pressed "${key}" on "${selector}" (${res.duration_ms}ms)`);
|
|
168
|
+
});
|
|
169
|
+
program
|
|
170
|
+
.command('select <session-id> <selector> <value...>')
|
|
171
|
+
.description('Select option(s) from a <select> element')
|
|
172
|
+
.action(async (sessionId, selector, values) => {
|
|
173
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/select`, { selector, values });
|
|
174
|
+
if (res.error) {
|
|
175
|
+
printDiagnostics(res);
|
|
176
|
+
process.exit(1);
|
|
177
|
+
}
|
|
178
|
+
console.log(`✓ Selected [${res.selected.join(', ')}] in "${selector}" (${res.duration_ms}ms)`);
|
|
179
|
+
});
|
|
180
|
+
program
|
|
181
|
+
.command('hover <session-id> <selector>')
|
|
182
|
+
.description('Hover over an element')
|
|
183
|
+
.action(async (sessionId, selector) => {
|
|
184
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/hover`, { selector });
|
|
185
|
+
if (res.error) {
|
|
186
|
+
printDiagnostics(res);
|
|
187
|
+
process.exit(1);
|
|
188
|
+
}
|
|
189
|
+
console.log(`✓ Hovered over "${selector}" (${res.duration_ms}ms)`);
|
|
190
|
+
});
|
|
191
|
+
program
|
|
192
|
+
.command('wait-selector <session-id> <selector>')
|
|
193
|
+
.description('Wait for an element to match state')
|
|
194
|
+
.option('--state <state>', 'visible|hidden|attached|detached', 'visible')
|
|
195
|
+
.option('--timeout-ms <ms>', 'Timeout in ms', '5000')
|
|
196
|
+
.action(async (sessionId, selector, opts) => {
|
|
197
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/wait_for_selector`, {
|
|
198
|
+
selector, state: opts.state, timeout_ms: parseInt(opts.timeoutMs),
|
|
199
|
+
});
|
|
200
|
+
if (res.error) {
|
|
201
|
+
printDiagnostics(res);
|
|
202
|
+
process.exit(1);
|
|
203
|
+
}
|
|
204
|
+
console.log(`✓ Selector "${selector}" is ${res.state} (${res.duration_ms}ms)`);
|
|
205
|
+
});
|
|
206
|
+
program
|
|
207
|
+
.command('wait-response <session-id> <url-pattern>')
|
|
208
|
+
.description('Wait for a network response matching URL pattern')
|
|
209
|
+
.option('--timeout-ms <ms>', 'Timeout in ms', '10000')
|
|
210
|
+
.option('--trigger-navigate <url>', 'Navigate to this URL to trigger the response')
|
|
211
|
+
.action(async (sessionId, urlPattern, opts) => {
|
|
212
|
+
const body = { url_pattern: urlPattern, timeout_ms: parseInt(opts.timeoutMs) };
|
|
213
|
+
if (opts.triggerNavigate)
|
|
214
|
+
body.trigger = { type: 'navigate', url: opts.triggerNavigate };
|
|
215
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/wait_for_response`, body);
|
|
216
|
+
if (res.error) {
|
|
217
|
+
printDiagnostics(res);
|
|
218
|
+
process.exit(1);
|
|
219
|
+
}
|
|
220
|
+
console.log(`✓ Response matched: ${res.url} [HTTP ${res.status_code}] (${res.duration_ms}ms)`);
|
|
221
|
+
});
|
|
222
|
+
program
|
|
223
|
+
.command('wait-url <session-id> <url-pattern>')
|
|
224
|
+
.description('Wait for the page URL to match a pattern (glob or full URL)')
|
|
225
|
+
.option('--timeout-ms <ms>', 'Timeout in ms', '5000')
|
|
226
|
+
.action(async (sessionId, urlPattern, opts) => {
|
|
227
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/wait_for_url`, {
|
|
228
|
+
url_pattern: urlPattern, timeout_ms: parseInt(opts.timeoutMs),
|
|
229
|
+
});
|
|
230
|
+
if (res.error) {
|
|
231
|
+
printDiagnostics(res);
|
|
232
|
+
process.exit(1);
|
|
233
|
+
}
|
|
234
|
+
console.log(`✓ URL matched: ${res.url} (${res.duration_ms}ms)`);
|
|
235
|
+
});
|
|
236
|
+
program
|
|
237
|
+
.command('upload <session-id> <selector> <file>')
|
|
238
|
+
.description('Upload a local file to a file input element')
|
|
239
|
+
.option('--mime-type <type>', 'MIME type', 'application/octet-stream')
|
|
240
|
+
.action(async (sessionId, selector, file, opts) => {
|
|
241
|
+
const buf = fs_1.default.readFileSync(file);
|
|
242
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/upload`, {
|
|
243
|
+
selector,
|
|
244
|
+
content: buf.toString('base64'),
|
|
245
|
+
filename: path_1.default.basename(file),
|
|
246
|
+
mime_type: opts.mimeType,
|
|
247
|
+
});
|
|
248
|
+
if (res.error) {
|
|
249
|
+
printDiagnostics(res);
|
|
250
|
+
process.exit(1);
|
|
251
|
+
}
|
|
252
|
+
console.log(`✓ Uploaded "${res.filename}" (${res.size_bytes} bytes, ${res.duration_ms}ms)`);
|
|
253
|
+
});
|
|
254
|
+
program
|
|
255
|
+
.command('download <session-id> <selector>')
|
|
256
|
+
.description('Click a download link and save the file')
|
|
257
|
+
.option('-o, --out <file>', 'Output file path (default: suggested filename)')
|
|
258
|
+
.option('--timeout-ms <ms>', 'Timeout in ms', '30000')
|
|
259
|
+
.action(async (sessionId, selector, opts) => {
|
|
260
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/download`, {
|
|
261
|
+
selector, timeout_ms: parseInt(opts.timeoutMs),
|
|
262
|
+
});
|
|
263
|
+
if (res.error) {
|
|
264
|
+
printDiagnostics(res);
|
|
265
|
+
process.exit(1);
|
|
266
|
+
}
|
|
267
|
+
const outPath = opts.out ?? res.filename;
|
|
268
|
+
fs_1.default.writeFileSync(outPath, Buffer.from(res.data, 'base64'));
|
|
269
|
+
console.log(`✓ Downloaded "${res.filename}" → ${outPath} (${res.size_bytes} bytes, ${res.duration_ms}ms)`);
|
|
270
|
+
});
|
|
271
|
+
program
|
|
272
|
+
.command('headed <session-id>')
|
|
273
|
+
.description('Switch session to headed (visible) mode')
|
|
274
|
+
.action(async (sessionId) => {
|
|
275
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/mode`, { mode: 'headed' });
|
|
276
|
+
if (res.error) {
|
|
277
|
+
console.error('Error:', res.error);
|
|
278
|
+
process.exit(1);
|
|
279
|
+
}
|
|
280
|
+
console.log(`✓ Session ${sessionId} switched to headed mode`);
|
|
281
|
+
});
|
|
282
|
+
program
|
|
283
|
+
.command('headless <session-id>')
|
|
284
|
+
.description('Switch session to headless mode')
|
|
285
|
+
.action(async (sessionId) => {
|
|
286
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/mode`, { mode: 'headless' });
|
|
287
|
+
if (res.error) {
|
|
288
|
+
console.error('Error:', res.error);
|
|
289
|
+
process.exit(1);
|
|
290
|
+
}
|
|
291
|
+
console.log(`✓ Session ${sessionId} switched to headless mode`);
|
|
292
|
+
});
|
|
293
|
+
program
|
|
294
|
+
.command('policy <session-id> [profile]')
|
|
295
|
+
.description('Get or set the safety execution policy for a session (safe|permissive|disabled)')
|
|
296
|
+
.option('--allow-sensitive', 'Enable sensitive action guardrail override')
|
|
297
|
+
.option('--deny-sensitive', 'Disable sensitive action guardrail override')
|
|
298
|
+
.action(async (sessionId, profile, opts) => {
|
|
299
|
+
if (!profile) {
|
|
300
|
+
// GET current policy
|
|
301
|
+
const res = await (0, client_1.apiGet)(`/api/v1/sessions/${sessionId}/policy`);
|
|
302
|
+
if (res.error) {
|
|
303
|
+
console.error('Error:', res.error);
|
|
304
|
+
process.exit(1);
|
|
305
|
+
}
|
|
306
|
+
console.log(`Profile: ${res.profile}`);
|
|
307
|
+
console.log(` domain_min_interval_ms: ${res.domain_min_interval_ms}`);
|
|
308
|
+
console.log(` jitter_ms: [${(res.jitter_ms ?? []).join(', ')}]`);
|
|
309
|
+
console.log(` cooldown_after_error_ms: ${res.cooldown_after_error_ms}`);
|
|
310
|
+
console.log(` max_retries_per_domain: ${res.max_retries_per_domain}`);
|
|
311
|
+
console.log(` max_actions_per_minute: ${res.max_actions_per_minute}`);
|
|
312
|
+
console.log(` allow_sensitive_actions: ${res.allow_sensitive_actions}`);
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
// SET policy
|
|
316
|
+
const body = { profile };
|
|
317
|
+
if (opts.allowSensitive)
|
|
318
|
+
body.allow_sensitive_actions = true;
|
|
319
|
+
if (opts.denySensitive)
|
|
320
|
+
body.allow_sensitive_actions = false;
|
|
321
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/policy`, body);
|
|
322
|
+
if (res.error) {
|
|
323
|
+
console.error('Error:', res.error);
|
|
324
|
+
process.exit(1);
|
|
325
|
+
}
|
|
326
|
+
console.log(`✓ Policy set for session ${sessionId}: ${res.profile}`);
|
|
327
|
+
console.log(` allow_sensitive_actions: ${res.allow_sensitive_actions}`);
|
|
328
|
+
}
|
|
329
|
+
});
|
|
330
|
+
program
|
|
331
|
+
.command('cdp-ws <session-id>')
|
|
332
|
+
.description('Print the browser-level CDP WebSocket URL for the session')
|
|
333
|
+
.action(async (sessionId) => {
|
|
334
|
+
const res = await (0, client_1.apiGet)(`/api/v1/sessions/${sessionId}/cdp/ws`);
|
|
335
|
+
if (res.error) {
|
|
336
|
+
console.error('Error:', res.error);
|
|
337
|
+
process.exit(1);
|
|
338
|
+
}
|
|
339
|
+
const wsUrl = res.browser_ws_url;
|
|
340
|
+
if (wsUrl) {
|
|
341
|
+
console.log(wsUrl);
|
|
342
|
+
}
|
|
343
|
+
else {
|
|
344
|
+
console.log(`(no WebSocket URL available — session ${sessionId})`);
|
|
345
|
+
console.log('Note: CDP WS URL is only available when using a full browser launch (not persistent context).');
|
|
346
|
+
}
|
|
347
|
+
});
|
|
348
|
+
}
|
|
349
|
+
//# sourceMappingURL=actions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actions.js","sourceRoot":"","sources":["../../../src/cli/commands/actions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/pages.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAGnC,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA2EpD"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.pagesCommands = pagesCommands;
|
|
7
|
+
const readline_1 = __importDefault(require("readline"));
|
|
8
|
+
const client_1 = require("../client");
|
|
9
|
+
function pagesCommands(program) {
|
|
10
|
+
const pages = program.command('pages').description('Manage browser tabs/pages within a session');
|
|
11
|
+
pages
|
|
12
|
+
.command('list <session-id>')
|
|
13
|
+
.description('List all open pages (tabs) in a session')
|
|
14
|
+
.action(async (sessionId) => {
|
|
15
|
+
const res = await (0, client_1.apiGet)(`/api/v1/sessions/${sessionId}/pages`);
|
|
16
|
+
if (res.error) {
|
|
17
|
+
console.error('Error:', res.error);
|
|
18
|
+
process.exit(1);
|
|
19
|
+
}
|
|
20
|
+
const ps = res.pages ?? [];
|
|
21
|
+
if (ps.length === 0) {
|
|
22
|
+
console.log('No pages.');
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
for (const p of ps) {
|
|
26
|
+
const active = p.active ? ' [active]' : '';
|
|
27
|
+
console.log(` ${p.page_id}${active} ${p.url ?? ''}`);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
pages
|
|
31
|
+
.command('new <session-id>')
|
|
32
|
+
.description('Open a new page (tab) in a session')
|
|
33
|
+
.action(async (sessionId) => {
|
|
34
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/pages`, {});
|
|
35
|
+
if (res.error) {
|
|
36
|
+
console.error('Error:', res.error);
|
|
37
|
+
process.exit(1);
|
|
38
|
+
}
|
|
39
|
+
console.log(`Created page: ${res.page_id}`);
|
|
40
|
+
});
|
|
41
|
+
pages
|
|
42
|
+
.command('switch <session-id> <page-id>')
|
|
43
|
+
.description('Make a page the active automation target')
|
|
44
|
+
.action(async (sessionId, pageId) => {
|
|
45
|
+
const res = await (0, client_1.apiPost)(`/api/v1/sessions/${sessionId}/pages/switch`, { page_id: pageId });
|
|
46
|
+
if (res.error) {
|
|
47
|
+
console.error('Error:', res.error);
|
|
48
|
+
process.exit(1);
|
|
49
|
+
}
|
|
50
|
+
console.log(`✓ Active page: ${res.active_page_id}`);
|
|
51
|
+
});
|
|
52
|
+
pages
|
|
53
|
+
.command('close <session-id> [page-id]')
|
|
54
|
+
.description('Close a page (omit page-id to pick interactively from a numbered list)')
|
|
55
|
+
.action(async (sessionId, pageId) => {
|
|
56
|
+
// Interactive selection when page-id is omitted
|
|
57
|
+
if (!pageId) {
|
|
58
|
+
const listRes = await (0, client_1.apiGet)(`/api/v1/sessions/${sessionId}/pages`);
|
|
59
|
+
if (listRes.error) {
|
|
60
|
+
console.error('Error:', listRes.error);
|
|
61
|
+
process.exit(1);
|
|
62
|
+
}
|
|
63
|
+
const ps = listRes.pages ?? [];
|
|
64
|
+
if (ps.length === 0) {
|
|
65
|
+
console.log('No pages found.');
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
if (ps.length === 1) {
|
|
69
|
+
console.error('Error: Cannot close the last remaining page in a session.');
|
|
70
|
+
process.exit(1);
|
|
71
|
+
}
|
|
72
|
+
console.log(`Pages in session ${sessionId}:`);
|
|
73
|
+
ps.forEach((p, i) => {
|
|
74
|
+
const marker = p.active ? ' [active]' : '';
|
|
75
|
+
console.log(` ${i + 1}) ${p.page_id}${marker} ${p.url ?? ''}`);
|
|
76
|
+
});
|
|
77
|
+
const rl = readline_1.default.createInterface({ input: process.stdin, output: process.stdout });
|
|
78
|
+
const answer = await new Promise((resolve) => {
|
|
79
|
+
rl.question('Enter page number to close (or press Enter to cancel): ', (ans) => {
|
|
80
|
+
rl.close();
|
|
81
|
+
resolve(ans.trim());
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
if (!answer) {
|
|
85
|
+
console.log('Cancelled.');
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const idx = parseInt(answer, 10) - 1;
|
|
89
|
+
if (isNaN(idx) || idx < 0 || idx >= ps.length) {
|
|
90
|
+
console.error(`Invalid selection: "${answer}". Enter a number between 1 and ${ps.length}.`);
|
|
91
|
+
process.exit(1);
|
|
92
|
+
}
|
|
93
|
+
pageId = ps[idx].page_id;
|
|
94
|
+
}
|
|
95
|
+
const res = await (0, client_1.apiDeleteWithBody)(`/api/v1/sessions/${sessionId}/pages/${pageId}`, {});
|
|
96
|
+
if (res.statusCode === 409) {
|
|
97
|
+
console.error('Error: Cannot close the last remaining page in a session.');
|
|
98
|
+
process.exit(1);
|
|
99
|
+
}
|
|
100
|
+
if (res.statusCode === 404) {
|
|
101
|
+
console.error('Error: Page or session not found.');
|
|
102
|
+
process.exit(1);
|
|
103
|
+
}
|
|
104
|
+
console.log(`✓ Page ${pageId} closed.`);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=pages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.js","sourceRoot":"","sources":["../../../src/cli/commands/pages.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/route.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAGnC,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAgDpD"}
|