@ceki/sdk 1.9.0 → 1.9.2

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/README.md CHANGED
@@ -1,23 +1,23 @@
1
- # ceki-browser
1
+ # @ceki/sdk
2
2
 
3
- TypeScript/Node.js SDK for [ceki.me](https://ceki.me) — rent real browsers from real people for AI agent automation.
3
+ TypeScript/Node.js SDK for [browser.ceki.me](https://browser.ceki.me) — rent real browsers from real people for AI agent automation.
4
4
 
5
5
  ## Install
6
6
 
7
7
  ```bash
8
- npm install ceki-browser
8
+ npm install @ceki/sdk
9
9
  ```
10
10
 
11
11
  For the CLI (global):
12
12
 
13
13
  ```bash
14
- npm install -g ceki-browser
14
+ npm install -g @ceki/sdk
15
15
  ```
16
16
 
17
17
  ## Quickstart
18
18
 
19
19
  ```typescript
20
- import { connect } from 'ceki-browser';
20
+ import { connect } from '@ceki/sdk';
21
21
 
22
22
  const client = await connect(process.env.CEKI_API_KEY!);
23
23
  const options = await client.search({ geo: 'US', language: 'en' });
@@ -36,10 +36,6 @@ await client.close();
36
36
  | Variable | Description |
37
37
  |---|---|
38
38
  | `CEKI_API_KEY` | Your API key (required) |
39
- | `CEKI_API_URL` | Override REST API base URL |
40
- | `CEKI_RELAY_URL` | Override relay WebSocket URL |
41
- | `CEKI_CHAT_URL` | Override chat API base URL |
42
- | `CEKI_BASIC_AUTH_USER` / `CEKI_BASIC_AUTH_PASS` | nginx htpasswd credentials |
43
39
 
44
40
  ## API
45
41
 
@@ -51,10 +47,6 @@ Establish a WebSocket connection to the relay. Returns a `Client` instance.
51
47
 
52
48
  | Field | Default | Description |
53
49
  |---|---|---|
54
- | `apiUrl` | `https://api.ceki.me` | REST API base URL |
55
- | `relayUrl` | `wss://browser.ceki.me/ws/agent` | Relay WebSocket URL |
56
- | `chatUrl` | `https://chat.ceki.me/api/chat` | Chat API URL |
57
- | `basicAuth` | `undefined` | `[user, password]` for nginx htpasswd |
58
50
  | `reconnect` | `true` | Auto-reconnect on disconnect |
59
51
 
60
52
  ### `client.search(filters?, limit?) -> BrowserOption[]`
@@ -157,18 +149,12 @@ const browser = await client.rent(scheduleId, { human: null });
157
149
 
158
150
  ## CLI
159
151
 
160
- Both SDKs install a single `ceki-browser` binary on your PATH. Same command set whether you came from Python or Node.js.
152
+ The SDK installs a `ceki` CLI binary on your PATH.
161
153
 
162
154
  ### Install
163
155
 
164
- Python:
165
156
  ```bash
166
- pip install ceki-browser
167
- ```
168
-
169
- Node.js:
170
- ```bash
171
- npm install -g ceki-browser
157
+ npm install -g @ceki/sdk
172
158
  ```
173
159
 
174
160
  ### Environment variables
@@ -176,21 +162,17 @@ npm install -g ceki-browser
176
162
  | Variable | Required | Purpose |
177
163
  |---|---|---|
178
164
  | `CEKI_API_KEY` | yes | Agent token (`ag_...`) |
179
- | `CEKI_API_URL` | no | Override API base URL (default: `https://api.ceki.me`) |
180
- | `CEKI_RELAY_URL` | no | Override relay WS URL (default: `wss://browser.ceki.me/ws/agent`) |
181
- | `CEKI_CHAT_URL` | no | Override chat-service URL |
182
- | `CEKI_BASIC_AUTH_USER` / `_PASS` | no | HTTP Basic Auth for protected dev/stage endpoints |
183
165
 
184
166
  ### Quick start
185
167
 
186
168
  ```bash
187
169
  export CEKI_API_KEY=ag_...
188
170
 
189
- SCHEDULE=$(ceki-browser search --limit 1 | jq -r '.[0].schedule_id')
190
- SID=$(ceki-browser rent --schedule $SCHEDULE | jq -r .session_id)
191
- ceki-browser navigate $SID https://example.com
192
- ceki-browser snapshot $SID -o snap.png
193
- ceki-browser stop $SID
171
+ SCHEDULE=$(ceki search --limit 1 | jq -r '.[0].schedule_id')
172
+ SID=$(ceki rent --schedule $SCHEDULE | jq -r .session_id)
173
+ ceki navigate $SID https://example.com
174
+ ceki snapshot $SID -o snap.png
175
+ ceki stop $SID
194
176
  ```
195
177
 
196
178
  The CLI persists session state locally — after `rent` it saves the session ID so subsequent commands resume it by SID without re-renting.
package/dist/cli.js CHANGED
@@ -2505,9 +2505,9 @@ async function cmdUpload(sid, args) {
2505
2505
  }
2506
2506
  }
2507
2507
  function printHelp() {
2508
- console.log(`ceki-browser \u2014 CLI for browser.ceki.me rental
2508
+ console.log(`ceki \u2014 CLI for browser.ceki.me rental
2509
2509
 
2510
- Usage: ceki-browser <command> [options]
2510
+ Usage: ceki <command> [options]
2511
2511
 
2512
2512
  Commands:
2513
2513
  rent --schedule N [--fingerprint-from PATH]
@@ -2614,14 +2614,14 @@ async function main() {
2614
2614
  break;
2615
2615
  case "chat":
2616
2616
  if (rest.length < 2) {
2617
- err("Usage: ceki-browser chat <sid> <action> [args]", "args");
2617
+ err("Usage: ceki chat <sid> <action> [args]", "args");
2618
2618
  process.exit(1);
2619
2619
  }
2620
2620
  await cmdChat(rest[0], rest[1], rest.slice(2));
2621
2621
  break;
2622
2622
  case "profile":
2623
2623
  if (rest.length < 2) {
2624
- err("Usage: ceki-browser profile export|import <sid> [args]", "args");
2624
+ err("Usage: ceki profile export|import <sid> [args]", "args");
2625
2625
  process.exit(1);
2626
2626
  }
2627
2627
  await cmdProfile(rest[1], rest[0], rest.slice(2));
package/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/cli.ts","../src/client.ts","../src/config.ts","../src/errors.ts","../src/chat.ts","../src/profile.ts","../src/state.ts","../src/humanize/keymap.ts","../src/browser.ts","../src/humanize/humanizer.ts","../src/humanize/profile.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport { connect } from './client.js';\nimport {\n CekiBrowserError,\n AuthError,\n CaptchaTimeoutError,\n SessionNotFound,\n SessionExpired,\n NotOwner,\n TimeoutError,\n ConnectionLost,\n TransportError,\n} from './errors.js';\nimport { saveSession, loadSession, deleteSession, getLastSeenTs, updateLastSeenTs } from './state.js';\nimport type { ConnectOptions, ChatMessage } from './types.js';\nimport type { Client } from './client.js';\nimport type { Browser } from './browser.js';\n\nfunction out(data: unknown): void {\n process.stdout.write(JSON.stringify(data) + '\\n');\n}\n\nfunction err(error: string, code = 'error'): void {\n process.stderr.write(JSON.stringify({ error, code }) + '\\n');\n}\n\nfunction getApiKey(): string {\n const key = process.env.CEKI_API_KEY;\n if (!key) {\n err('CEKI_API_KEY not set', 'auth');\n process.exit(2);\n }\n return key;\n}\n\nfunction connectOptions(): Partial<ConnectOptions> {\n return { reconnect: false };\n}\n\nasync function resumeBrowser(apiKey: string, sessionId: string): Promise<[Client, Browser]> {\n const client = await connect(apiKey, connectOptions());\n const browser = await client.resume(sessionId, { human: null });\n return [client, browser];\n}\n\nasync function closeClient(client: Client): Promise<void> {\n try { await client.disconnect(); } catch { /* ignore */ }\n}\n\nfunction parseBool(val: string): boolean {\n return val === 'true' || val === '1' || val === 'yes';\n}\n\n// --- Command handlers ---\n\nasync function cmdRent(args: string[]): Promise<void> {\n let scheduleId: number | null = null;\n let fingerprintFrom: string | null = null;\n let mode: 'incognito' | 'main' = 'incognito';\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--schedule' && args[i + 1]) scheduleId = parseInt(args[++i], 10);\n if (args[i] === '--fingerprint-from' && args[i + 1]) fingerprintFrom = args[++i];\n if (args[i] === '--mode' && args[i + 1]) {\n const v = args[++i];\n if (v !== 'incognito' && v !== 'main') {\n err('invalid mode, must be incognito or main', 'args');\n process.exit(1);\n }\n mode = v;\n }\n }\n if (scheduleId == null) {\n err('--schedule is required', 'args');\n process.exit(1);\n }\n\n const apiKey = getApiKey();\n let fpData: boolean | Record<string, unknown> = true;\n if (fingerprintFrom) {\n const profile = JSON.parse(fs.readFileSync(fingerprintFrom, 'utf-8'));\n fpData = profile.fingerprint || true;\n }\n\n const client = await connect(apiKey, connectOptions());\n try {\n const browser = await client.rent(scheduleId, { human: null, fingerprint: fpData, mode });\n saveSession(browser.sessionId, {\n session_id: browser.sessionId,\n chat_topic_id: browser.chatTopicId,\n schedule_id: browser.scheduleId,\n last_seen_ts: null,\n });\n out({\n session_id: browser.sessionId,\n chat_topic_id: browser.chatTopicId,\n schedule_id: browser.scheduleId,\n });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSearch(args: string[]): Promise<void> {\n let limit = 20;\n const filters: Record<string, string> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--limit' && args[i + 1]) limit = parseInt(args[++i], 10);\n if (args[i] === '--filter' && args[i + 1]) {\n const [k, ...v] = args[++i].split('=');\n filters[k] = v.join('=');\n }\n }\n\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.search(filters, limit);\n out(results);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSessions(args: string[]): Promise<void> {\n let showAll = false;\n let limit = 50;\n let jsonOutput = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--all') showAll = true;\n else if (args[i] === '--json') jsonOutput = true;\n else if (args[i] === '--limit' && args[i + 1]) limit = Number(args[++i]);\n }\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.listSessions({ active: !showAll, limit });\n if (jsonOutput) {\n out(results);\n } else {\n if (!results.length) {\n process.stdout.write('No sessions found.\\n');\n return;\n }\n const header = 'SID'.padEnd(8) + 'SCHEDULE'.padEnd(10) + 'STARTED'.padEnd(22) + 'DURATION'.padEnd(10) + 'EARNED'.padEnd(9) + 'STATUS'.padEnd(10) + 'RENTER'.padEnd(16) + 'PROVIDER';\n process.stdout.write(header + '\\n');\n for (const s of results) {\n const started = s.started_at ?? '—';\n const mins = Math.floor(s.duration / 60);\n const secs = s.duration % 60;\n const dur = `${mins}:${String(secs).padStart(2, '0')}`;\n const earned = `$${s.earned.toFixed(2)}`;\n const renter = (s.renter as Record<string, string>)?.name ?? '—';\n const provider = (s.provider as Record<string, string>)?.name ?? '—';\n const line = String(s.id).padEnd(8) + String(s.schedule_id).padEnd(10) + started.padEnd(22) + dur.padEnd(10) + earned.padEnd(9) + s.status.padEnd(10) + renter.padEnd(16) + provider;\n process.stdout.write(line + '\\n');\n }\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdMyBrowsers(): Promise<void> {\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.myBrowsers();\n out(results);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSnapshot(sid: string, args: string[]): Promise<void> {\n let outputPath: string | null = null;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const lastSeen = getLastSeenTs(sid);\n browser._lastSeenTs = lastSeen;\n const snap = await browser.snapshot();\n const pngBuf = Buffer.from(snap.screenshot, 'base64');\n fs.writeFileSync(outputPath, pngBuf);\n if (browser._lastSeenTs) {\n updateLastSeenTs(sid, browser._lastSeenTs);\n }\n const chatList = snap.chat.map((m: ChatMessage) => ({\n from: m.sender_id,\n text: m.text,\n ts: m.created_at,\n }));\n out({ screenshot: outputPath, chat: chatList, ts: snap.ts.toISOString() });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdNavigate(sid: string, args: string[]): Promise<void> {\n const url = args[0];\n if (!url) {\n err('URL is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.navigate(url);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdClick(sid: string, args: string[]): Promise<void> {\n const x = parseInt(args[0], 10);\n const y = parseInt(args[1], 10);\n if (isNaN(x) || isNaN(y)) {\n err('x and y coordinates are required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.click(x, y);\n out({ ok: true, pointer: [x, y] });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdType(sid: string, args: string[]): Promise<void> {\n let text = '';\n let natural = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--natural') natural = true;\n else if (!text) text = args[i];\n }\n if (!text) {\n err('text is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const human = natural ? 'natural' as const : null;\n const client = await connect(apiKey, connectOptions());\n try {\n const browser = await client.resume(sid, { human });\n if (!natural) {\n browser._humanizer = null;\n }\n await browser.type(text);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdScroll(sid: string, args: string[]): Promise<void> {\n const x = parseInt(args[0], 10);\n const y = parseInt(args[1], 10);\n const dy = parseInt(args[2], 10);\n if (isNaN(x) || isNaN(y) || isNaN(dy)) {\n err('x, y, dy are required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.scroll({ x, y, deltaY: dy });\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdChat(sid: string, action: string, args: string[]): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n switch (action) {\n case 'send': {\n const text = args[0];\n if (!text) {\n err('text is required', 'args');\n process.exit(1);\n }\n const result = await browser.chat.send(text);\n out({ ok: true, message_id: result.messageId });\n break;\n }\n case 'send-image': {\n let imagePath: string | null = null;\n let text: string | undefined;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--image' && args[i + 1]) imagePath = args[++i];\n if (args[i] === '--text' && args[i + 1]) text = args[++i];\n }\n if (!imagePath) {\n err('--image is required', 'args');\n process.exit(1);\n }\n if (text) {\n await browser.chat.send(text);\n }\n const result = await browser.chat.sendImage(imagePath);\n out({ ok: true, message_id: result.messageId });\n break;\n }\n case 'next': {\n let timeout = 60;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--timeout' && args[i + 1]) timeout = parseFloat(args[++i]);\n }\n const lastSeen = getLastSeenTs(sid);\n const msgs = await browser.chat.history({ since: lastSeen ?? undefined });\n if (msgs.length > 0) {\n const m = msgs[0];\n updateLastSeenTs(sid, m.created_at);\n out({ from: m.sender_id, text: m.text, ts: m.created_at });\n } else {\n let resolved = false;\n const waitPromise = new Promise<ChatMessage | null>((resolve) => {\n const timer = setTimeout(() => {\n if (!resolved) {\n resolved = true;\n resolve(null);\n }\n }, timeout * 1000);\n\n browser.chat.onMessage((msg: ChatMessage) => {\n if (!resolved) {\n resolved = true;\n clearTimeout(timer);\n resolve(msg);\n }\n });\n });\n\n const msg = await waitPromise;\n if (msg) {\n updateLastSeenTs(sid, msg.created_at);\n out({ from: msg.sender_id, text: msg.text, ts: msg.created_at });\n } else {\n out(null);\n }\n }\n break;\n }\n case 'history': {\n let since: string | undefined;\n let limit = 50;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--since' && args[i + 1]) {\n const val = args[++i];\n const asNum = Number(val);\n if (!isNaN(asNum) && val.match(/^\\d+(\\.\\d+)?$/)) {\n since = new Date(asNum * 1000).toISOString();\n } else {\n since = val;\n }\n }\n if (args[i] === '--limit' && args[i + 1]) limit = parseInt(args[++i], 10);\n }\n const msgs = await browser.chat.history({ since, limit });\n out(msgs.map((m: ChatMessage) => ({ from: m.sender_id, text: m.text, ts: m.created_at })));\n break;\n }\n default:\n err(`Unknown chat action: ${action}`, 'args');\n process.exit(1);\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdStop(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.close();\n deleteSession(sid);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdProfile(sid: string, action: string, args: string[]): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n switch (action) {\n case 'export': {\n let outputPath: string | null = null;\n let domains: string[] | undefined;\n let noSessionStorage = false;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n if (args[i] === '--domains' && args[i + 1]) domains = args[++i].split(',').map(d => d.trim());\n if (args[i] === '--no-session-storage') noSessionStorage = true;\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n const profile = await browser.profile.export({\n domains,\n includeSessionStorage: !noSessionStorage,\n });\n fs.writeFileSync(outputPath, JSON.stringify(profile, null, 2), 'utf-8');\n out({ ok: true, path: outputPath });\n break;\n }\n case 'import': {\n let inputPath: string | null = null;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-i' || args[i] === '--input') && args[i + 1]) inputPath = args[++i];\n }\n if (!inputPath) {\n err('-i/--input is required', 'args');\n process.exit(1);\n }\n const profileData = JSON.parse(fs.readFileSync(inputPath, 'utf-8'));\n await browser.profile.import(profileData);\n out({ ok: true });\n break;\n }\n default:\n err(`Unknown profile action: ${action}`, 'args');\n process.exit(1);\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdWait(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const reason = await browser.waitUntilEnded();\n out({ ended: true, reason });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdScreenshot(sid: string, args: string[]): Promise<void> {\n let outputPath: string | null = null;\n let fullPage = false;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n if (args[i] === '--full') fullPage = true;\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const data = await browser.screenshot({ format: 'png', fullPage });\n fs.writeFileSync(outputPath, data as Buffer);\n out({ ok: true, path: outputPath });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSwitchTab(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.switchTab();\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdConfigure(sid: string, args: string[]): Promise<void> {\n const opts: Record<string, unknown> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--masking-mode' && args[i + 1]) opts.maskingMode = parseBool(args[++i]);\n if (args[i] === '--fingerprint' && args[i + 1]) opts.fingerprint = parseBool(args[++i]);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.configure(opts as { maskingMode?: boolean; fingerprint?: boolean });\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdCdp(sid: string, args: string[]): Promise<void> {\n let method: string | null = null;\n let params: Record<string, unknown> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--method' && args[i + 1]) method = args[++i];\n if (args[i] === '--params' && args[i + 1]) params = JSON.parse(args[++i]);\n }\n if (!method) {\n err('--method is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.send({ method, params });\n out(result);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdRequestCaptcha(sid: string, args: string[]): Promise<void> {\n let acceptance = 60;\n let completion = 120;\n let manual = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--acceptance' && args[i + 1]) acceptance = parseFloat(args[++i]);\n if (args[i] === '--completion' && args[i + 1]) completion = parseFloat(args[++i]);\n if (args[i] === '--manual') manual = true;\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.requestCaptcha({\n acceptanceTimeout: acceptance,\n completionTimeout: completion,\n autoAccept: !manual,\n });\n out({\n solved: result.solved,\n proof_message_id: result.proofMessageId,\n cancel_reason: result.cancelReason,\n child_event_id: result.childEventId,\n correction_id: result.correctionId,\n });\n if (!result.solved) process.exit(1);\n } catch (e) {\n if (e instanceof CaptchaTimeoutError) {\n out({ solved: false, cancel_reason: `timeout:${e.phase}`, child_event_id: null, correction_id: null });\n process.exit(1);\n }\n throw e;\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdUpload(sid: string, args: string[]): Promise<void> {\n let selector: string | null = null;\n let filePath: string | null = null;\n let filename: string | undefined;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--selector' && args[i + 1]) selector = args[++i];\n if (args[i] === '--file' && args[i + 1]) filePath = args[++i];\n if (args[i] === '--filename' && args[i + 1]) filename = args[++i];\n }\n if (!selector || !filePath) {\n err('--selector and --file are required', 'args');\n process.exit(1);\n }\n if (!fs.existsSync(filePath)) {\n err(`File not found: ${filePath}`, 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.upload(selector, filePath, filename);\n out(result);\n } finally {\n await closeClient(client);\n }\n}\n\n// --- Help ---\n\nfunction printHelp(): void {\n console.log(`ceki-browser — CLI for browser.ceki.me rental\n\nUsage: ceki-browser <command> [options]\n\nCommands:\n rent --schedule N [--fingerprint-from PATH]\n my-browsers\n search [--limit N] [--filter k=v]...\n snapshot <sid> -o PATH\n screenshot <sid> -o PATH [--full]\n navigate <sid> <url>\n click <sid> <x> <y>\n type <sid> \"<text>\" [--natural]\n scroll <sid> <x> <y> <dy>\n switch-tab <sid>\n configure <sid> [--masking-mode true|false] [--fingerprint true|false]\n cdp <sid> --method <M> [--params JSON]\n upload <sid> --selector CSS --file PATH [--filename NAME]\n request-captcha <sid> [--acceptance N] [--completion M] [--manual]\n wait <sid>\n chat <sid> send \"<text>\"\n chat <sid> send-image --image PATH [--text \"...\"]\n chat <sid> next [--timeout N]\n chat <sid> history [--since TS] [--limit N]\n profile export <sid> -o file [--domains a,b,c] [--no-session-storage]\n profile import <sid> -i file\n stop <sid>\n\nEnvironment:\n CEKI_API_KEY (required)\n CEKI_RELAY_URL (default: wss://browser.ceki.me/ws/agent)\n CEKI_API_URL (default: https://api.ceki.me)\n CEKI_CHAT_URL (default: https://chat.ceki.me/api/chat)\n CEKI_BASIC_AUTH_USER / CEKI_BASIC_AUTH_PASS (optional)\n\nExit codes: 0=success, 1=error, 2=auth, 3=session_not_found, 4=timeout, 5=network`);\n}\n\n// --- Main ---\n\nasync function main(): Promise<void> {\n const argv = process.argv.slice(2);\n\n if (argv.length === 0 || argv[0] === '--help' || argv[0] === '-h') {\n printHelp();\n process.exit(0);\n }\n\n if (argv[0] === '--version' || argv[0] === '-v') {\n const pkgPath = path.resolve(path.dirname(new URL(import.meta.url).pathname), '..', 'package.json');\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));\n console.log(pkg.version);\n } catch {\n console.log('unknown');\n }\n process.exit(0);\n }\n\n const command = argv[0];\n const rest = argv.slice(1);\n\n switch (command) {\n case 'rent':\n await cmdRent(rest);\n break;\n case 'search':\n await cmdSearch(rest);\n break;\n case 'sessions':\n await cmdSessions(rest);\n break;\n case 'my-browsers':\n await cmdMyBrowsers();\n break;\n case 'snapshot':\n await cmdSnapshot(rest[0], rest.slice(1));\n break;\n case 'navigate':\n await cmdNavigate(rest[0], rest.slice(1));\n break;\n case 'click':\n await cmdClick(rest[0], rest.slice(1));\n break;\n case 'type':\n await cmdType(rest[0], rest.slice(1));\n break;\n case 'scroll':\n await cmdScroll(rest[0], rest.slice(1));\n break;\n case 'switch-tab':\n await cmdSwitchTab(rest[0]);\n break;\n case 'configure':\n await cmdConfigure(rest[0], rest.slice(1));\n break;\n case 'cdp':\n await cmdCdp(rest[0], rest.slice(1));\n break;\n case 'upload':\n await cmdUpload(rest[0], rest.slice(1));\n break;\n case 'request-captcha':\n await cmdRequestCaptcha(rest[0], rest.slice(1));\n break;\n case 'wait':\n await cmdWait(rest[0]);\n break;\n case 'stop':\n await cmdStop(rest[0]);\n break;\n case 'screenshot':\n await cmdScreenshot(rest[0], rest.slice(1));\n break;\n case 'chat':\n if (rest.length < 2) {\n err('Usage: ceki-browser chat <sid> <action> [args]', 'args');\n process.exit(1);\n }\n await cmdChat(rest[0], rest[1], rest.slice(2));\n break;\n case 'profile':\n if (rest.length < 2) {\n err('Usage: ceki-browser profile export|import <sid> [args]', 'args');\n process.exit(1);\n }\n await cmdProfile(rest[1], rest[0], rest.slice(2));\n break;\n default:\n err(`Unknown command: ${command}`, 'args');\n process.exit(1);\n }\n}\n\nmain().catch((e: unknown) => {\n if (e instanceof SessionExpired || e instanceof SessionNotFound) {\n err(String(e), 'session_not_found');\n process.exit(3);\n }\n if (e instanceof NotOwner) {\n err(String(e), 'not_owner');\n process.exit(3);\n }\n if (e instanceof TimeoutError) {\n err(String(e), 'timeout');\n process.exit(4);\n }\n if (e instanceof ConnectionLost || e instanceof AuthError || e instanceof TransportError) {\n err(String(e), 'network');\n process.exit(5);\n }\n if (e instanceof CekiBrowserError) {\n err(String(e), 'ceki_error');\n process.exit(1);\n }\n err(e instanceof Error ? e.message : String(e), 'error');\n process.exit(1);\n});\n","import WebSocket from 'ws';\nimport { resolveConfig } from './config.js';\nimport {\n CekiBrowserError,\n AuthError,\n SessionNotFound,\n SessionExpired,\n NotOwner,\n TimeoutError,\n SessionEnded,\n InsufficientFunds,\n RateLimitExceeded,\n ConnectionLost,\n ProviderOffline,\n CdpUnrecoverable,\n TransportError,\n} from './errors.js';\nimport { Browser } from './browser.js';\nimport { Humanizer } from './humanize/humanizer.js';\nimport { HumanProfile } from './humanize/profile.js';\nimport type { ConnectOptions, BrowserOption, Match, RentOptions, SessionInfo } from './types.js';\n\nconst BACKOFF_SCHEDULE = [1, 2, 4, 8, 16, 32, 60];\nconst MAX_RECONNECT_ATTEMPTS = 10;\nconst PING_INTERVAL = 30000;\nconst PONG_TIMEOUT = 90000;\n\ninterface PendingRent {\n scheduleId: number;\n eventId: string | null;\n resolve: (match: Match) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n opts?: RentOptions;\n}\n\ninterface PendingResume {\n sessionId: string;\n resolve: (match: Match) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n opts?: RentOptions;\n}\n\nexport class Client {\n /** @internal */ _apiKey: string;\n /** @internal */ _chatUrl: string;\n /** @internal */ _basicAuth: [string, string] | undefined;\n /** @internal */ _activeBrowsers: Map<string, Browser> = new Map();\n\n private _ws: WebSocket | null = null;\n /** @internal */ _apiUrl: string;\n private _relayUrl: string;\n private _reconnect: boolean;\n private _reconnectAttempt = 0;\n private _reconnecting = false;\n private _closed = false;\n\n private _pingTimer: ReturnType<typeof setInterval> | null = null;\n private _pongTimer: ReturnType<typeof setTimeout> | null = null;\n private _lastPongAt = 0;\n\n private _pendingRents: Map<string, PendingRent> = new Map(); // keyed by `rent:<scheduleId>` or eventId\n private _pendingResumes: Map<string, PendingResume> = new Map(); // keyed by sessionId\n\n private _connectResolve: (() => void) | null = null;\n private _connectReject: ((err: Error) => void) | null = null;\n\n constructor(apiKey: string, opts?: Partial<ConnectOptions>) {\n const cfg = resolveConfig(opts);\n this._apiKey = apiKey;\n this._apiUrl = cfg.apiUrl;\n this._relayUrl = cfg.relayUrl;\n this._chatUrl = cfg.chatUrl;\n this._basicAuth = cfg.basicAuth;\n this._reconnect = cfg.reconnect;\n }\n\n /** Factory: create client and connect */\n static async create(apiKey: string, opts?: Partial<ConnectOptions>): Promise<Client> {\n const client = new Client(apiKey, opts);\n await client._connect();\n return client;\n }\n\n /** @internal */\n _wsSend(msg: Record<string, unknown>): void {\n if (!this._ws || this._ws.readyState !== WebSocket.OPEN) {\n throw new ConnectionLost('WebSocket not connected');\n }\n this._ws.send(JSON.stringify(msg));\n }\n\n async search(\n filters?: Record<string, unknown>,\n limit?: number,\n ): Promise<BrowserOption[]> {\n const params = new URLSearchParams();\n if (limit != null) params.set('limit', String(limit));\n if (filters) {\n for (const [key, value] of Object.entries(filters)) {\n if (value != null) params.set(key, String(value));\n }\n }\n\n const url = `${this._apiUrl}/api/browsers/search?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`Search request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const data = (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(data) ? data : []) as BrowserOption[];\n }\n\n async listSessions(opts?: { active?: boolean; limit?: number }): Promise<SessionInfo[]> {\n const active = opts?.active ?? true;\n const limit = opts?.limit ?? 50;\n const params = new URLSearchParams({\n active: active ? '1' : '0',\n limit: String(limit),\n });\n const url = `${this._apiUrl}/api/agent/sessions?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`listSessions request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const items = (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(items) ? items : []) as SessionInfo[];\n }\n\n async myBrowsers(): Promise<BrowserOption[]> {\n const url = `${this._apiUrl}/api/agent/browsers`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`myBrowsers request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const items = (body as Record<string, unknown>).browsers ?? (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(items) ? items : []) as BrowserOption[];\n }\n\n async rent(scheduleId: number, opts?: RentOptions): Promise<Browser> {\n const rentMsg: Record<string, unknown> = { type: 'rent', browser_id: scheduleId };\n if (opts?.mode) rentMsg.mode = opts.mode;\n this._wsSend(rentMsg);\n\n const key = `rent:${scheduleId}`;\n\n return new Promise<Browser>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingRents.delete(key);\n reject(new TimeoutError('Rent timed out after 90s'));\n }, 90000);\n\n this._pendingRents.set(key, {\n scheduleId,\n eventId: null,\n opts,\n resolve: (match: Match) => {\n const humanizer = this._resolveHumanizer(opts);\n const browser = new Browser(this, match, humanizer);\n this._activeBrowsers.set(browser.sessionId, browser);\n if (opts?.maskingMode) {\n browser.configure({ maskingMode: true }).catch(() => {});\n }\n if (opts?.fingerprint) {\n browser.configure({ fingerprint: opts.fingerprint }).catch(() => {});\n }\n resolve(browser);\n },\n reject,\n timer,\n });\n });\n }\n\n async resume(sessionId: string, opts?: RentOptions): Promise<Browser> {\n this._wsSend({ type: 'resume', session_id: sessionId });\n\n return new Promise<Browser>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingResumes.delete(sessionId);\n reject(new TimeoutError('Resume timed out after 10s'));\n }, 10000);\n\n this._pendingResumes.set(sessionId, {\n sessionId,\n opts,\n resolve: (match: Match) => {\n const humanizer = this._resolveHumanizer(opts);\n const browser = new Browser(this, match, humanizer);\n this._activeBrowsers.set(browser.sessionId, browser);\n resolve(browser);\n },\n reject,\n timer,\n });\n });\n }\n\n async close(): Promise<void> {\n this._closed = true;\n\n // Close all active browsers\n const closePromises: Promise<void>[] = [];\n for (const browser of this._activeBrowsers.values()) {\n closePromises.push(browser.close().catch(() => {}));\n }\n await Promise.allSettled(closePromises);\n\n // Reject pending rents\n for (const [key, pending] of this._pendingRents) {\n clearTimeout(pending.timer);\n pending.reject(new Error('Client closed'));\n }\n this._pendingRents.clear();\n\n // Reject pending resumes\n for (const [key, pending] of this._pendingResumes) {\n clearTimeout(pending.timer);\n pending.reject(new Error('Client closed'));\n }\n this._pendingResumes.clear();\n\n this._stopHeartbeat();\n this._closeWs();\n }\n\n async disconnect(): Promise<void> {\n this._closed = true;\n this._activeBrowsers.clear();\n this._pendingRents.clear();\n this._pendingResumes.clear();\n this._stopHeartbeat();\n this._closeWs();\n }\n\n // --- Private methods ---\n\n private async _connect(): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n this._connectResolve = resolve;\n this._connectReject = reject;\n this._openWs();\n });\n }\n\n private _openWs(): void {\n const protocols = [`bearer.${this._apiKey}`];\n this._ws = new WebSocket(this._relayUrl, protocols);\n\n this._ws.on('open', () => {\n this._reconnectAttempt = 0;\n this._reconnecting = false;\n this._lastPongAt = Date.now();\n this._startHeartbeat();\n\n if (this._connectResolve) {\n this._connectResolve();\n this._connectResolve = null;\n this._connectReject = null;\n }\n });\n\n this._ws.on('message', (data: WebSocket.Data) => {\n this._handleMessage(data);\n });\n\n this._ws.on('close', (code: number, reason: Buffer) => {\n this._stopHeartbeat();\n const reasonStr = reason.toString();\n\n if (code === 4401 || code === 4403) {\n const err = new AuthError(reasonStr || `Auth failed (${code})`);\n if (this._connectReject) {\n this._connectReject(err);\n this._connectResolve = null;\n this._connectReject = null;\n }\n return;\n }\n\n if (!this._closed && this._reconnect) {\n this._scheduleReconnect();\n }\n });\n\n this._ws.on('error', (err: Error) => {\n if (this._connectReject) {\n this._connectReject(new TransportError(err.message));\n this._connectResolve = null;\n this._connectReject = null;\n }\n });\n }\n\n private _closeWs(): void {\n if (this._ws) {\n try {\n this._ws.removeAllListeners();\n this._ws.close();\n } catch {\n // ignore close errors\n }\n this._ws = null;\n }\n }\n\n private _scheduleReconnect(): void {\n if (this._closed || this._reconnecting) return;\n if (this._reconnectAttempt >= MAX_RECONNECT_ATTEMPTS) {\n // Reject all pending operations\n const err = new ConnectionLost('Max reconnection attempts exceeded');\n this._rejectAllPending(err);\n return;\n }\n\n this._reconnecting = true;\n const backoffIdx = Math.min(this._reconnectAttempt, BACKOFF_SCHEDULE.length - 1);\n const delay = BACKOFF_SCHEDULE[backoffIdx] * 1000;\n this._reconnectAttempt++;\n\n setTimeout(() => {\n if (this._closed) return;\n this._closeWs();\n this._connectResolve = () => {\n // After reconnect, resume all active browsers\n for (const browser of this._activeBrowsers.values()) {\n this._wsSend({ type: 'resume', session_id: browser.sessionId });\n }\n };\n this._connectReject = () => {\n // Reconnect failed, try again\n this._reconnecting = false;\n this._scheduleReconnect();\n };\n this._openWs();\n }, delay);\n }\n\n private _startHeartbeat(): void {\n this._stopHeartbeat();\n this._pingTimer = setInterval(() => {\n try {\n this._wsSend({ type: 'ping' });\n } catch {\n // If send fails, WS close handler will trigger reconnect\n }\n }, PING_INTERVAL);\n\n this._pongTimer = setTimeout(() => {\n this._checkPongTimeout();\n }, PONG_TIMEOUT);\n }\n\n private _stopHeartbeat(): void {\n if (this._pingTimer) {\n clearInterval(this._pingTimer);\n this._pingTimer = null;\n }\n if (this._pongTimer) {\n clearTimeout(this._pongTimer);\n this._pongTimer = null;\n }\n }\n\n private _checkPongTimeout(): void {\n if (this._closed) return;\n const elapsed = Date.now() - this._lastPongAt;\n if (elapsed >= PONG_TIMEOUT) {\n // Heartbeat timeout — close and reconnect\n this._closeWs();\n if (this._reconnect) {\n this._scheduleReconnect();\n }\n } else {\n // Schedule next check\n this._pongTimer = setTimeout(() => {\n this._checkPongTimeout();\n }, PONG_TIMEOUT - elapsed);\n }\n }\n\n private _handleMessage(data: WebSocket.Data): void {\n let msg: Record<string, unknown>;\n try {\n msg = JSON.parse(data.toString()) as Record<string, unknown>;\n } catch {\n return;\n }\n\n const type = String(msg.type ?? '');\n const sessionId = msg.session_id ? String(msg.session_id) : null;\n\n switch (type) {\n case 'pong':\n this._lastPongAt = Date.now();\n break;\n\n case 'rent_pending':\n this._onRentPending(msg);\n break;\n\n case 'match':\n this._onMatch(msg);\n break;\n\n case 'rent.error':\n this._onRentError(msg);\n break;\n\n case 'resume_ok':\n this._onResumeOk(msg);\n break;\n\n case 'resume_failed':\n this._onResumeFailed(msg);\n break;\n\n case 'cdp_response':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onCdpResponse(msg);\n }\n break;\n\n case 'cdp_event':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onCdpEvent(msg);\n }\n break;\n\n case 'tab_opened':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onTabOpened(msg);\n }\n break;\n\n case 'session.ended':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onSessionEnded(msg);\n }\n break;\n\n case 'session.provider_disconnected':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onProviderDisconnected();\n }\n break;\n\n case 'session.provider_reconnected':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onProviderReconnected();\n }\n break;\n\n case 'user_events':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onUserEvents(msg);\n }\n break;\n\n case 'chat.message':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatMessage((msg.payload ?? msg) as Record<string, unknown>);\n }\n break;\n\n case 'chat.read':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatRead((msg.payload ?? msg) as Record<string, unknown>);\n }\n break;\n\n case 'chat.send_ack':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatSendAck(msg);\n }\n break;\n\n case 'chat.error':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatSendError(msg);\n }\n break;\n\n case 'error':\n this._onError(msg);\n break;\n }\n }\n\n private _onRentPending(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n // Update pending rent with eventId for matching\n for (const [key, pending] of this._pendingRents) {\n if (!pending.eventId) {\n pending.eventId = eventId;\n // Re-key by eventId for faster lookup on match\n this._pendingRents.delete(key);\n this._pendingRents.set(`event:${eventId}`, pending);\n break;\n }\n }\n }\n\n private _onMatch(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n const scheduleId = Number(msg.schedule_id ?? 0);\n const sessionId = String(msg.session_id ?? '');\n\n if (msg.requires_ack) {\n try { this._wsSend({ type: 'match_ack', session_id: sessionId }); } catch { /* ignore */ }\n }\n\n // Try eventId match first\n let pending = this._pendingRents.get(`event:${eventId}`);\n if (!pending) {\n // Fallback to scheduleId match\n pending = this._pendingRents.get(`rent:${scheduleId}`);\n }\n\n if (pending) {\n clearTimeout(pending.timer);\n const key = pending.eventId ? `event:${pending.eventId}` : `rent:${pending.scheduleId}`;\n this._pendingRents.delete(key);\n\n const match: Match = {\n session_id: sessionId,\n schedule_id: scheduleId,\n event_id: eventId || null,\n chat_topic_id: msg.chat_topic_id ? String(msg.chat_topic_id) : null,\n provider_user_id: msg.provider_user_id != null ? Number(msg.provider_user_id) : null,\n started_at: Date.now(),\n browser_info: (msg.browser_info as Record<string, unknown>) ?? {},\n };\n\n pending.resolve(match);\n }\n }\n\n private _onRentError(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n const code = String(msg.code ?? '');\n const message = String(msg.message ?? '');\n\n let pending = this._pendingRents.get(`event:${eventId}`);\n if (!pending) {\n // Try to find any pending rent\n for (const [key, p] of this._pendingRents) {\n pending = p;\n this._pendingRents.delete(key);\n break;\n }\n } else {\n this._pendingRents.delete(`event:${eventId}`);\n }\n\n if (pending) {\n clearTimeout(pending.timer);\n if (code === 'provider_offline') {\n pending.reject(new ProviderOffline(message));\n } else {\n pending.reject(new TransportError(message || `Rent error: ${code}`));\n }\n }\n }\n\n private _onResumeOk(msg: Record<string, unknown>): void {\n const sessionId = String(msg.session_id ?? '');\n const pending = this._pendingResumes.get(sessionId);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingResumes.delete(sessionId);\n\n const match: Match = {\n session_id: sessionId,\n event_id: msg.event_id != null ? String(msg.event_id) : null,\n schedule_id: Number(msg.schedule_id ?? 0),\n chat_topic_id: msg.chat_topic_id ? String(msg.chat_topic_id) : null,\n provider_user_id: msg.provider_user_id != null ? Number(msg.provider_user_id) : null,\n started_at: Date.now(),\n browser_info: (msg.browser_info as Record<string, unknown>) ?? {},\n };\n\n pending.resolve(match);\n }\n\n private _onResumeFailed(msg: Record<string, unknown>): void {\n const sessionId = String(msg.session_id ?? '');\n const reason = String(msg.reason ?? '');\n const pending = this._pendingResumes.get(sessionId);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingResumes.delete(sessionId);\n\n switch (reason) {\n case 'expired':\n pending.reject(new SessionExpired());\n break;\n case 'not_owner':\n pending.reject(new NotOwner());\n break;\n case 'not_found':\n pending.reject(new SessionNotFound());\n break;\n default:\n pending.reject(new SessionNotFound(reason));\n }\n }\n\n private _onError(msg: Record<string, unknown>): void {\n const code = Number(msg.code ?? 0);\n const reason = String(msg.reason ?? msg.message ?? '');\n const sessionId = msg.session_id ? String(msg.session_id) : null;\n\n // Route session-specific errors to browser\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n if (browser) {\n switch (code) {\n case -1011: // heartbeat timeout\n browser._onSessionEnded({ reason: 'heartbeat_timeout' });\n return;\n case -1012:\n browser._onError({ reason: 'insufficient_funds' });\n return;\n case -1013:\n browser._onError({ reason: 'rate_limit_exceeded' });\n return;\n case -1015: // provider_declined\n browser._onSessionEnded({ reason: 'provider_declined' });\n return;\n case -1018: // killed\n browser._onSessionEnded({ reason: 'killed' });\n return;\n case -1050:\n browser._onError({ reason: `cdp_unrecoverable: ${reason}` });\n return;\n default:\n browser._onError(msg);\n return;\n }\n }\n }\n\n // Global errors — reject pending operations\n let err: CekiBrowserError;\n switch (code) {\n case -1012:\n err = new InsufficientFunds(reason);\n this._rejectAllPending(err);\n break;\n case -1013:\n err = new RateLimitExceeded(0, reason);\n this._rejectAllPending(err);\n break;\n case -1015:\n err = new ProviderOffline(reason);\n this._rejectFirstPendingRent(err);\n break;\n default:\n err = new CekiBrowserError(reason || `relay error ${code}`);\n this._rejectFirstPendingRent(err);\n break;\n }\n }\n\n private _rejectFirstPendingRent(err: Error): void {\n const eventId = this._pendingRents.keys().next().value;\n if (eventId != null) {\n const pending = this._pendingRents.get(eventId)!;\n clearTimeout(pending.timer);\n this._pendingRents.delete(eventId);\n pending.reject(err);\n }\n }\n\n private _rejectAllPending(err: Error): void {\n for (const [key, pending] of this._pendingRents) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingRents.clear();\n\n for (const [key, pending] of this._pendingResumes) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingResumes.clear();\n }\n\n private _resolveHumanizer(opts?: RentOptions): Humanizer | null {\n if (process.env.CEKI_HUMAN_DISABLE === '1') return null;\n const human = opts?.human;\n if (human === null || human === undefined) {\n const envPreset = process.env.CEKI_HUMAN_PROFILE;\n const envPath = process.env.CEKI_HUMAN_PROFILE_PATH;\n if (envPath) return new Humanizer(HumanProfile.load(envPath));\n if (envPreset) return new Humanizer(HumanProfile.loadPreset(envPreset));\n return new Humanizer(HumanProfile.loadPreset('natural'));\n }\n if (human === 'natural' || human === 'careful') {\n return new Humanizer(HumanProfile.loadPreset(human));\n }\n return null;\n }\n}\n\n/** Factory function: create a connected Client */\nexport async function connect(apiKey: string, opts?: Partial<ConnectOptions>): Promise<Client> {\n return Client.create(apiKey, opts);\n}\n","import type { ConnectOptions } from './types.js';\n\nexport const defaults = {\n apiUrl: 'https://api.ceki.me',\n relayUrl: 'wss://browser.ceki.me/ws/agent',\n chatUrl: 'https://chat.ceki.me/api/chat',\n};\n\nexport function resolveConfig(opts?: Partial<ConnectOptions>) {\n return {\n apiUrl: opts?.apiUrl ?? process.env.CEKI_API_URL ?? defaults.apiUrl,\n relayUrl: opts?.relayUrl ?? process.env.CEKI_RELAY_URL ?? defaults.relayUrl,\n chatUrl: opts?.chatUrl ?? process.env.CEKI_CHAT_URL ?? defaults.chatUrl,\n basicAuth: opts?.basicAuth ?? (process.env.CEKI_BASIC_AUTH_USER && process.env.CEKI_BASIC_AUTH_PASS\n ? [process.env.CEKI_BASIC_AUTH_USER, process.env.CEKI_BASIC_AUTH_PASS] as [string, string]\n : undefined),\n reconnect: opts?.reconnect ?? true,\n };\n}\n","export class CekiBrowserError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'CekiBrowserError';\n }\n}\n\nexport class AuthError extends CekiBrowserError {\n constructor(message = 'Authentication failed') {\n super(message);\n this.name = 'AuthError';\n }\n}\n\nexport class SessionNotFound extends CekiBrowserError {\n constructor(message = 'Session not found') {\n super(message);\n this.name = 'SessionNotFound';\n }\n}\n\nexport class SessionExpired extends SessionNotFound {\n constructor(message = 'Session expired') {\n super(message);\n this.name = 'SessionExpired';\n }\n}\n\nexport class NotOwner extends CekiBrowserError {\n constructor(message = 'Not session owner') {\n super(message);\n this.name = 'NotOwner';\n }\n}\n\nexport class TransportError extends CekiBrowserError {\n constructor(message = 'Transport error') {\n super(message);\n this.name = 'TransportError';\n }\n}\n\nexport class TimeoutError extends CekiBrowserError {\n constructor(message = 'Operation timed out') {\n super(message);\n this.name = 'TimeoutError';\n }\n}\n\nexport class SessionEnded extends CekiBrowserError {\n reason: string;\n constructor(reason: string) {\n super(`Session ended: ${reason}`);\n this.name = 'SessionEnded';\n this.reason = reason;\n }\n}\n\nexport class InsufficientFunds extends CekiBrowserError {\n constructor(message = 'Insufficient funds') {\n super(message);\n this.name = 'InsufficientFunds';\n }\n}\n\nexport class RateLimitExceeded extends CekiBrowserError {\n retryAfter: number;\n constructor(retryAfter = 0, message = 'Rate limit exceeded') {\n super(message);\n this.name = 'RateLimitExceeded';\n this.retryAfter = retryAfter;\n }\n}\n\nexport class ConnectionLost extends CekiBrowserError {\n constructor(message = 'Connection lost') {\n super(message);\n this.name = 'ConnectionLost';\n }\n}\n\nexport class ProviderOffline extends CekiBrowserError {\n constructor(message = 'Provider offline') {\n super(message);\n this.name = 'ProviderOffline';\n }\n}\n\nexport class ProviderDisconnected extends CekiBrowserError {\n constructor(message = 'Provider disconnected') {\n super(message);\n this.name = 'ProviderDisconnected';\n }\n}\n\nexport class CdpUnrecoverable extends CekiBrowserError {\n lastError: string;\n constructor(lastError: string) {\n super(`CDP unrecoverable: ${lastError}`);\n this.name = 'CdpUnrecoverable';\n this.lastError = lastError;\n }\n}\n\nexport class CaptchaError extends CekiBrowserError {\n constructor(message = 'Captcha error') {\n super(message);\n this.name = 'CaptchaError';\n }\n}\n\nexport class CaptchaTimeoutError extends CaptchaError {\n phase: 'acceptance' | 'completion';\n constructor(phase: 'acceptance' | 'completion') {\n super(`Captcha timeout: ${phase}`);\n this.name = 'CaptchaTimeoutError';\n this.phase = phase;\n }\n}\n\nexport class ChatSendFailed extends CekiBrowserError {\n status: number;\n messageText: string;\n constructor(status: number, messageText: string) {\n super(`Chat send failed (${status})`);\n this.name = 'ChatSendFailed';\n this.status = status;\n this.messageText = messageText;\n }\n}\n","import * as crypto from 'node:crypto';\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport { TimeoutError, ChatSendFailed } from './errors.js';\nimport type { ChatMessage, ReadReceipt, ChatHistoryOptions } from './types.js';\nimport type { Browser } from './browser.js';\n\ntype MessageHandler = (msg: ChatMessage) => void | Promise<void>;\ntype ReadHandler = (receipt: ReadReceipt) => void | Promise<void>;\n\ninterface PendingSend {\n resolve: (value: { messageId: string; sentAt: string }) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n}\n\nconst MAX_IMAGE_SIZE = 5 * 1024 * 1024; // 5MB\n\nfunction detectMime(buf: Buffer): { mime: string; ext: string } {\n if (buf.length >= 4 && buf[0] === 0x89 && buf[1] === 0x50 && buf[2] === 0x4e && buf[3] === 0x47) {\n return { mime: 'image/png', ext: 'png' };\n }\n if (buf.length >= 3 && buf[0] === 0xff && buf[1] === 0xd8 && buf[2] === 0xff) {\n return { mime: 'image/jpeg', ext: 'jpg' };\n }\n if (buf.length >= 12 && buf[0] === 0x52 && buf[1] === 0x49 && buf[2] === 0x46 && buf[3] === 0x46\n && buf[8] === 0x57 && buf[9] === 0x45 && buf[10] === 0x42 && buf[11] === 0x50) {\n return { mime: 'image/webp', ext: 'webp' };\n }\n return { mime: 'application/octet-stream', ext: 'bin' };\n}\n\nfunction randomHex(len: number): string {\n return crypto.randomBytes(len / 2).toString('hex');\n}\n\nexport class BrowserChat {\n private _browser: Browser;\n private _topicId: string | null;\n private _messageHandlers: MessageHandler[] = [];\n private _readHandlers: ReadHandler[] = [];\n private _pendingSends: Map<string, PendingSend> = new Map();\n /** @internal */ _actionCallbacks: Map<number, (action: Record<string, unknown>) => void> = new Map();\n\n constructor(browser: Browser) {\n this._browser = browser;\n this._topicId = browser.chatTopicId;\n }\n\n get topicId(): string | null {\n return this._topicId;\n }\n\n async send(text: string): Promise<{ messageId: string; sentAt: string }> {\n const clientMsgId = randomHex(32);\n const msg = {\n type: 'chat.send' as const,\n session_id: this._browser.sessionId,\n client_msg_id: clientMsgId,\n text,\n };\n\n return new Promise<{ messageId: string; sentAt: string }>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingSends.delete(clientMsgId);\n reject(new TimeoutError('Chat send timed out'));\n }, 15000);\n this._pendingSends.set(clientMsgId, { resolve, reject, timer });\n this._browser._sendRaw(msg);\n });\n }\n\n async sendImage(source: string | Buffer, text?: string): Promise<{ messageId: string; sentAt: string }> {\n let buf: Buffer;\n let filename: string;\n\n if (typeof source === 'string') {\n buf = fs.readFileSync(source);\n filename = path.basename(source);\n } else {\n buf = Buffer.isBuffer(source) ? source : Buffer.from(source);\n filename = 'image';\n }\n\n if (buf.length > MAX_IMAGE_SIZE) {\n throw new Error(`Image too large: ${buf.length} bytes (max ${MAX_IMAGE_SIZE})`);\n }\n\n const { mime, ext } = detectMime(buf);\n if (!filename.includes('.')) {\n filename = `${filename}.${ext}`;\n }\n\n const clientMsgId = randomHex(32);\n const data_b64 = buf.toString('base64');\n\n const msg: Record<string, unknown> = {\n type: 'chat.send_image',\n session_id: this._browser.sessionId,\n client_msg_id: clientMsgId,\n filename,\n mime,\n data_b64,\n };\n if (text) msg.text = text;\n\n return new Promise<{ messageId: string; sentAt: string }>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingSends.delete(clientMsgId);\n reject(new TimeoutError('Chat sendImage timed out'));\n }, 15000);\n this._pendingSends.set(clientMsgId, { resolve, reject, timer });\n this._browser._sendRaw(msg);\n });\n }\n\n onMessage(cb: MessageHandler): void {\n this._messageHandlers.push(cb);\n }\n\n onRead(cb: ReadHandler): void {\n this._readHandlers.push(cb);\n }\n\n async history(opts?: ChatHistoryOptions): Promise<ChatMessage[]> {\n if (!this._topicId) return [];\n\n const params = new URLSearchParams();\n params.set('topic_id', this._topicId);\n if (opts?.limit != null) params.set('limit', String(opts.limit));\n if (opts?.beforeId) params.set('before', opts.beforeId);\n if (opts?.since) params.set('since', opts.since);\n\n const url = `${this._browser._chatUrl}/messages?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._browser._apiKey}`,\n };\n\n const basicAuth = this._browser._basicAuth;\n if (basicAuth) {\n const encoded = Buffer.from(`${basicAuth[0]}:${basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new Error(`Chat history request failed: ${resp.status} ${resp.statusText}`);\n }\n\n const body = await resp.json() as Record<string, unknown>;\n const messages = (body.messages ?? body.data ?? body) as Record<string, unknown>[];\n if (!Array.isArray(messages)) return [];\n\n return messages.map(parseChatMessage);\n }\n\n /** @internal */\n _onMessage(payload: Record<string, unknown>): void {\n const msgData = (payload.message ?? payload) as Record<string, unknown>;\n if (msgData.type === 'action' && msgData.action) {\n const action = msgData.action as Record<string, unknown>;\n const eventId = Number(action.event_id);\n if (eventId && this._actionCallbacks.has(eventId)) {\n this._actionCallbacks.get(eventId)!(action);\n }\n }\n const msg = parseChatMessage(msgData);\n for (const h of this._messageHandlers) {\n try {\n const result = h(msg);\n if (result && typeof (result as Promise<void>).catch === 'function') {\n (result as Promise<void>).catch(() => {});\n }\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onRead(payload: Record<string, unknown>): void {\n const receipt: ReadReceipt = {\n topic_id: String(payload.topic_id ?? this._topicId ?? ''),\n last_read_message_id: String(payload.last_read_message_id ?? ''),\n read_at: Number(payload.read_at ?? 0),\n };\n for (const h of this._readHandlers) {\n try {\n const result = h(receipt);\n if (result && typeof (result as Promise<void>).catch === 'function') {\n (result as Promise<void>).catch(() => {});\n }\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onSendAck(msg: Record<string, unknown>): void {\n const clientMsgId = String(msg.client_msg_id ?? '');\n const pending = this._pendingSends.get(clientMsgId);\n if (!pending) return;\n clearTimeout(pending.timer);\n this._pendingSends.delete(clientMsgId);\n pending.resolve({\n messageId: String(msg.message_id ?? ''),\n sentAt: String(msg.sent_at ?? ''),\n });\n }\n\n /** @internal */\n _onSendError(msg: Record<string, unknown>): void {\n const clientMsgId = String(msg.client_msg_id ?? '');\n const pending = this._pendingSends.get(clientMsgId);\n if (!pending) return;\n clearTimeout(pending.timer);\n this._pendingSends.delete(clientMsgId);\n pending.reject(new ChatSendFailed(\n Number(msg.status ?? 0),\n String(msg.message ?? ''),\n ));\n }\n}\n\nfunction parseChatMessage(data: Record<string, unknown>): ChatMessage {\n const action = data.action as Record<string, unknown> | undefined;\n return {\n id: String(data.id ?? data._id ?? data.message_id ?? ''),\n topic_id: String(data.topic_id ?? ''),\n sender_id: data.sender_id != null ? Number(data.sender_id) : null,\n text: data.text != null ? String(data.text) : null,\n media: (data.media as Record<string, unknown>[] | null) ?? null,\n type: String(data.type ?? 'text'),\n created_at: String(data.created_at ?? ''),\n edited_at: data.edited_at != null ? String(data.edited_at) : null,\n deleted_at: data.deleted_at != null ? String(data.deleted_at) : null,\n action: action ? {\n kind: String(action.kind ?? ''),\n event_id: Number(action.event_id ?? 0),\n data: (action.data as Record<string, unknown>) ?? undefined,\n } : null,\n };\n}\n","import type { Browser } from './browser.js';\nimport type { Profile, ProfileExportOptions } from './types.js';\n\nexport class BrowserProfile {\n private _browser: Browser;\n\n constructor(browser: Browser) {\n this._browser = browser;\n }\n\n async export(opts?: ProfileExportOptions): Promise<Profile> {\n // 1. Try fingerprint (graceful fail)\n let fingerprint: Record<string, unknown> | null = null;\n try {\n const fpResult = await this._browser.send({ method: 'Browser.getFingerprint' });\n fingerprint = (fpResult as Record<string, unknown>) ?? null;\n } catch {\n fingerprint = null;\n }\n\n // 2. Get cookies\n let cookies: Record<string, unknown>[] = [];\n try {\n const cookieResult = await this._browser.send({ method: 'Network.getCookies' }) as Record<string, unknown>;\n const allCookies = (cookieResult?.cookies ?? []) as Record<string, unknown>[];\n\n if (opts?.domains && opts.domains.length > 0) {\n const domainSet = new Set(opts.domains.map(d => d.toLowerCase()));\n cookies = allCookies.filter(c => {\n const cookieDomain = String(c.domain ?? '').toLowerCase().replace(/^\\./, '');\n return domainSet.has(cookieDomain) || opts!.domains!.some(d =>\n cookieDomain.endsWith('.' + d.toLowerCase()) || cookieDomain === d.toLowerCase()\n );\n });\n } else {\n cookies = allCookies;\n }\n } catch {\n cookies = [];\n }\n\n // 3. Get localStorage\n let localStorage: Record<string, string> = {};\n try {\n const lsResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'JSON.stringify(localStorage)', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = lsResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n localStorage = JSON.parse(String(resultObj.value)) as Record<string, string>;\n }\n } catch {\n localStorage = {};\n }\n\n // 4. Get sessionStorage\n let sessionStorage: Record<string, string> = {};\n if (opts?.includeSessionStorage !== false) {\n try {\n const ssResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'JSON.stringify(sessionStorage)', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = ssResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n sessionStorage = JSON.parse(String(resultObj.value)) as Record<string, string>;\n }\n } catch {\n sessionStorage = {};\n }\n }\n\n // 5. Get origin\n let origin = '';\n try {\n const originResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'location.origin', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = originResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n origin = String(resultObj.value);\n }\n } catch {\n origin = '';\n }\n\n return {\n schema_version: 2,\n fingerprint,\n origin,\n cookies,\n localStorage,\n sessionStorage,\n };\n }\n\n async import(profile: Profile): Promise<void> {\n if (profile.schema_version !== 1 && profile.schema_version !== 2) {\n throw new Error(`Unsupported profile schema_version: ${profile.schema_version}`);\n }\n\n // Set cookies\n if (profile.cookies && profile.cookies.length > 0) {\n await this._browser.send({\n method: 'Network.setCookies',\n params: { cookies: profile.cookies },\n });\n }\n\n // Inject localStorage\n if (profile.localStorage && Object.keys(profile.localStorage).length > 0) {\n const entries = JSON.stringify(profile.localStorage);\n await this._browser.send({\n method: 'Runtime.evaluate',\n params: {\n expression: `(function(){var d=${entries};for(var k in d)localStorage.setItem(k,d[k])})()`,\n returnByValue: true,\n },\n });\n }\n\n // Inject sessionStorage\n if (profile.sessionStorage && Object.keys(profile.sessionStorage).length > 0) {\n const entries = JSON.stringify(profile.sessionStorage);\n await this._browser.send({\n method: 'Runtime.evaluate',\n params: {\n expression: `(function(){var d=${entries};for(var k in d)sessionStorage.setItem(k,d[k])})()`,\n returnByValue: true,\n },\n });\n }\n }\n}\n","import * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport * as os from 'node:os';\n\nconst STATE_DIR = path.join(os.homedir(), '.ceki', 'sessions');\n\nfunction statePath(sid: string): string {\n return path.join(STATE_DIR, `${sid}.json`);\n}\n\nexport function loadSession(sid: string): Record<string, unknown> | null {\n try {\n const raw = fs.readFileSync(statePath(sid), 'utf-8');\n return JSON.parse(raw) as Record<string, unknown>;\n } catch {\n return null;\n }\n}\n\nexport function saveSession(sid: string, data: Record<string, unknown>): void {\n fs.mkdirSync(STATE_DIR, { recursive: true });\n const payload = { ...data, updated_at: new Date().toISOString() };\n fs.writeFileSync(statePath(sid), JSON.stringify(payload, null, 2), 'utf-8');\n}\n\nexport function deleteSession(sid: string): void {\n try {\n fs.unlinkSync(statePath(sid));\n } catch (err: unknown) {\n if ((err as NodeJS.ErrnoException).code !== 'ENOENT') throw err;\n }\n}\n\nexport function getLastSeenTs(sid: string): string | null {\n const data = loadSession(sid);\n if (!data) return null;\n return (data.last_seen_ts as string) ?? null;\n}\n\nexport function updateLastSeenTs(sid: string, ts: string): void {\n const data = loadSession(sid) ?? {};\n data.last_seen_ts = ts;\n saveSession(sid, data);\n}\n","export interface KeyMapping {\n code: string;\n key: string;\n vk: number;\n needsShift: boolean;\n}\n\nconst STATIC_MAP: Record<string, KeyMapping> = {\n ' ': { code: 'Space', key: ' ', vk: 32, needsShift: false },\n '\\n': { code: 'Enter', key: 'Enter', vk: 13, needsShift: false },\n '\\t': { code: 'Tab', key: 'Tab', vk: 9, needsShift: false },\n\n // Shifted digits\n '!': { code: 'Digit1', key: '!', vk: 49, needsShift: true },\n '@': { code: 'Digit2', key: '@', vk: 50, needsShift: true },\n '#': { code: 'Digit3', key: '#', vk: 51, needsShift: true },\n '$': { code: 'Digit4', key: '$', vk: 52, needsShift: true },\n '%': { code: 'Digit5', key: '%', vk: 53, needsShift: true },\n '^': { code: 'Digit6', key: '^', vk: 54, needsShift: true },\n '&': { code: 'Digit7', key: '&', vk: 55, needsShift: true },\n '*': { code: 'Digit8', key: '*', vk: 56, needsShift: true },\n '(': { code: 'Digit9', key: '(', vk: 57, needsShift: true },\n ')': { code: 'Digit0', key: ')', vk: 48, needsShift: true },\n\n // Punctuation (unshifted)\n '-': { code: 'Minus', key: '-', vk: 189, needsShift: false },\n '=': { code: 'Equal', key: '=', vk: 187, needsShift: false },\n '[': { code: 'BracketLeft', key: '[', vk: 219, needsShift: false },\n ']': { code: 'BracketRight', key: ']', vk: 221, needsShift: false },\n '\\\\': { code: 'Backslash', key: '\\\\', vk: 220, needsShift: false },\n ';': { code: 'Semicolon', key: ';', vk: 186, needsShift: false },\n \"'\": { code: 'Quote', key: \"'\", vk: 222, needsShift: false },\n ',': { code: 'Comma', key: ',', vk: 188, needsShift: false },\n '.': { code: 'Period', key: '.', vk: 190, needsShift: false },\n '/': { code: 'Slash', key: '/', vk: 191, needsShift: false },\n '`': { code: 'Backquote', key: '`', vk: 192, needsShift: false },\n\n // Punctuation (shifted)\n '_': { code: 'Minus', key: '_', vk: 189, needsShift: true },\n '+': { code: 'Equal', key: '+', vk: 187, needsShift: true },\n '{': { code: 'BracketLeft', key: '{', vk: 219, needsShift: true },\n '}': { code: 'BracketRight', key: '}', vk: 221, needsShift: true },\n '|': { code: 'Backslash', key: '|', vk: 220, needsShift: true },\n ':': { code: 'Semicolon', key: ':', vk: 186, needsShift: true },\n '\"': { code: 'Quote', key: '\"', vk: 222, needsShift: true },\n '<': { code: 'Comma', key: '<', vk: 188, needsShift: true },\n '>': { code: 'Period', key: '>', vk: 190, needsShift: true },\n '?': { code: 'Slash', key: '?', vk: 191, needsShift: true },\n '~': { code: 'Backquote', key: '~', vk: 192, needsShift: true },\n};\n\nexport function keymapForChar(char: string): KeyMapping | null {\n // a-z\n if (char >= 'a' && char <= 'z') {\n const upper = char.toUpperCase();\n return {\n code: `Key${upper}`,\n key: char,\n vk: upper.charCodeAt(0),\n needsShift: false,\n };\n }\n\n // A-Z\n if (char >= 'A' && char <= 'Z') {\n return {\n code: `Key${char}`,\n key: char,\n vk: char.charCodeAt(0),\n needsShift: true,\n };\n }\n\n // 0-9\n if (char >= '0' && char <= '9') {\n return {\n code: `Digit${char}`,\n key: char,\n vk: char.charCodeAt(0),\n needsShift: false,\n };\n }\n\n // Static map\n const mapping = STATIC_MAP[char];\n if (mapping) return mapping;\n\n // Non-ASCII or unknown — fallback\n return null;\n}\n","import { TimeoutError, SessionEnded, CaptchaError, CaptchaTimeoutError } from './errors.js';\nimport { BrowserChat } from './chat.js';\nimport { BrowserProfile } from './profile.js';\nimport { saveSession, getLastSeenTs, updateLastSeenTs } from './state.js';\nimport type { Match, ScreenshotOptions, ScrollOptions, Snapshot, ChatMessage, CaptchaOptions, CaptchaResult } from './types.js';\nimport type { Client } from './client.js';\n\nimport { Humanizer } from './humanize/humanizer.js';\nimport { HumanProfile } from './humanize/profile.js';\nimport { keymapForChar } from './humanize/keymap.js';\nexport type { Humanizer, HumanProfile };\n\ninterface PendingCdp {\n resolve: (value: unknown) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n}\n\ntype EventHandler = (method: string, params: Record<string, unknown>) => void;\ntype TabHandler = (url: string) => void;\ntype VoidHandler = () => void;\ntype UserEventHandler = (events: Record<string, unknown>[]) => void;\n\nexport class Browser {\n readonly sessionId: string;\n readonly browserId: number;\n readonly scheduleId: number;\n readonly chatTopicId: string | null;\n readonly browserInfo: Record<string, unknown>;\n readonly providerUserId: number | null;\n /** @internal */ _eventId: string | null;\n\n readonly chat: BrowserChat;\n readonly profile: BrowserProfile;\n\n /** @internal */ _client: Client;\n /** @internal */ _humanizer: Humanizer | null = null;\n /** @internal */ _lastPointer: [number, number] | null = null;\n /** @internal */ _lastSeenTs: string | null = null;\n /** @internal */ _cdpCounter = 1;\n /** @internal */ _pendingCdp: Map<number, PendingCdp> = new Map();\n /** @internal */ _ended: Promise<string>;\n /** @internal */ _endedReason: string | null = null;\n /** @internal */ _resolveEnded!: (reason: string) => void;\n\n private _eventHandlers: EventHandler[] = [];\n private _tabHandlers: TabHandler[] = [];\n private _disconnectHandlers: VoidHandler[] = [];\n private _reconnectHandlers: VoidHandler[] = [];\n private _userEventHandlers: UserEventHandler[] = [];\n\n /** @internal */\n get _apiKey(): string {\n return this._client._apiKey;\n }\n\n /** @internal */\n get _chatUrl(): string {\n return this._client._chatUrl;\n }\n\n /** @internal */\n get _basicAuth(): [string, string] | undefined {\n return this._client._basicAuth;\n }\n\n constructor(client: Client, match: Match, humanizer?: Humanizer | null) {\n this._client = client;\n this.sessionId = match.session_id;\n this.browserId = match.schedule_id;\n this.scheduleId = match.schedule_id;\n this.chatTopicId = match.chat_topic_id ?? null;\n this.browserInfo = match.browser_info ?? {};\n this.providerUserId = match.provider_user_id ?? null;\n this._eventId = match.event_id ?? null;\n this._humanizer = humanizer ?? null;\n\n this.chat = new BrowserChat(this);\n this.profile = new BrowserProfile(this);\n\n this._ended = new Promise<string>((resolve) => {\n this._resolveEnded = resolve;\n });\n\n // Load last_seen_ts from state\n this._lastSeenTs = getLastSeenTs(this.sessionId);\n\n // Save session state\n saveSession(this.sessionId, {\n session_id: this.sessionId,\n chat_topic_id: this.chatTopicId,\n schedule_id: this.scheduleId,\n last_seen_ts: this._lastSeenTs,\n });\n }\n\n /** @internal — send raw message via client WS */\n _sendRaw(msg: Record<string, unknown>): void {\n this._client._wsSend(msg);\n }\n\n async send(\n cdp: { method: string; params?: Record<string, unknown> },\n timeout = 30000,\n ): Promise<unknown> {\n if (this._endedReason) {\n throw new SessionEnded(this._endedReason);\n }\n\n const id = this._cdpCounter++;\n const msg = {\n type: 'cdp' as const,\n session_id: this.sessionId,\n id,\n method: cdp.method,\n params: cdp.params ?? {},\n };\n\n return new Promise<unknown>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingCdp.delete(id);\n reject(new TimeoutError(`CDP ${cdp.method} timed out after ${timeout}ms`));\n }, timeout);\n this._pendingCdp.set(id, { resolve, reject, timer });\n this._sendRaw(msg);\n });\n }\n\n async navigate(url: string, timeout = 30000): Promise<{ url: string; frameId?: string }> {\n if (this._humanizer) await this._humanizer.before('navigate');\n const result = await this.send({ method: 'Page.navigate', params: { url } }, timeout) as Record<string, unknown>;\n if (this._humanizer) await this._humanizer.after('navigate');\n return {\n url: String(result?.url ?? url),\n frameId: result?.frameId ? String(result.frameId) : undefined,\n };\n }\n\n async click(x: number, y: number): Promise<void> {\n if (this._humanizer) await this._humanizer.before('click');\n\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mousePressed', x, y, button: 'left', clickCount: 1 },\n });\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseReleased', x, y, button: 'left', clickCount: 1 },\n });\n\n this._lastPointer = [x, y];\n\n if (this._humanizer) await this._humanizer.after('click');\n }\n\n private async _sendKeystroke(char: string): Promise<void> {\n const mapping = keymapForChar(char);\n if (!mapping) {\n await this.send({ method: 'Input.insertText', params: { text: char } });\n return;\n }\n const { code, key, vk, needsShift } = mapping;\n if (needsShift) {\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: { type: 'keyDown', key: 'Shift', code: 'ShiftLeft', windowsVirtualKeyCode: 16, nativeVirtualKeyCode: 16 },\n });\n }\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: {\n type: 'keyDown', key, code, text: char,\n unmodifiedText: needsShift ? char.toLowerCase() : char,\n windowsVirtualKeyCode: vk, nativeVirtualKeyCode: vk,\n ...(needsShift ? { modifiers: 8 } : {}),\n },\n });\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: {\n type: 'keyUp', key, code,\n windowsVirtualKeyCode: vk, nativeVirtualKeyCode: vk,\n ...(needsShift ? { modifiers: 8 } : {}),\n },\n });\n if (needsShift) {\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: { type: 'keyUp', key: 'Shift', code: 'ShiftLeft', windowsVirtualKeyCode: 16, nativeVirtualKeyCode: 16 },\n });\n }\n }\n\n async type(text: string): Promise<void> {\n if (this._humanizer) {\n await this._humanizer.before('type');\n\n // Re-click last pointer position to focus\n if (this._lastPointer) {\n const [px, py] = this._lastPointer;\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mousePressed', x: px, y: py, button: 'left', clickCount: 1 },\n });\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseReleased', x: px, y: py, button: 'left', clickCount: 1 },\n });\n }\n\n // Type char-by-char with delays\n for (const char of text) {\n await this._sendKeystroke(char);\n const delay = this._humanizer.typeDelay();\n if (delay > 0) {\n await new Promise<void>(r => setTimeout(r, delay));\n }\n }\n\n await this._humanizer.after('type');\n } else {\n for (const char of text) {\n await this._sendKeystroke(char);\n }\n }\n }\n\n async scroll(opts?: ScrollOptions): Promise<void> {\n const x = opts?.x ?? 0;\n const y = opts?.y ?? 0;\n const deltaX = opts?.deltaX ?? 0;\n const deltaY = opts?.deltaY ?? -300;\n\n if (this._humanizer) await this._humanizer.before('scroll');\n\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseWheel', x, y, deltaX, deltaY },\n });\n\n this._lastPointer = [x, y];\n\n if (this._humanizer) await this._humanizer.after('scroll');\n }\n\n async screenshot(opts?: ScreenshotOptions): Promise<{ data: string } | Buffer> {\n const format = opts?.format ?? 'base64';\n const fullPage = opts?.fullPage ?? false;\n\n let clip: Record<string, unknown> | undefined;\n\n if (fullPage) {\n const metrics = await this.send({ method: 'Page.getLayoutMetrics' }) as Record<string, unknown>;\n const contentSize = metrics?.contentSize as Record<string, unknown> | undefined;\n if (contentSize) {\n const width = Number(contentSize.width ?? 1920);\n const height = Math.min(Number(contentSize.height ?? 1080), 16384);\n clip = { x: 0, y: 0, width, height, scale: 1 };\n }\n }\n\n const params: Record<string, unknown> = { format: 'png' };\n if (clip) params.clip = clip;\n\n const result = await this.send({ method: 'Page.captureScreenshot', params }) as Record<string, unknown>;\n const data = String(result?.data ?? '');\n\n if (format === 'png') {\n return Buffer.from(data, 'base64');\n }\n\n return { data };\n }\n\n async snapshot(): Promise<Snapshot> {\n const [ssResult, chatMessages] = await Promise.all([\n this.screenshot({ format: 'base64' }),\n this.chat.history({ since: this._lastSeenTs ?? undefined }),\n ]);\n\n const screenshotData = (ssResult as { data: string }).data;\n\n if (chatMessages.length > 0) {\n const lastMsg = chatMessages[chatMessages.length - 1];\n this._lastSeenTs = lastMsg.created_at;\n updateLastSeenTs(this.sessionId, this._lastSeenTs);\n }\n\n return {\n screenshot: screenshotData,\n chat: chatMessages,\n ts: new Date(),\n };\n }\n\n async upload(\n selector: string,\n source: string | Buffer,\n filename?: string,\n ): Promise<{ ok: boolean; filename: string; size: number }> {\n let buf: Buffer;\n let resolvedFilename: string;\n\n if (typeof source === 'string') {\n const fs = await import('node:fs');\n const path = await import('node:path');\n buf = fs.readFileSync(source);\n resolvedFilename = filename ?? path.basename(source);\n } else {\n buf = Buffer.isBuffer(source) ? source : Buffer.from(source);\n resolvedFilename = filename ?? 'file';\n }\n\n const b64 = buf.toString('base64');\n const size = buf.length;\n\n // Inject file via Runtime.evaluate + DataTransfer + File API\n const expression = `\n (function() {\n var input = document.querySelector(${JSON.stringify(selector)});\n if (!input) return JSON.stringify({ok: false, error: 'Element not found'});\n var b64 = ${JSON.stringify(b64)};\n var binary = atob(b64);\n var bytes = new Uint8Array(binary.length);\n for (var i = 0; i < binary.length; i++) bytes[i] = binary.charCodeAt(i);\n var file = new File([bytes], ${JSON.stringify(resolvedFilename)}, {type: 'application/octet-stream'});\n var dt = new DataTransfer();\n dt.items.add(file);\n input.files = dt.files;\n input.dispatchEvent(new Event('change', {bubbles: true}));\n return JSON.stringify({ok: true, filename: ${JSON.stringify(resolvedFilename)}, size: ${size}});\n })()\n `.trim();\n\n const result = await this.send({\n method: 'Runtime.evaluate',\n params: { expression, returnByValue: true },\n }) as Record<string, unknown>;\n\n const resultObj = result?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n return JSON.parse(String(resultObj.value)) as { ok: boolean; filename: string; size: number };\n }\n return { ok: true, filename: resolvedFilename, size };\n }\n\n async switchTab(): Promise<void> {\n this._sendRaw({ type: 'switch_tab', session_id: this.sessionId });\n }\n\n async configure(opts: { maskingMode?: boolean; fingerprint?: boolean | Record<string, unknown> }): Promise<void> {\n const msg: Record<string, unknown> = {\n type: 'session.configure',\n session_id: this.sessionId,\n };\n if (opts.maskingMode !== undefined) msg.masking_mode = opts.maskingMode;\n if (opts.fingerprint !== undefined) msg.fingerprint = opts.fingerprint;\n this._sendRaw(msg);\n }\n\n async close(timeout = 10000): Promise<void> {\n if (this._endedReason) return;\n\n this._sendRaw({\n type: 'session.end',\n session_id: this.sessionId,\n reason: 'user_stop',\n });\n\n await Promise.race([\n this._ended,\n new Promise<void>((_, reject) =>\n setTimeout(() => reject(new TimeoutError('Close timed out')), timeout)\n ),\n ]).catch(() => {\n // If timed out, force cleanup\n });\n\n this._cleanup();\n }\n\n async release(timeout?: number): Promise<void> {\n return this.close(timeout);\n }\n\n async waitUntilEnded(): Promise<string> {\n return this._ended;\n }\n\n onEvent(cb: EventHandler): void {\n this._eventHandlers.push(cb);\n }\n\n onTabOpened(cb: TabHandler): void {\n this._tabHandlers.push(cb);\n }\n\n onProviderDisconnected(cb: VoidHandler): void {\n this._disconnectHandlers.push(cb);\n }\n\n onProviderReconnected(cb: VoidHandler): void {\n this._reconnectHandlers.push(cb);\n }\n\n onUserEvent(cb: UserEventHandler): void {\n this._userEventHandlers.push(cb);\n }\n\n // --- Captcha / human action ---\n\n private _apiHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n 'Content-Type': 'application/json',\n };\n const basicAuth = this._basicAuth;\n if (basicAuth) {\n const encoded = Buffer.from(`${basicAuth[0]}:${basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n return headers;\n }\n\n async requestCaptcha(opts?: CaptchaOptions): Promise<CaptchaResult> {\n let acceptanceTimeout = opts?.acceptanceTimeout ?? 60;\n let completionTimeout = opts?.completionTimeout ?? 120;\n const autoAccept = opts?.autoAccept ?? true;\n\n if (acceptanceTimeout < 30) throw new Error('acceptanceTimeout must be >= 30 seconds');\n if (completionTimeout < 30) throw new Error('completionTimeout must be >= 30 seconds');\n\n acceptanceTimeout = Math.min(acceptanceTimeout, 300);\n completionTimeout = Math.min(completionTimeout, 600);\n\n const { id: childEventId } = await this._createCaptchaEvent(acceptanceTimeout, completionTimeout);\n const completionDeadline = Date.now() + completionTimeout * 1000;\n\n const buffer: Record<string, unknown>[] = [];\n let waiter: ((action: Record<string, unknown>) => void) | null = null;\n\n this.chat._actionCallbacks.set(childEventId, (action) => {\n if (waiter) {\n const w = waiter;\n waiter = null;\n w(action);\n } else {\n buffer.push(action);\n }\n });\n\n const nextAction = (timeoutMs: number): Promise<Record<string, unknown>> => {\n if (buffer.length > 0) return Promise.resolve(buffer.shift()!);\n return new Promise<Record<string, unknown>>((resolve, reject) => {\n const timer = setTimeout(() => {\n waiter = null;\n reject(new Error('timeout'));\n }, timeoutMs);\n waiter = (action) => {\n clearTimeout(timer);\n resolve(action);\n };\n });\n };\n\n const cleanup = () => {\n this.chat._actionCallbacks.delete(childEventId);\n waiter = null;\n };\n\n const makeResult = async (\n data: Record<string, unknown>,\n solved: boolean,\n ): Promise<CaptchaResult> => {\n const correctionId = data.correction_id != null ? Number(data.correction_id) : null;\n const proofMessageId = data.proof_message_id != null ? String(data.proof_message_id) : null;\n let voted = false;\n\n const result: CaptchaResult = {\n solved,\n proofMessageId,\n cancelReason: null,\n childEventId,\n correctionId,\n acceptWork: async () => {\n if (voted) return;\n if (!correctionId) throw new CaptchaError('no correction_id — provider has not proposed completion');\n voted = true;\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}/vote`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify({ ids: [correctionId], vote: true }),\n });\n },\n rejectWork: async (reason?: string) => {\n if (voted) return;\n if (!correctionId) throw new CaptchaError('no correction_id — provider has not proposed completion');\n voted = true;\n const body: Record<string, unknown> = { ids: [correctionId], vote: false };\n if (reason) body.reason = reason;\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}/vote`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify(body),\n });\n },\n };\n\n if (autoAccept && solved && correctionId) {\n await new Promise<void>(r => setTimeout(r, 2000));\n await result.acceptWork();\n }\n\n return result;\n };\n\n let accepted = false;\n\n try {\n // Phase 1: wait for acceptance\n const acceptDeadline = Date.now() + acceptanceTimeout * 1000;\n while (true) {\n const remaining = acceptDeadline - Date.now();\n if (remaining <= 0) throw new Error('timeout');\n const action = await nextAction(remaining);\n const kind = String(action.kind ?? '');\n const data = (action.data ?? {}) as Record<string, unknown>;\n\n if (kind === 'human_action_accepted') {\n accepted = true;\n break;\n }\n if (kind === 'human_action_completed') {\n cleanup();\n return await makeResult(data, true);\n }\n if (kind === 'human_action_failed' || kind === 'human_action_declined' || kind === 'human_action_withdrew') {\n cleanup();\n return {\n solved: false,\n proofMessageId: null,\n cancelReason: kind.replace('human_action_', ''),\n childEventId,\n correctionId: null,\n acceptWork: async () => {},\n rejectWork: async () => {},\n };\n }\n }\n\n // Phase 2: wait for completion\n while (true) {\n const remaining = completionDeadline - Date.now();\n if (remaining <= 0) throw new Error('timeout');\n const action = await nextAction(remaining);\n const kind = String(action.kind ?? '');\n const data = (action.data ?? {}) as Record<string, unknown>;\n\n if (kind === 'human_action_completed') {\n cleanup();\n return await makeResult(data, true);\n }\n if (kind === 'human_action_failed' || kind === 'human_action_withdrew') {\n cleanup();\n return {\n solved: false,\n proofMessageId: null,\n cancelReason: kind.replace('human_action_', ''),\n childEventId,\n correctionId: null,\n acceptWork: async () => {},\n rejectWork: async () => {},\n };\n }\n }\n } catch {\n cleanup();\n const phase = accepted ? 'completion' : 'acceptance';\n await this._expireCaptchaEvent(childEventId);\n throw new CaptchaTimeoutError(phase);\n }\n }\n\n private async _createCaptchaEvent(acceptanceTimeout: number, completionTimeout: number): Promise<{ id: number; amount: number }> {\n const body = {\n acceptance_deadline_at: Math.floor(acceptanceTimeout),\n completion_deadline_at: Math.floor(completionTimeout),\n };\n\n const resp = await fetch(`${this._client._apiUrl}/api/agent/sessions/${this._eventId}/captcha-request`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify(body),\n });\n if (!resp.ok) {\n throw new Error(`Captcha request failed: ${resp.status}`);\n }\n const result = await resp.json() as { id: number; amount: number };\n if (!result.id) throw new Error('Captcha request did not return an id');\n return { id: result.id, amount: result.amount };\n }\n\n private async _expireCaptchaEvent(childEventId: number): Promise<void> {\n try {\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}`, {\n method: 'PATCH',\n headers: this._apiHeaders(),\n body: JSON.stringify({ status_id: 777 }),\n });\n } catch { /* best effort */ }\n }\n\n // --- Internal handlers called by Client dispatch ---\n\n /** @internal */\n _onCdpResponse(msg: Record<string, unknown>): void {\n const id = Number(msg.id);\n const pending = this._pendingCdp.get(id);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingCdp.delete(id);\n\n if (msg.ok === false) {\n const error = msg.error as Record<string, unknown> | undefined;\n pending.reject(new Error(String(error?.message ?? error?.code ?? 'CDP error')));\n } else {\n pending.resolve(msg.result ?? null);\n }\n }\n\n /** @internal */\n _onCdpEvent(msg: Record<string, unknown>): void {\n const method = String(msg.method ?? '');\n const params = (msg.params ?? {}) as Record<string, unknown>;\n for (const h of this._eventHandlers) {\n try {\n h(method, params);\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onTabOpened(msg: Record<string, unknown>): void {\n const url = String(msg.url ?? '');\n for (const h of this._tabHandlers) {\n try {\n h(url);\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onSessionEnded(msg: Record<string, unknown>): void {\n const reason = String(msg.reason ?? 'unknown');\n this._endedReason = reason;\n this._resolveEnded(reason);\n this._rejectAllPending(new SessionEnded(reason));\n this._cleanup();\n }\n\n /** @internal */\n _onProviderDisconnected(): void {\n for (const h of this._disconnectHandlers) {\n try { h(); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onProviderReconnected(): void {\n for (const h of this._reconnectHandlers) {\n try { h(); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onError(msg: Record<string, unknown>): void {\n const reason = String(msg.reason ?? msg.message ?? 'unknown error');\n this._endedReason = reason;\n this._resolveEnded(reason);\n this._rejectAllPending(new SessionEnded(reason));\n this._cleanup();\n }\n\n /** @internal */\n _onUserEvents(msg: Record<string, unknown>): void {\n const events = (msg.events ?? []) as Record<string, unknown>[];\n for (const h of this._userEventHandlers) {\n try { h(events); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onChatMessage(payload: Record<string, unknown>): void {\n this.chat._onMessage(payload);\n }\n\n /** @internal */\n _onChatRead(payload: Record<string, unknown>): void {\n this.chat._onRead(payload);\n }\n\n /** @internal */\n _onChatSendAck(msg: Record<string, unknown>): void {\n this.chat._onSendAck(msg);\n }\n\n /** @internal */\n _onChatSendError(msg: Record<string, unknown>): void {\n this.chat._onSendError(msg);\n }\n\n private _rejectAllPending(err: Error): void {\n for (const [id, pending] of this._pendingCdp) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingCdp.clear();\n }\n\n private _cleanup(): void {\n this._client._activeBrowsers.delete(this.sessionId);\n }\n}\n","import { HumanProfile } from './profile.js';\n\nfunction seededRandom(seed: number | null): () => number {\n if (seed === null || seed === undefined) {\n return Math.random;\n }\n let s = seed;\n return () => {\n s = (s * 1664525 + 1013904223) & 0xffffffff;\n return (s >>> 0) / 0xffffffff;\n };\n}\n\nfunction gaussianRandom(rng: () => number, mean: number, sigma: number): number {\n let u1: number, u2: number;\n do { u1 = rng(); } while (u1 === 0);\n u2 = rng();\n const z = Math.sqrt(-2.0 * Math.log(u1)) * Math.cos(2.0 * Math.PI * u2);\n return mean + z * sigma;\n}\n\nexport class Humanizer {\n readonly profile: HumanProfile;\n private _rng: () => number;\n\n constructor(profile: HumanProfile) {\n this.profile = profile;\n this._rng = seededRandom(profile.raw.rng_seed ?? null);\n }\n\n async before(action: string): Promise<void> {\n const [lo, hi] = this.profile.getRange(action, 'pre');\n if (lo === 0 && hi === 0) return;\n const delay = lo + this._rng() * (hi - lo);\n await sleep(delay);\n }\n\n async after(action: string): Promise<void> {\n const [lo, hi] = this.profile.getRange(action, 'post');\n if (lo === 0 && hi === 0) return;\n const delay = lo + this._rng() * (hi - lo);\n await sleep(delay);\n }\n\n typeDelay(): number {\n const typing = this.profile.raw.typing ?? {};\n const wpm = typing.wpm ?? 110;\n const jitter = typing.jitter ?? 0.35;\n const thinkProb = typing.thinking_pause_prob ?? 0;\n const thinkMs = typing.thinking_pause_ms ?? [300, 1200];\n\n const meanInterval = 60_000 / (wpm * 5);\n const sigma = meanInterval * jitter;\n\n let delay = gaussianRandom(this._rng, meanInterval, sigma);\n delay = Math.max(delay, 20);\n\n if (thinkProb > 0 && this._rng() < thinkProb) {\n delay += thinkMs[0] + this._rng() * (thinkMs[1] - thinkMs[0]);\n }\n\n return delay;\n }\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(resolve => setTimeout(resolve, ms));\n}\n","import * as fs from 'node:fs';\n\nexport interface HumanProfileRaw {\n version?: number;\n name?: string;\n typing?: {\n wpm?: number;\n jitter?: number;\n thinking_pause_prob?: number;\n thinking_pause_ms?: [number, number];\n typo_prob?: number;\n };\n pre_action_ms?: Record<string, [number, number]>;\n post_action_ms?: Record<string, [number, number]>;\n mouse?: {\n move_before_click?: boolean;\n trajectory?: string;\n };\n rng_seed?: number | null;\n}\n\nconst PRESETS: Record<string, HumanProfileRaw> = {\n natural: {\n version: 1,\n name: 'natural',\n typing: { wpm: 110, jitter: 0.35, thinking_pause_prob: 0.012, thinking_pause_ms: [300, 1200], typo_prob: 0.0 },\n pre_action_ms: { click: [80, 350], type: [120, 500], scroll: [50, 250], navigate: [0, 0], screenshot: [0, 0] },\n post_action_ms: { click: [150, 800], type: [150, 800], scroll: [200, 900], navigate: [400, 1800], screenshot: [0, 0] },\n mouse: { move_before_click: false, trajectory: 'off' },\n rng_seed: null,\n },\n careful: {\n version: 1,\n name: 'careful',\n typing: { wpm: 80, jitter: 0.4, thinking_pause_prob: 0.025, thinking_pause_ms: [400, 1800], typo_prob: 0.0 },\n pre_action_ms: { click: [200, 600], type: [250, 800], scroll: [100, 400], navigate: [0, 0], screenshot: [0, 0] },\n post_action_ms: { click: [400, 1500], type: [300, 1200], scroll: [300, 1200], navigate: [800, 3000], screenshot: [0, 0] },\n mouse: { move_before_click: false, trajectory: 'off' },\n rng_seed: null,\n },\n};\n\nconst DEFAULTS: HumanProfileRaw = {\n version: 1,\n name: 'custom',\n typing: {\n wpm: 110,\n jitter: 0.35,\n thinking_pause_prob: 0.012,\n thinking_pause_ms: [300, 1200],\n typo_prob: 0.0,\n },\n pre_action_ms: {\n click: [80, 350],\n type: [120, 500],\n scroll: [50, 250],\n navigate: [0, 0],\n screenshot: [0, 0],\n },\n post_action_ms: {\n click: [150, 800],\n type: [150, 800],\n scroll: [200, 900],\n navigate: [400, 1800],\n screenshot: [0, 0],\n },\n mouse: {\n move_before_click: false,\n trajectory: 'off',\n },\n rng_seed: null,\n};\n\nfunction deepMerge(base: Record<string, unknown>, override: Record<string, unknown>): Record<string, unknown> {\n const result: Record<string, unknown> = { ...base };\n for (const [key, value] of Object.entries(override)) {\n if (\n key in result &&\n typeof result[key] === 'object' &&\n result[key] !== null &&\n !Array.isArray(result[key]) &&\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value)\n ) {\n result[key] = deepMerge(\n result[key] as Record<string, unknown>,\n value as Record<string, unknown>,\n );\n } else {\n result[key] = value;\n }\n }\n return result;\n}\n\nexport class HumanProfile {\n readonly name: string;\n readonly raw: HumanProfileRaw;\n\n constructor(name: string, raw: HumanProfileRaw) {\n this.name = name;\n this.raw = raw;\n }\n\n static fromDict(d: Record<string, unknown>): HumanProfile {\n const merged = deepMerge(\n DEFAULTS as unknown as Record<string, unknown>,\n d,\n ) as HumanProfileRaw;\n const name = (d.name as string) ?? 'custom';\n merged.name = name;\n return new HumanProfile(name, merged);\n }\n\n static load(filePath: string): HumanProfile {\n const raw = fs.readFileSync(filePath, 'utf-8');\n const data = JSON.parse(raw) as Record<string, unknown>;\n return HumanProfile.fromDict(data);\n }\n\n static loadPreset(name: string): HumanProfile {\n const preset = PRESETS[name];\n if (!preset) {\n throw new Error(`Preset '${name}' not found. Available: ${Object.keys(PRESETS).join(', ')}`);\n }\n return HumanProfile.fromDict(preset as unknown as Record<string, unknown>);\n }\n\n getRange(action: string, phase: 'pre' | 'post'): [number, number] {\n const key = `${phase}_action_ms` as keyof HumanProfileRaw;\n const mapping = this.raw[key] as Record<string, [number, number]> | undefined;\n const pair = mapping?.[action];\n if (Array.isArray(pair) && pair.length === 2) {\n return [pair[0], pair[1]];\n }\n return [0, 0];\n }\n\n typingInterval(): number {\n const wpm = this.raw.typing?.wpm ?? 110;\n return 60_000 / (wpm * 5);\n }\n\n toDict(): HumanProfileRaw {\n return JSON.parse(JSON.stringify(this.raw)) as HumanProfileRaw;\n }\n\n toJSON(indent = 2): string {\n return JSON.stringify(this.raw, null, indent);\n }\n}\n"],"mappings":"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","names":["fs","path","resolve","fs","path","err","resolve","fs","path","err","resolve","fs","resolve","err","resolve","msg"]}
1
+ {"version":3,"sources":["../src/cli.ts","../src/client.ts","../src/config.ts","../src/errors.ts","../src/chat.ts","../src/profile.ts","../src/state.ts","../src/humanize/keymap.ts","../src/browser.ts","../src/humanize/humanizer.ts","../src/humanize/profile.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport { connect } from './client.js';\nimport {\n CekiBrowserError,\n AuthError,\n CaptchaTimeoutError,\n SessionNotFound,\n SessionExpired,\n NotOwner,\n TimeoutError,\n ConnectionLost,\n TransportError,\n} from './errors.js';\nimport { saveSession, loadSession, deleteSession, getLastSeenTs, updateLastSeenTs } from './state.js';\nimport type { ConnectOptions, ChatMessage } from './types.js';\nimport type { Client } from './client.js';\nimport type { Browser } from './browser.js';\n\nfunction out(data: unknown): void {\n process.stdout.write(JSON.stringify(data) + '\\n');\n}\n\nfunction err(error: string, code = 'error'): void {\n process.stderr.write(JSON.stringify({ error, code }) + '\\n');\n}\n\nfunction getApiKey(): string {\n const key = process.env.CEKI_API_KEY;\n if (!key) {\n err('CEKI_API_KEY not set', 'auth');\n process.exit(2);\n }\n return key;\n}\n\nfunction connectOptions(): Partial<ConnectOptions> {\n return { reconnect: false };\n}\n\nasync function resumeBrowser(apiKey: string, sessionId: string): Promise<[Client, Browser]> {\n const client = await connect(apiKey, connectOptions());\n const browser = await client.resume(sessionId, { human: null });\n return [client, browser];\n}\n\nasync function closeClient(client: Client): Promise<void> {\n try { await client.disconnect(); } catch { /* ignore */ }\n}\n\nfunction parseBool(val: string): boolean {\n return val === 'true' || val === '1' || val === 'yes';\n}\n\n// --- Command handlers ---\n\nasync function cmdRent(args: string[]): Promise<void> {\n let scheduleId: number | null = null;\n let fingerprintFrom: string | null = null;\n let mode: 'incognito' | 'main' = 'incognito';\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--schedule' && args[i + 1]) scheduleId = parseInt(args[++i], 10);\n if (args[i] === '--fingerprint-from' && args[i + 1]) fingerprintFrom = args[++i];\n if (args[i] === '--mode' && args[i + 1]) {\n const v = args[++i];\n if (v !== 'incognito' && v !== 'main') {\n err('invalid mode, must be incognito or main', 'args');\n process.exit(1);\n }\n mode = v;\n }\n }\n if (scheduleId == null) {\n err('--schedule is required', 'args');\n process.exit(1);\n }\n\n const apiKey = getApiKey();\n let fpData: boolean | Record<string, unknown> = true;\n if (fingerprintFrom) {\n const profile = JSON.parse(fs.readFileSync(fingerprintFrom, 'utf-8'));\n fpData = profile.fingerprint || true;\n }\n\n const client = await connect(apiKey, connectOptions());\n try {\n const browser = await client.rent(scheduleId, { human: null, fingerprint: fpData, mode });\n saveSession(browser.sessionId, {\n session_id: browser.sessionId,\n chat_topic_id: browser.chatTopicId,\n schedule_id: browser.scheduleId,\n last_seen_ts: null,\n });\n out({\n session_id: browser.sessionId,\n chat_topic_id: browser.chatTopicId,\n schedule_id: browser.scheduleId,\n });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSearch(args: string[]): Promise<void> {\n let limit = 20;\n const filters: Record<string, string> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--limit' && args[i + 1]) limit = parseInt(args[++i], 10);\n if (args[i] === '--filter' && args[i + 1]) {\n const [k, ...v] = args[++i].split('=');\n filters[k] = v.join('=');\n }\n }\n\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.search(filters, limit);\n out(results);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSessions(args: string[]): Promise<void> {\n let showAll = false;\n let limit = 50;\n let jsonOutput = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--all') showAll = true;\n else if (args[i] === '--json') jsonOutput = true;\n else if (args[i] === '--limit' && args[i + 1]) limit = Number(args[++i]);\n }\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.listSessions({ active: !showAll, limit });\n if (jsonOutput) {\n out(results);\n } else {\n if (!results.length) {\n process.stdout.write('No sessions found.\\n');\n return;\n }\n const header = 'SID'.padEnd(8) + 'SCHEDULE'.padEnd(10) + 'STARTED'.padEnd(22) + 'DURATION'.padEnd(10) + 'EARNED'.padEnd(9) + 'STATUS'.padEnd(10) + 'RENTER'.padEnd(16) + 'PROVIDER';\n process.stdout.write(header + '\\n');\n for (const s of results) {\n const started = s.started_at ?? '—';\n const mins = Math.floor(s.duration / 60);\n const secs = s.duration % 60;\n const dur = `${mins}:${String(secs).padStart(2, '0')}`;\n const earned = `$${s.earned.toFixed(2)}`;\n const renter = (s.renter as Record<string, string>)?.name ?? '—';\n const provider = (s.provider as Record<string, string>)?.name ?? '—';\n const line = String(s.id).padEnd(8) + String(s.schedule_id).padEnd(10) + started.padEnd(22) + dur.padEnd(10) + earned.padEnd(9) + s.status.padEnd(10) + renter.padEnd(16) + provider;\n process.stdout.write(line + '\\n');\n }\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdMyBrowsers(): Promise<void> {\n const apiKey = getApiKey();\n const client = await connect(apiKey, connectOptions());\n try {\n const results = await client.myBrowsers();\n out(results);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSnapshot(sid: string, args: string[]): Promise<void> {\n let outputPath: string | null = null;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const lastSeen = getLastSeenTs(sid);\n browser._lastSeenTs = lastSeen;\n const snap = await browser.snapshot();\n const pngBuf = Buffer.from(snap.screenshot, 'base64');\n fs.writeFileSync(outputPath, pngBuf);\n if (browser._lastSeenTs) {\n updateLastSeenTs(sid, browser._lastSeenTs);\n }\n const chatList = snap.chat.map((m: ChatMessage) => ({\n from: m.sender_id,\n text: m.text,\n ts: m.created_at,\n }));\n out({ screenshot: outputPath, chat: chatList, ts: snap.ts.toISOString() });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdNavigate(sid: string, args: string[]): Promise<void> {\n const url = args[0];\n if (!url) {\n err('URL is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.navigate(url);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdClick(sid: string, args: string[]): Promise<void> {\n const x = parseInt(args[0], 10);\n const y = parseInt(args[1], 10);\n if (isNaN(x) || isNaN(y)) {\n err('x and y coordinates are required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.click(x, y);\n out({ ok: true, pointer: [x, y] });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdType(sid: string, args: string[]): Promise<void> {\n let text = '';\n let natural = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--natural') natural = true;\n else if (!text) text = args[i];\n }\n if (!text) {\n err('text is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const human = natural ? 'natural' as const : null;\n const client = await connect(apiKey, connectOptions());\n try {\n const browser = await client.resume(sid, { human });\n if (!natural) {\n browser._humanizer = null;\n }\n await browser.type(text);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdScroll(sid: string, args: string[]): Promise<void> {\n const x = parseInt(args[0], 10);\n const y = parseInt(args[1], 10);\n const dy = parseInt(args[2], 10);\n if (isNaN(x) || isNaN(y) || isNaN(dy)) {\n err('x, y, dy are required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.scroll({ x, y, deltaY: dy });\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdChat(sid: string, action: string, args: string[]): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n switch (action) {\n case 'send': {\n const text = args[0];\n if (!text) {\n err('text is required', 'args');\n process.exit(1);\n }\n const result = await browser.chat.send(text);\n out({ ok: true, message_id: result.messageId });\n break;\n }\n case 'send-image': {\n let imagePath: string | null = null;\n let text: string | undefined;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--image' && args[i + 1]) imagePath = args[++i];\n if (args[i] === '--text' && args[i + 1]) text = args[++i];\n }\n if (!imagePath) {\n err('--image is required', 'args');\n process.exit(1);\n }\n if (text) {\n await browser.chat.send(text);\n }\n const result = await browser.chat.sendImage(imagePath);\n out({ ok: true, message_id: result.messageId });\n break;\n }\n case 'next': {\n let timeout = 60;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--timeout' && args[i + 1]) timeout = parseFloat(args[++i]);\n }\n const lastSeen = getLastSeenTs(sid);\n const msgs = await browser.chat.history({ since: lastSeen ?? undefined });\n if (msgs.length > 0) {\n const m = msgs[0];\n updateLastSeenTs(sid, m.created_at);\n out({ from: m.sender_id, text: m.text, ts: m.created_at });\n } else {\n let resolved = false;\n const waitPromise = new Promise<ChatMessage | null>((resolve) => {\n const timer = setTimeout(() => {\n if (!resolved) {\n resolved = true;\n resolve(null);\n }\n }, timeout * 1000);\n\n browser.chat.onMessage((msg: ChatMessage) => {\n if (!resolved) {\n resolved = true;\n clearTimeout(timer);\n resolve(msg);\n }\n });\n });\n\n const msg = await waitPromise;\n if (msg) {\n updateLastSeenTs(sid, msg.created_at);\n out({ from: msg.sender_id, text: msg.text, ts: msg.created_at });\n } else {\n out(null);\n }\n }\n break;\n }\n case 'history': {\n let since: string | undefined;\n let limit = 50;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--since' && args[i + 1]) {\n const val = args[++i];\n const asNum = Number(val);\n if (!isNaN(asNum) && val.match(/^\\d+(\\.\\d+)?$/)) {\n since = new Date(asNum * 1000).toISOString();\n } else {\n since = val;\n }\n }\n if (args[i] === '--limit' && args[i + 1]) limit = parseInt(args[++i], 10);\n }\n const msgs = await browser.chat.history({ since, limit });\n out(msgs.map((m: ChatMessage) => ({ from: m.sender_id, text: m.text, ts: m.created_at })));\n break;\n }\n default:\n err(`Unknown chat action: ${action}`, 'args');\n process.exit(1);\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdStop(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.close();\n deleteSession(sid);\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdProfile(sid: string, action: string, args: string[]): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n switch (action) {\n case 'export': {\n let outputPath: string | null = null;\n let domains: string[] | undefined;\n let noSessionStorage = false;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n if (args[i] === '--domains' && args[i + 1]) domains = args[++i].split(',').map(d => d.trim());\n if (args[i] === '--no-session-storage') noSessionStorage = true;\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n const profile = await browser.profile.export({\n domains,\n includeSessionStorage: !noSessionStorage,\n });\n fs.writeFileSync(outputPath, JSON.stringify(profile, null, 2), 'utf-8');\n out({ ok: true, path: outputPath });\n break;\n }\n case 'import': {\n let inputPath: string | null = null;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-i' || args[i] === '--input') && args[i + 1]) inputPath = args[++i];\n }\n if (!inputPath) {\n err('-i/--input is required', 'args');\n process.exit(1);\n }\n const profileData = JSON.parse(fs.readFileSync(inputPath, 'utf-8'));\n await browser.profile.import(profileData);\n out({ ok: true });\n break;\n }\n default:\n err(`Unknown profile action: ${action}`, 'args');\n process.exit(1);\n }\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdWait(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const reason = await browser.waitUntilEnded();\n out({ ended: true, reason });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdScreenshot(sid: string, args: string[]): Promise<void> {\n let outputPath: string | null = null;\n let fullPage = false;\n for (let i = 0; i < args.length; i++) {\n if ((args[i] === '-o' || args[i] === '--output') && args[i + 1]) outputPath = args[++i];\n if (args[i] === '--full') fullPage = true;\n }\n if (!outputPath) {\n err('-o/--output is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const data = await browser.screenshot({ format: 'png', fullPage });\n fs.writeFileSync(outputPath, data as Buffer);\n out({ ok: true, path: outputPath });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdSwitchTab(sid: string): Promise<void> {\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.switchTab();\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdConfigure(sid: string, args: string[]): Promise<void> {\n const opts: Record<string, unknown> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--masking-mode' && args[i + 1]) opts.maskingMode = parseBool(args[++i]);\n if (args[i] === '--fingerprint' && args[i + 1]) opts.fingerprint = parseBool(args[++i]);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n await browser.configure(opts as { maskingMode?: boolean; fingerprint?: boolean });\n out({ ok: true });\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdCdp(sid: string, args: string[]): Promise<void> {\n let method: string | null = null;\n let params: Record<string, unknown> = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--method' && args[i + 1]) method = args[++i];\n if (args[i] === '--params' && args[i + 1]) params = JSON.parse(args[++i]);\n }\n if (!method) {\n err('--method is required', 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.send({ method, params });\n out(result);\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdRequestCaptcha(sid: string, args: string[]): Promise<void> {\n let acceptance = 60;\n let completion = 120;\n let manual = false;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--acceptance' && args[i + 1]) acceptance = parseFloat(args[++i]);\n if (args[i] === '--completion' && args[i + 1]) completion = parseFloat(args[++i]);\n if (args[i] === '--manual') manual = true;\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.requestCaptcha({\n acceptanceTimeout: acceptance,\n completionTimeout: completion,\n autoAccept: !manual,\n });\n out({\n solved: result.solved,\n proof_message_id: result.proofMessageId,\n cancel_reason: result.cancelReason,\n child_event_id: result.childEventId,\n correction_id: result.correctionId,\n });\n if (!result.solved) process.exit(1);\n } catch (e) {\n if (e instanceof CaptchaTimeoutError) {\n out({ solved: false, cancel_reason: `timeout:${e.phase}`, child_event_id: null, correction_id: null });\n process.exit(1);\n }\n throw e;\n } finally {\n await closeClient(client);\n }\n}\n\nasync function cmdUpload(sid: string, args: string[]): Promise<void> {\n let selector: string | null = null;\n let filePath: string | null = null;\n let filename: string | undefined;\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--selector' && args[i + 1]) selector = args[++i];\n if (args[i] === '--file' && args[i + 1]) filePath = args[++i];\n if (args[i] === '--filename' && args[i + 1]) filename = args[++i];\n }\n if (!selector || !filePath) {\n err('--selector and --file are required', 'args');\n process.exit(1);\n }\n if (!fs.existsSync(filePath)) {\n err(`File not found: ${filePath}`, 'args');\n process.exit(1);\n }\n const apiKey = getApiKey();\n const [client, browser] = await resumeBrowser(apiKey, sid);\n try {\n const result = await browser.upload(selector, filePath, filename);\n out(result);\n } finally {\n await closeClient(client);\n }\n}\n\n// --- Help ---\n\nfunction printHelp(): void {\n console.log(`ceki — CLI for browser.ceki.me rental\n\nUsage: ceki <command> [options]\n\nCommands:\n rent --schedule N [--fingerprint-from PATH]\n my-browsers\n search [--limit N] [--filter k=v]...\n snapshot <sid> -o PATH\n screenshot <sid> -o PATH [--full]\n navigate <sid> <url>\n click <sid> <x> <y>\n type <sid> \"<text>\" [--natural]\n scroll <sid> <x> <y> <dy>\n switch-tab <sid>\n configure <sid> [--masking-mode true|false] [--fingerprint true|false]\n cdp <sid> --method <M> [--params JSON]\n upload <sid> --selector CSS --file PATH [--filename NAME]\n request-captcha <sid> [--acceptance N] [--completion M] [--manual]\n wait <sid>\n chat <sid> send \"<text>\"\n chat <sid> send-image --image PATH [--text \"...\"]\n chat <sid> next [--timeout N]\n chat <sid> history [--since TS] [--limit N]\n profile export <sid> -o file [--domains a,b,c] [--no-session-storage]\n profile import <sid> -i file\n stop <sid>\n\nEnvironment:\n CEKI_API_KEY (required)\n CEKI_RELAY_URL (default: wss://browser.ceki.me/ws/agent)\n CEKI_API_URL (default: https://api.ceki.me)\n CEKI_CHAT_URL (default: https://chat.ceki.me/api/chat)\n CEKI_BASIC_AUTH_USER / CEKI_BASIC_AUTH_PASS (optional)\n\nExit codes: 0=success, 1=error, 2=auth, 3=session_not_found, 4=timeout, 5=network`);\n}\n\n// --- Main ---\n\nasync function main(): Promise<void> {\n const argv = process.argv.slice(2);\n\n if (argv.length === 0 || argv[0] === '--help' || argv[0] === '-h') {\n printHelp();\n process.exit(0);\n }\n\n if (argv[0] === '--version' || argv[0] === '-v') {\n const pkgPath = path.resolve(path.dirname(new URL(import.meta.url).pathname), '..', 'package.json');\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));\n console.log(pkg.version);\n } catch {\n console.log('unknown');\n }\n process.exit(0);\n }\n\n const command = argv[0];\n const rest = argv.slice(1);\n\n switch (command) {\n case 'rent':\n await cmdRent(rest);\n break;\n case 'search':\n await cmdSearch(rest);\n break;\n case 'sessions':\n await cmdSessions(rest);\n break;\n case 'my-browsers':\n await cmdMyBrowsers();\n break;\n case 'snapshot':\n await cmdSnapshot(rest[0], rest.slice(1));\n break;\n case 'navigate':\n await cmdNavigate(rest[0], rest.slice(1));\n break;\n case 'click':\n await cmdClick(rest[0], rest.slice(1));\n break;\n case 'type':\n await cmdType(rest[0], rest.slice(1));\n break;\n case 'scroll':\n await cmdScroll(rest[0], rest.slice(1));\n break;\n case 'switch-tab':\n await cmdSwitchTab(rest[0]);\n break;\n case 'configure':\n await cmdConfigure(rest[0], rest.slice(1));\n break;\n case 'cdp':\n await cmdCdp(rest[0], rest.slice(1));\n break;\n case 'upload':\n await cmdUpload(rest[0], rest.slice(1));\n break;\n case 'request-captcha':\n await cmdRequestCaptcha(rest[0], rest.slice(1));\n break;\n case 'wait':\n await cmdWait(rest[0]);\n break;\n case 'stop':\n await cmdStop(rest[0]);\n break;\n case 'screenshot':\n await cmdScreenshot(rest[0], rest.slice(1));\n break;\n case 'chat':\n if (rest.length < 2) {\n err('Usage: ceki chat <sid> <action> [args]', 'args');\n process.exit(1);\n }\n await cmdChat(rest[0], rest[1], rest.slice(2));\n break;\n case 'profile':\n if (rest.length < 2) {\n err('Usage: ceki profile export|import <sid> [args]', 'args');\n process.exit(1);\n }\n await cmdProfile(rest[1], rest[0], rest.slice(2));\n break;\n default:\n err(`Unknown command: ${command}`, 'args');\n process.exit(1);\n }\n}\n\nmain().catch((e: unknown) => {\n if (e instanceof SessionExpired || e instanceof SessionNotFound) {\n err(String(e), 'session_not_found');\n process.exit(3);\n }\n if (e instanceof NotOwner) {\n err(String(e), 'not_owner');\n process.exit(3);\n }\n if (e instanceof TimeoutError) {\n err(String(e), 'timeout');\n process.exit(4);\n }\n if (e instanceof ConnectionLost || e instanceof AuthError || e instanceof TransportError) {\n err(String(e), 'network');\n process.exit(5);\n }\n if (e instanceof CekiBrowserError) {\n err(String(e), 'ceki_error');\n process.exit(1);\n }\n err(e instanceof Error ? e.message : String(e), 'error');\n process.exit(1);\n});\n","import WebSocket from 'ws';\nimport { resolveConfig } from './config.js';\nimport {\n CekiBrowserError,\n AuthError,\n SessionNotFound,\n SessionExpired,\n NotOwner,\n TimeoutError,\n SessionEnded,\n InsufficientFunds,\n RateLimitExceeded,\n ConnectionLost,\n ProviderOffline,\n CdpUnrecoverable,\n TransportError,\n} from './errors.js';\nimport { Browser } from './browser.js';\nimport { Humanizer } from './humanize/humanizer.js';\nimport { HumanProfile } from './humanize/profile.js';\nimport type { ConnectOptions, BrowserOption, Match, RentOptions, SessionInfo } from './types.js';\n\nconst BACKOFF_SCHEDULE = [1, 2, 4, 8, 16, 32, 60];\nconst MAX_RECONNECT_ATTEMPTS = 10;\nconst PING_INTERVAL = 30000;\nconst PONG_TIMEOUT = 90000;\n\ninterface PendingRent {\n scheduleId: number;\n eventId: string | null;\n resolve: (match: Match) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n opts?: RentOptions;\n}\n\ninterface PendingResume {\n sessionId: string;\n resolve: (match: Match) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n opts?: RentOptions;\n}\n\nexport class Client {\n /** @internal */ _apiKey: string;\n /** @internal */ _chatUrl: string;\n /** @internal */ _basicAuth: [string, string] | undefined;\n /** @internal */ _activeBrowsers: Map<string, Browser> = new Map();\n\n private _ws: WebSocket | null = null;\n /** @internal */ _apiUrl: string;\n private _relayUrl: string;\n private _reconnect: boolean;\n private _reconnectAttempt = 0;\n private _reconnecting = false;\n private _closed = false;\n\n private _pingTimer: ReturnType<typeof setInterval> | null = null;\n private _pongTimer: ReturnType<typeof setTimeout> | null = null;\n private _lastPongAt = 0;\n\n private _pendingRents: Map<string, PendingRent> = new Map(); // keyed by `rent:<scheduleId>` or eventId\n private _pendingResumes: Map<string, PendingResume> = new Map(); // keyed by sessionId\n\n private _connectResolve: (() => void) | null = null;\n private _connectReject: ((err: Error) => void) | null = null;\n\n constructor(apiKey: string, opts?: Partial<ConnectOptions>) {\n const cfg = resolveConfig(opts);\n this._apiKey = apiKey;\n this._apiUrl = cfg.apiUrl;\n this._relayUrl = cfg.relayUrl;\n this._chatUrl = cfg.chatUrl;\n this._basicAuth = cfg.basicAuth;\n this._reconnect = cfg.reconnect;\n }\n\n /** Factory: create client and connect */\n static async create(apiKey: string, opts?: Partial<ConnectOptions>): Promise<Client> {\n const client = new Client(apiKey, opts);\n await client._connect();\n return client;\n }\n\n /** @internal */\n _wsSend(msg: Record<string, unknown>): void {\n if (!this._ws || this._ws.readyState !== WebSocket.OPEN) {\n throw new ConnectionLost('WebSocket not connected');\n }\n this._ws.send(JSON.stringify(msg));\n }\n\n async search(\n filters?: Record<string, unknown>,\n limit?: number,\n ): Promise<BrowserOption[]> {\n const params = new URLSearchParams();\n if (limit != null) params.set('limit', String(limit));\n if (filters) {\n for (const [key, value] of Object.entries(filters)) {\n if (value != null) params.set(key, String(value));\n }\n }\n\n const url = `${this._apiUrl}/api/browsers/search?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`Search request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const data = (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(data) ? data : []) as BrowserOption[];\n }\n\n async listSessions(opts?: { active?: boolean; limit?: number }): Promise<SessionInfo[]> {\n const active = opts?.active ?? true;\n const limit = opts?.limit ?? 50;\n const params = new URLSearchParams({\n active: active ? '1' : '0',\n limit: String(limit),\n });\n const url = `${this._apiUrl}/api/agent/sessions?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`listSessions request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const items = (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(items) ? items : []) as SessionInfo[];\n }\n\n async myBrowsers(): Promise<BrowserOption[]> {\n const url = `${this._apiUrl}/api/agent/browsers`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n };\n if (this._basicAuth) {\n const encoded = Buffer.from(`${this._basicAuth[0]}:${this._basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new TransportError(`myBrowsers request failed: ${resp.status} ${resp.statusText}`);\n }\n const body = await resp.json();\n const items = (body as Record<string, unknown>).browsers ?? (body as Record<string, unknown>).data ?? body;\n return (Array.isArray(items) ? items : []) as BrowserOption[];\n }\n\n async rent(scheduleId: number, opts?: RentOptions): Promise<Browser> {\n const rentMsg: Record<string, unknown> = { type: 'rent', browser_id: scheduleId };\n if (opts?.mode) rentMsg.mode = opts.mode;\n this._wsSend(rentMsg);\n\n const key = `rent:${scheduleId}`;\n\n return new Promise<Browser>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingRents.delete(key);\n reject(new TimeoutError('Rent timed out after 90s'));\n }, 90000);\n\n this._pendingRents.set(key, {\n scheduleId,\n eventId: null,\n opts,\n resolve: (match: Match) => {\n const humanizer = this._resolveHumanizer(opts);\n const browser = new Browser(this, match, humanizer);\n this._activeBrowsers.set(browser.sessionId, browser);\n if (opts?.maskingMode) {\n browser.configure({ maskingMode: true }).catch(() => {});\n }\n if (opts?.fingerprint) {\n browser.configure({ fingerprint: opts.fingerprint }).catch(() => {});\n }\n resolve(browser);\n },\n reject,\n timer,\n });\n });\n }\n\n async resume(sessionId: string, opts?: RentOptions): Promise<Browser> {\n this._wsSend({ type: 'resume', session_id: sessionId });\n\n return new Promise<Browser>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingResumes.delete(sessionId);\n reject(new TimeoutError('Resume timed out after 10s'));\n }, 10000);\n\n this._pendingResumes.set(sessionId, {\n sessionId,\n opts,\n resolve: (match: Match) => {\n const humanizer = this._resolveHumanizer(opts);\n const browser = new Browser(this, match, humanizer);\n this._activeBrowsers.set(browser.sessionId, browser);\n resolve(browser);\n },\n reject,\n timer,\n });\n });\n }\n\n async close(): Promise<void> {\n this._closed = true;\n\n // Close all active browsers\n const closePromises: Promise<void>[] = [];\n for (const browser of this._activeBrowsers.values()) {\n closePromises.push(browser.close().catch(() => {}));\n }\n await Promise.allSettled(closePromises);\n\n // Reject pending rents\n for (const [key, pending] of this._pendingRents) {\n clearTimeout(pending.timer);\n pending.reject(new Error('Client closed'));\n }\n this._pendingRents.clear();\n\n // Reject pending resumes\n for (const [key, pending] of this._pendingResumes) {\n clearTimeout(pending.timer);\n pending.reject(new Error('Client closed'));\n }\n this._pendingResumes.clear();\n\n this._stopHeartbeat();\n this._closeWs();\n }\n\n async disconnect(): Promise<void> {\n this._closed = true;\n this._activeBrowsers.clear();\n this._pendingRents.clear();\n this._pendingResumes.clear();\n this._stopHeartbeat();\n this._closeWs();\n }\n\n // --- Private methods ---\n\n private async _connect(): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n this._connectResolve = resolve;\n this._connectReject = reject;\n this._openWs();\n });\n }\n\n private _openWs(): void {\n const protocols = [`bearer.${this._apiKey}`];\n this._ws = new WebSocket(this._relayUrl, protocols);\n\n this._ws.on('open', () => {\n this._reconnectAttempt = 0;\n this._reconnecting = false;\n this._lastPongAt = Date.now();\n this._startHeartbeat();\n\n if (this._connectResolve) {\n this._connectResolve();\n this._connectResolve = null;\n this._connectReject = null;\n }\n });\n\n this._ws.on('message', (data: WebSocket.Data) => {\n this._handleMessage(data);\n });\n\n this._ws.on('close', (code: number, reason: Buffer) => {\n this._stopHeartbeat();\n const reasonStr = reason.toString();\n\n if (code === 4401 || code === 4403) {\n const err = new AuthError(reasonStr || `Auth failed (${code})`);\n if (this._connectReject) {\n this._connectReject(err);\n this._connectResolve = null;\n this._connectReject = null;\n }\n return;\n }\n\n if (!this._closed && this._reconnect) {\n this._scheduleReconnect();\n }\n });\n\n this._ws.on('error', (err: Error) => {\n if (this._connectReject) {\n this._connectReject(new TransportError(err.message));\n this._connectResolve = null;\n this._connectReject = null;\n }\n });\n }\n\n private _closeWs(): void {\n if (this._ws) {\n try {\n this._ws.removeAllListeners();\n this._ws.close();\n } catch {\n // ignore close errors\n }\n this._ws = null;\n }\n }\n\n private _scheduleReconnect(): void {\n if (this._closed || this._reconnecting) return;\n if (this._reconnectAttempt >= MAX_RECONNECT_ATTEMPTS) {\n // Reject all pending operations\n const err = new ConnectionLost('Max reconnection attempts exceeded');\n this._rejectAllPending(err);\n return;\n }\n\n this._reconnecting = true;\n const backoffIdx = Math.min(this._reconnectAttempt, BACKOFF_SCHEDULE.length - 1);\n const delay = BACKOFF_SCHEDULE[backoffIdx] * 1000;\n this._reconnectAttempt++;\n\n setTimeout(() => {\n if (this._closed) return;\n this._closeWs();\n this._connectResolve = () => {\n // After reconnect, resume all active browsers\n for (const browser of this._activeBrowsers.values()) {\n this._wsSend({ type: 'resume', session_id: browser.sessionId });\n }\n };\n this._connectReject = () => {\n // Reconnect failed, try again\n this._reconnecting = false;\n this._scheduleReconnect();\n };\n this._openWs();\n }, delay);\n }\n\n private _startHeartbeat(): void {\n this._stopHeartbeat();\n this._pingTimer = setInterval(() => {\n try {\n this._wsSend({ type: 'ping' });\n } catch {\n // If send fails, WS close handler will trigger reconnect\n }\n }, PING_INTERVAL);\n\n this._pongTimer = setTimeout(() => {\n this._checkPongTimeout();\n }, PONG_TIMEOUT);\n }\n\n private _stopHeartbeat(): void {\n if (this._pingTimer) {\n clearInterval(this._pingTimer);\n this._pingTimer = null;\n }\n if (this._pongTimer) {\n clearTimeout(this._pongTimer);\n this._pongTimer = null;\n }\n }\n\n private _checkPongTimeout(): void {\n if (this._closed) return;\n const elapsed = Date.now() - this._lastPongAt;\n if (elapsed >= PONG_TIMEOUT) {\n // Heartbeat timeout — close and reconnect\n this._closeWs();\n if (this._reconnect) {\n this._scheduleReconnect();\n }\n } else {\n // Schedule next check\n this._pongTimer = setTimeout(() => {\n this._checkPongTimeout();\n }, PONG_TIMEOUT - elapsed);\n }\n }\n\n private _handleMessage(data: WebSocket.Data): void {\n let msg: Record<string, unknown>;\n try {\n msg = JSON.parse(data.toString()) as Record<string, unknown>;\n } catch {\n return;\n }\n\n const type = String(msg.type ?? '');\n const sessionId = msg.session_id ? String(msg.session_id) : null;\n\n switch (type) {\n case 'pong':\n this._lastPongAt = Date.now();\n break;\n\n case 'rent_pending':\n this._onRentPending(msg);\n break;\n\n case 'match':\n this._onMatch(msg);\n break;\n\n case 'rent.error':\n this._onRentError(msg);\n break;\n\n case 'resume_ok':\n this._onResumeOk(msg);\n break;\n\n case 'resume_failed':\n this._onResumeFailed(msg);\n break;\n\n case 'cdp_response':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onCdpResponse(msg);\n }\n break;\n\n case 'cdp_event':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onCdpEvent(msg);\n }\n break;\n\n case 'tab_opened':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onTabOpened(msg);\n }\n break;\n\n case 'session.ended':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onSessionEnded(msg);\n }\n break;\n\n case 'session.provider_disconnected':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onProviderDisconnected();\n }\n break;\n\n case 'session.provider_reconnected':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onProviderReconnected();\n }\n break;\n\n case 'user_events':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onUserEvents(msg);\n }\n break;\n\n case 'chat.message':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatMessage((msg.payload ?? msg) as Record<string, unknown>);\n }\n break;\n\n case 'chat.read':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatRead((msg.payload ?? msg) as Record<string, unknown>);\n }\n break;\n\n case 'chat.send_ack':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatSendAck(msg);\n }\n break;\n\n case 'chat.error':\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n browser?._onChatSendError(msg);\n }\n break;\n\n case 'error':\n this._onError(msg);\n break;\n }\n }\n\n private _onRentPending(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n // Update pending rent with eventId for matching\n for (const [key, pending] of this._pendingRents) {\n if (!pending.eventId) {\n pending.eventId = eventId;\n // Re-key by eventId for faster lookup on match\n this._pendingRents.delete(key);\n this._pendingRents.set(`event:${eventId}`, pending);\n break;\n }\n }\n }\n\n private _onMatch(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n const scheduleId = Number(msg.schedule_id ?? 0);\n const sessionId = String(msg.session_id ?? '');\n\n if (msg.requires_ack) {\n try { this._wsSend({ type: 'match_ack', session_id: sessionId }); } catch { /* ignore */ }\n }\n\n // Try eventId match first\n let pending = this._pendingRents.get(`event:${eventId}`);\n if (!pending) {\n // Fallback to scheduleId match\n pending = this._pendingRents.get(`rent:${scheduleId}`);\n }\n\n if (pending) {\n clearTimeout(pending.timer);\n const key = pending.eventId ? `event:${pending.eventId}` : `rent:${pending.scheduleId}`;\n this._pendingRents.delete(key);\n\n const match: Match = {\n session_id: sessionId,\n schedule_id: scheduleId,\n event_id: eventId || null,\n chat_topic_id: msg.chat_topic_id ? String(msg.chat_topic_id) : null,\n provider_user_id: msg.provider_user_id != null ? Number(msg.provider_user_id) : null,\n started_at: Date.now(),\n browser_info: (msg.browser_info as Record<string, unknown>) ?? {},\n };\n\n pending.resolve(match);\n }\n }\n\n private _onRentError(msg: Record<string, unknown>): void {\n const eventId = String(msg.event_id ?? '');\n const code = String(msg.code ?? '');\n const message = String(msg.message ?? '');\n\n let pending = this._pendingRents.get(`event:${eventId}`);\n if (!pending) {\n // Try to find any pending rent\n for (const [key, p] of this._pendingRents) {\n pending = p;\n this._pendingRents.delete(key);\n break;\n }\n } else {\n this._pendingRents.delete(`event:${eventId}`);\n }\n\n if (pending) {\n clearTimeout(pending.timer);\n if (code === 'provider_offline') {\n pending.reject(new ProviderOffline(message));\n } else {\n pending.reject(new TransportError(message || `Rent error: ${code}`));\n }\n }\n }\n\n private _onResumeOk(msg: Record<string, unknown>): void {\n const sessionId = String(msg.session_id ?? '');\n const pending = this._pendingResumes.get(sessionId);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingResumes.delete(sessionId);\n\n const match: Match = {\n session_id: sessionId,\n event_id: msg.event_id != null ? String(msg.event_id) : null,\n schedule_id: Number(msg.schedule_id ?? 0),\n chat_topic_id: msg.chat_topic_id ? String(msg.chat_topic_id) : null,\n provider_user_id: msg.provider_user_id != null ? Number(msg.provider_user_id) : null,\n started_at: Date.now(),\n browser_info: (msg.browser_info as Record<string, unknown>) ?? {},\n };\n\n pending.resolve(match);\n }\n\n private _onResumeFailed(msg: Record<string, unknown>): void {\n const sessionId = String(msg.session_id ?? '');\n const reason = String(msg.reason ?? '');\n const pending = this._pendingResumes.get(sessionId);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingResumes.delete(sessionId);\n\n switch (reason) {\n case 'expired':\n pending.reject(new SessionExpired());\n break;\n case 'not_owner':\n pending.reject(new NotOwner());\n break;\n case 'not_found':\n pending.reject(new SessionNotFound());\n break;\n default:\n pending.reject(new SessionNotFound(reason));\n }\n }\n\n private _onError(msg: Record<string, unknown>): void {\n const code = Number(msg.code ?? 0);\n const reason = String(msg.reason ?? msg.message ?? '');\n const sessionId = msg.session_id ? String(msg.session_id) : null;\n\n // Route session-specific errors to browser\n if (sessionId) {\n const browser = this._activeBrowsers.get(sessionId);\n if (browser) {\n switch (code) {\n case -1011: // heartbeat timeout\n browser._onSessionEnded({ reason: 'heartbeat_timeout' });\n return;\n case -1012:\n browser._onError({ reason: 'insufficient_funds' });\n return;\n case -1013:\n browser._onError({ reason: 'rate_limit_exceeded' });\n return;\n case -1015: // provider_declined\n browser._onSessionEnded({ reason: 'provider_declined' });\n return;\n case -1018: // killed\n browser._onSessionEnded({ reason: 'killed' });\n return;\n case -1050:\n browser._onError({ reason: `cdp_unrecoverable: ${reason}` });\n return;\n default:\n browser._onError(msg);\n return;\n }\n }\n }\n\n // Global errors — reject pending operations\n let err: CekiBrowserError;\n switch (code) {\n case -1012:\n err = new InsufficientFunds(reason);\n this._rejectAllPending(err);\n break;\n case -1013:\n err = new RateLimitExceeded(0, reason);\n this._rejectAllPending(err);\n break;\n case -1015:\n err = new ProviderOffline(reason);\n this._rejectFirstPendingRent(err);\n break;\n default:\n err = new CekiBrowserError(reason || `relay error ${code}`);\n this._rejectFirstPendingRent(err);\n break;\n }\n }\n\n private _rejectFirstPendingRent(err: Error): void {\n const eventId = this._pendingRents.keys().next().value;\n if (eventId != null) {\n const pending = this._pendingRents.get(eventId)!;\n clearTimeout(pending.timer);\n this._pendingRents.delete(eventId);\n pending.reject(err);\n }\n }\n\n private _rejectAllPending(err: Error): void {\n for (const [key, pending] of this._pendingRents) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingRents.clear();\n\n for (const [key, pending] of this._pendingResumes) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingResumes.clear();\n }\n\n private _resolveHumanizer(opts?: RentOptions): Humanizer | null {\n if (process.env.CEKI_HUMAN_DISABLE === '1') return null;\n const human = opts?.human;\n if (human === null || human === undefined) {\n const envPreset = process.env.CEKI_HUMAN_PROFILE;\n const envPath = process.env.CEKI_HUMAN_PROFILE_PATH;\n if (envPath) return new Humanizer(HumanProfile.load(envPath));\n if (envPreset) return new Humanizer(HumanProfile.loadPreset(envPreset));\n return new Humanizer(HumanProfile.loadPreset('natural'));\n }\n if (human === 'natural' || human === 'careful') {\n return new Humanizer(HumanProfile.loadPreset(human));\n }\n return null;\n }\n}\n\n/** Factory function: create a connected Client */\nexport async function connect(apiKey: string, opts?: Partial<ConnectOptions>): Promise<Client> {\n return Client.create(apiKey, opts);\n}\n","import type { ConnectOptions } from './types.js';\n\nexport const defaults = {\n apiUrl: 'https://api.ceki.me',\n relayUrl: 'wss://browser.ceki.me/ws/agent',\n chatUrl: 'https://chat.ceki.me/api/chat',\n};\n\nexport function resolveConfig(opts?: Partial<ConnectOptions>) {\n return {\n apiUrl: opts?.apiUrl ?? process.env.CEKI_API_URL ?? defaults.apiUrl,\n relayUrl: opts?.relayUrl ?? process.env.CEKI_RELAY_URL ?? defaults.relayUrl,\n chatUrl: opts?.chatUrl ?? process.env.CEKI_CHAT_URL ?? defaults.chatUrl,\n basicAuth: opts?.basicAuth ?? (process.env.CEKI_BASIC_AUTH_USER && process.env.CEKI_BASIC_AUTH_PASS\n ? [process.env.CEKI_BASIC_AUTH_USER, process.env.CEKI_BASIC_AUTH_PASS] as [string, string]\n : undefined),\n reconnect: opts?.reconnect ?? true,\n };\n}\n","export class CekiBrowserError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'CekiBrowserError';\n }\n}\n\nexport class AuthError extends CekiBrowserError {\n constructor(message = 'Authentication failed') {\n super(message);\n this.name = 'AuthError';\n }\n}\n\nexport class SessionNotFound extends CekiBrowserError {\n constructor(message = 'Session not found') {\n super(message);\n this.name = 'SessionNotFound';\n }\n}\n\nexport class SessionExpired extends SessionNotFound {\n constructor(message = 'Session expired') {\n super(message);\n this.name = 'SessionExpired';\n }\n}\n\nexport class NotOwner extends CekiBrowserError {\n constructor(message = 'Not session owner') {\n super(message);\n this.name = 'NotOwner';\n }\n}\n\nexport class TransportError extends CekiBrowserError {\n constructor(message = 'Transport error') {\n super(message);\n this.name = 'TransportError';\n }\n}\n\nexport class TimeoutError extends CekiBrowserError {\n constructor(message = 'Operation timed out') {\n super(message);\n this.name = 'TimeoutError';\n }\n}\n\nexport class SessionEnded extends CekiBrowserError {\n reason: string;\n constructor(reason: string) {\n super(`Session ended: ${reason}`);\n this.name = 'SessionEnded';\n this.reason = reason;\n }\n}\n\nexport class InsufficientFunds extends CekiBrowserError {\n constructor(message = 'Insufficient funds') {\n super(message);\n this.name = 'InsufficientFunds';\n }\n}\n\nexport class RateLimitExceeded extends CekiBrowserError {\n retryAfter: number;\n constructor(retryAfter = 0, message = 'Rate limit exceeded') {\n super(message);\n this.name = 'RateLimitExceeded';\n this.retryAfter = retryAfter;\n }\n}\n\nexport class ConnectionLost extends CekiBrowserError {\n constructor(message = 'Connection lost') {\n super(message);\n this.name = 'ConnectionLost';\n }\n}\n\nexport class ProviderOffline extends CekiBrowserError {\n constructor(message = 'Provider offline') {\n super(message);\n this.name = 'ProviderOffline';\n }\n}\n\nexport class ProviderDisconnected extends CekiBrowserError {\n constructor(message = 'Provider disconnected') {\n super(message);\n this.name = 'ProviderDisconnected';\n }\n}\n\nexport class CdpUnrecoverable extends CekiBrowserError {\n lastError: string;\n constructor(lastError: string) {\n super(`CDP unrecoverable: ${lastError}`);\n this.name = 'CdpUnrecoverable';\n this.lastError = lastError;\n }\n}\n\nexport class CaptchaError extends CekiBrowserError {\n constructor(message = 'Captcha error') {\n super(message);\n this.name = 'CaptchaError';\n }\n}\n\nexport class CaptchaTimeoutError extends CaptchaError {\n phase: 'acceptance' | 'completion';\n constructor(phase: 'acceptance' | 'completion') {\n super(`Captcha timeout: ${phase}`);\n this.name = 'CaptchaTimeoutError';\n this.phase = phase;\n }\n}\n\nexport class ChatSendFailed extends CekiBrowserError {\n status: number;\n messageText: string;\n constructor(status: number, messageText: string) {\n super(`Chat send failed (${status})`);\n this.name = 'ChatSendFailed';\n this.status = status;\n this.messageText = messageText;\n }\n}\n","import * as crypto from 'node:crypto';\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport { TimeoutError, ChatSendFailed } from './errors.js';\nimport type { ChatMessage, ReadReceipt, ChatHistoryOptions } from './types.js';\nimport type { Browser } from './browser.js';\n\ntype MessageHandler = (msg: ChatMessage) => void | Promise<void>;\ntype ReadHandler = (receipt: ReadReceipt) => void | Promise<void>;\n\ninterface PendingSend {\n resolve: (value: { messageId: string; sentAt: string }) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n}\n\nconst MAX_IMAGE_SIZE = 5 * 1024 * 1024; // 5MB\n\nfunction detectMime(buf: Buffer): { mime: string; ext: string } {\n if (buf.length >= 4 && buf[0] === 0x89 && buf[1] === 0x50 && buf[2] === 0x4e && buf[3] === 0x47) {\n return { mime: 'image/png', ext: 'png' };\n }\n if (buf.length >= 3 && buf[0] === 0xff && buf[1] === 0xd8 && buf[2] === 0xff) {\n return { mime: 'image/jpeg', ext: 'jpg' };\n }\n if (buf.length >= 12 && buf[0] === 0x52 && buf[1] === 0x49 && buf[2] === 0x46 && buf[3] === 0x46\n && buf[8] === 0x57 && buf[9] === 0x45 && buf[10] === 0x42 && buf[11] === 0x50) {\n return { mime: 'image/webp', ext: 'webp' };\n }\n return { mime: 'application/octet-stream', ext: 'bin' };\n}\n\nfunction randomHex(len: number): string {\n return crypto.randomBytes(len / 2).toString('hex');\n}\n\nexport class BrowserChat {\n private _browser: Browser;\n private _topicId: string | null;\n private _messageHandlers: MessageHandler[] = [];\n private _readHandlers: ReadHandler[] = [];\n private _pendingSends: Map<string, PendingSend> = new Map();\n /** @internal */ _actionCallbacks: Map<number, (action: Record<string, unknown>) => void> = new Map();\n\n constructor(browser: Browser) {\n this._browser = browser;\n this._topicId = browser.chatTopicId;\n }\n\n get topicId(): string | null {\n return this._topicId;\n }\n\n async send(text: string): Promise<{ messageId: string; sentAt: string }> {\n const clientMsgId = randomHex(32);\n const msg = {\n type: 'chat.send' as const,\n session_id: this._browser.sessionId,\n client_msg_id: clientMsgId,\n text,\n };\n\n return new Promise<{ messageId: string; sentAt: string }>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingSends.delete(clientMsgId);\n reject(new TimeoutError('Chat send timed out'));\n }, 15000);\n this._pendingSends.set(clientMsgId, { resolve, reject, timer });\n this._browser._sendRaw(msg);\n });\n }\n\n async sendImage(source: string | Buffer, text?: string): Promise<{ messageId: string; sentAt: string }> {\n let buf: Buffer;\n let filename: string;\n\n if (typeof source === 'string') {\n buf = fs.readFileSync(source);\n filename = path.basename(source);\n } else {\n buf = Buffer.isBuffer(source) ? source : Buffer.from(source);\n filename = 'image';\n }\n\n if (buf.length > MAX_IMAGE_SIZE) {\n throw new Error(`Image too large: ${buf.length} bytes (max ${MAX_IMAGE_SIZE})`);\n }\n\n const { mime, ext } = detectMime(buf);\n if (!filename.includes('.')) {\n filename = `${filename}.${ext}`;\n }\n\n const clientMsgId = randomHex(32);\n const data_b64 = buf.toString('base64');\n\n const msg: Record<string, unknown> = {\n type: 'chat.send_image',\n session_id: this._browser.sessionId,\n client_msg_id: clientMsgId,\n filename,\n mime,\n data_b64,\n };\n if (text) msg.text = text;\n\n return new Promise<{ messageId: string; sentAt: string }>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingSends.delete(clientMsgId);\n reject(new TimeoutError('Chat sendImage timed out'));\n }, 15000);\n this._pendingSends.set(clientMsgId, { resolve, reject, timer });\n this._browser._sendRaw(msg);\n });\n }\n\n onMessage(cb: MessageHandler): void {\n this._messageHandlers.push(cb);\n }\n\n onRead(cb: ReadHandler): void {\n this._readHandlers.push(cb);\n }\n\n async history(opts?: ChatHistoryOptions): Promise<ChatMessage[]> {\n if (!this._topicId) return [];\n\n const params = new URLSearchParams();\n params.set('topic_id', this._topicId);\n if (opts?.limit != null) params.set('limit', String(opts.limit));\n if (opts?.beforeId) params.set('before', opts.beforeId);\n if (opts?.since) params.set('since', opts.since);\n\n const url = `${this._browser._chatUrl}/messages?${params.toString()}`;\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._browser._apiKey}`,\n };\n\n const basicAuth = this._browser._basicAuth;\n if (basicAuth) {\n const encoded = Buffer.from(`${basicAuth[0]}:${basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n\n const resp = await fetch(url, { headers });\n if (!resp.ok) {\n throw new Error(`Chat history request failed: ${resp.status} ${resp.statusText}`);\n }\n\n const body = await resp.json() as Record<string, unknown>;\n const messages = (body.messages ?? body.data ?? body) as Record<string, unknown>[];\n if (!Array.isArray(messages)) return [];\n\n return messages.map(parseChatMessage);\n }\n\n /** @internal */\n _onMessage(payload: Record<string, unknown>): void {\n const msgData = (payload.message ?? payload) as Record<string, unknown>;\n if (msgData.type === 'action' && msgData.action) {\n const action = msgData.action as Record<string, unknown>;\n const eventId = Number(action.event_id);\n if (eventId && this._actionCallbacks.has(eventId)) {\n this._actionCallbacks.get(eventId)!(action);\n }\n }\n const msg = parseChatMessage(msgData);\n for (const h of this._messageHandlers) {\n try {\n const result = h(msg);\n if (result && typeof (result as Promise<void>).catch === 'function') {\n (result as Promise<void>).catch(() => {});\n }\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onRead(payload: Record<string, unknown>): void {\n const receipt: ReadReceipt = {\n topic_id: String(payload.topic_id ?? this._topicId ?? ''),\n last_read_message_id: String(payload.last_read_message_id ?? ''),\n read_at: Number(payload.read_at ?? 0),\n };\n for (const h of this._readHandlers) {\n try {\n const result = h(receipt);\n if (result && typeof (result as Promise<void>).catch === 'function') {\n (result as Promise<void>).catch(() => {});\n }\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onSendAck(msg: Record<string, unknown>): void {\n const clientMsgId = String(msg.client_msg_id ?? '');\n const pending = this._pendingSends.get(clientMsgId);\n if (!pending) return;\n clearTimeout(pending.timer);\n this._pendingSends.delete(clientMsgId);\n pending.resolve({\n messageId: String(msg.message_id ?? ''),\n sentAt: String(msg.sent_at ?? ''),\n });\n }\n\n /** @internal */\n _onSendError(msg: Record<string, unknown>): void {\n const clientMsgId = String(msg.client_msg_id ?? '');\n const pending = this._pendingSends.get(clientMsgId);\n if (!pending) return;\n clearTimeout(pending.timer);\n this._pendingSends.delete(clientMsgId);\n pending.reject(new ChatSendFailed(\n Number(msg.status ?? 0),\n String(msg.message ?? ''),\n ));\n }\n}\n\nfunction parseChatMessage(data: Record<string, unknown>): ChatMessage {\n const action = data.action as Record<string, unknown> | undefined;\n return {\n id: String(data.id ?? data._id ?? data.message_id ?? ''),\n topic_id: String(data.topic_id ?? ''),\n sender_id: data.sender_id != null ? Number(data.sender_id) : null,\n text: data.text != null ? String(data.text) : null,\n media: (data.media as Record<string, unknown>[] | null) ?? null,\n type: String(data.type ?? 'text'),\n created_at: String(data.created_at ?? ''),\n edited_at: data.edited_at != null ? String(data.edited_at) : null,\n deleted_at: data.deleted_at != null ? String(data.deleted_at) : null,\n action: action ? {\n kind: String(action.kind ?? ''),\n event_id: Number(action.event_id ?? 0),\n data: (action.data as Record<string, unknown>) ?? undefined,\n } : null,\n };\n}\n","import type { Browser } from './browser.js';\nimport type { Profile, ProfileExportOptions } from './types.js';\n\nexport class BrowserProfile {\n private _browser: Browser;\n\n constructor(browser: Browser) {\n this._browser = browser;\n }\n\n async export(opts?: ProfileExportOptions): Promise<Profile> {\n // 1. Try fingerprint (graceful fail)\n let fingerprint: Record<string, unknown> | null = null;\n try {\n const fpResult = await this._browser.send({ method: 'Browser.getFingerprint' });\n fingerprint = (fpResult as Record<string, unknown>) ?? null;\n } catch {\n fingerprint = null;\n }\n\n // 2. Get cookies\n let cookies: Record<string, unknown>[] = [];\n try {\n const cookieResult = await this._browser.send({ method: 'Network.getCookies' }) as Record<string, unknown>;\n const allCookies = (cookieResult?.cookies ?? []) as Record<string, unknown>[];\n\n if (opts?.domains && opts.domains.length > 0) {\n const domainSet = new Set(opts.domains.map(d => d.toLowerCase()));\n cookies = allCookies.filter(c => {\n const cookieDomain = String(c.domain ?? '').toLowerCase().replace(/^\\./, '');\n return domainSet.has(cookieDomain) || opts!.domains!.some(d =>\n cookieDomain.endsWith('.' + d.toLowerCase()) || cookieDomain === d.toLowerCase()\n );\n });\n } else {\n cookies = allCookies;\n }\n } catch {\n cookies = [];\n }\n\n // 3. Get localStorage\n let localStorage: Record<string, string> = {};\n try {\n const lsResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'JSON.stringify(localStorage)', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = lsResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n localStorage = JSON.parse(String(resultObj.value)) as Record<string, string>;\n }\n } catch {\n localStorage = {};\n }\n\n // 4. Get sessionStorage\n let sessionStorage: Record<string, string> = {};\n if (opts?.includeSessionStorage !== false) {\n try {\n const ssResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'JSON.stringify(sessionStorage)', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = ssResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n sessionStorage = JSON.parse(String(resultObj.value)) as Record<string, string>;\n }\n } catch {\n sessionStorage = {};\n }\n }\n\n // 5. Get origin\n let origin = '';\n try {\n const originResult = await this._browser.send({\n method: 'Runtime.evaluate',\n params: { expression: 'location.origin', returnByValue: true },\n }) as Record<string, unknown>;\n const resultObj = originResult?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n origin = String(resultObj.value);\n }\n } catch {\n origin = '';\n }\n\n return {\n schema_version: 2,\n fingerprint,\n origin,\n cookies,\n localStorage,\n sessionStorage,\n };\n }\n\n async import(profile: Profile): Promise<void> {\n if (profile.schema_version !== 1 && profile.schema_version !== 2) {\n throw new Error(`Unsupported profile schema_version: ${profile.schema_version}`);\n }\n\n // Set cookies\n if (profile.cookies && profile.cookies.length > 0) {\n await this._browser.send({\n method: 'Network.setCookies',\n params: { cookies: profile.cookies },\n });\n }\n\n // Inject localStorage\n if (profile.localStorage && Object.keys(profile.localStorage).length > 0) {\n const entries = JSON.stringify(profile.localStorage);\n await this._browser.send({\n method: 'Runtime.evaluate',\n params: {\n expression: `(function(){var d=${entries};for(var k in d)localStorage.setItem(k,d[k])})()`,\n returnByValue: true,\n },\n });\n }\n\n // Inject sessionStorage\n if (profile.sessionStorage && Object.keys(profile.sessionStorage).length > 0) {\n const entries = JSON.stringify(profile.sessionStorage);\n await this._browser.send({\n method: 'Runtime.evaluate',\n params: {\n expression: `(function(){var d=${entries};for(var k in d)sessionStorage.setItem(k,d[k])})()`,\n returnByValue: true,\n },\n });\n }\n }\n}\n","import * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport * as os from 'node:os';\n\nconst STATE_DIR = path.join(os.homedir(), '.ceki', 'sessions');\n\nfunction statePath(sid: string): string {\n return path.join(STATE_DIR, `${sid}.json`);\n}\n\nexport function loadSession(sid: string): Record<string, unknown> | null {\n try {\n const raw = fs.readFileSync(statePath(sid), 'utf-8');\n return JSON.parse(raw) as Record<string, unknown>;\n } catch {\n return null;\n }\n}\n\nexport function saveSession(sid: string, data: Record<string, unknown>): void {\n fs.mkdirSync(STATE_DIR, { recursive: true });\n const payload = { ...data, updated_at: new Date().toISOString() };\n fs.writeFileSync(statePath(sid), JSON.stringify(payload, null, 2), 'utf-8');\n}\n\nexport function deleteSession(sid: string): void {\n try {\n fs.unlinkSync(statePath(sid));\n } catch (err: unknown) {\n if ((err as NodeJS.ErrnoException).code !== 'ENOENT') throw err;\n }\n}\n\nexport function getLastSeenTs(sid: string): string | null {\n const data = loadSession(sid);\n if (!data) return null;\n return (data.last_seen_ts as string) ?? null;\n}\n\nexport function updateLastSeenTs(sid: string, ts: string): void {\n const data = loadSession(sid) ?? {};\n data.last_seen_ts = ts;\n saveSession(sid, data);\n}\n","export interface KeyMapping {\n code: string;\n key: string;\n vk: number;\n needsShift: boolean;\n}\n\nconst STATIC_MAP: Record<string, KeyMapping> = {\n ' ': { code: 'Space', key: ' ', vk: 32, needsShift: false },\n '\\n': { code: 'Enter', key: 'Enter', vk: 13, needsShift: false },\n '\\t': { code: 'Tab', key: 'Tab', vk: 9, needsShift: false },\n\n // Shifted digits\n '!': { code: 'Digit1', key: '!', vk: 49, needsShift: true },\n '@': { code: 'Digit2', key: '@', vk: 50, needsShift: true },\n '#': { code: 'Digit3', key: '#', vk: 51, needsShift: true },\n '$': { code: 'Digit4', key: '$', vk: 52, needsShift: true },\n '%': { code: 'Digit5', key: '%', vk: 53, needsShift: true },\n '^': { code: 'Digit6', key: '^', vk: 54, needsShift: true },\n '&': { code: 'Digit7', key: '&', vk: 55, needsShift: true },\n '*': { code: 'Digit8', key: '*', vk: 56, needsShift: true },\n '(': { code: 'Digit9', key: '(', vk: 57, needsShift: true },\n ')': { code: 'Digit0', key: ')', vk: 48, needsShift: true },\n\n // Punctuation (unshifted)\n '-': { code: 'Minus', key: '-', vk: 189, needsShift: false },\n '=': { code: 'Equal', key: '=', vk: 187, needsShift: false },\n '[': { code: 'BracketLeft', key: '[', vk: 219, needsShift: false },\n ']': { code: 'BracketRight', key: ']', vk: 221, needsShift: false },\n '\\\\': { code: 'Backslash', key: '\\\\', vk: 220, needsShift: false },\n ';': { code: 'Semicolon', key: ';', vk: 186, needsShift: false },\n \"'\": { code: 'Quote', key: \"'\", vk: 222, needsShift: false },\n ',': { code: 'Comma', key: ',', vk: 188, needsShift: false },\n '.': { code: 'Period', key: '.', vk: 190, needsShift: false },\n '/': { code: 'Slash', key: '/', vk: 191, needsShift: false },\n '`': { code: 'Backquote', key: '`', vk: 192, needsShift: false },\n\n // Punctuation (shifted)\n '_': { code: 'Minus', key: '_', vk: 189, needsShift: true },\n '+': { code: 'Equal', key: '+', vk: 187, needsShift: true },\n '{': { code: 'BracketLeft', key: '{', vk: 219, needsShift: true },\n '}': { code: 'BracketRight', key: '}', vk: 221, needsShift: true },\n '|': { code: 'Backslash', key: '|', vk: 220, needsShift: true },\n ':': { code: 'Semicolon', key: ':', vk: 186, needsShift: true },\n '\"': { code: 'Quote', key: '\"', vk: 222, needsShift: true },\n '<': { code: 'Comma', key: '<', vk: 188, needsShift: true },\n '>': { code: 'Period', key: '>', vk: 190, needsShift: true },\n '?': { code: 'Slash', key: '?', vk: 191, needsShift: true },\n '~': { code: 'Backquote', key: '~', vk: 192, needsShift: true },\n};\n\nexport function keymapForChar(char: string): KeyMapping | null {\n // a-z\n if (char >= 'a' && char <= 'z') {\n const upper = char.toUpperCase();\n return {\n code: `Key${upper}`,\n key: char,\n vk: upper.charCodeAt(0),\n needsShift: false,\n };\n }\n\n // A-Z\n if (char >= 'A' && char <= 'Z') {\n return {\n code: `Key${char}`,\n key: char,\n vk: char.charCodeAt(0),\n needsShift: true,\n };\n }\n\n // 0-9\n if (char >= '0' && char <= '9') {\n return {\n code: `Digit${char}`,\n key: char,\n vk: char.charCodeAt(0),\n needsShift: false,\n };\n }\n\n // Static map\n const mapping = STATIC_MAP[char];\n if (mapping) return mapping;\n\n // Non-ASCII or unknown — fallback\n return null;\n}\n","import { TimeoutError, SessionEnded, CaptchaError, CaptchaTimeoutError } from './errors.js';\nimport { BrowserChat } from './chat.js';\nimport { BrowserProfile } from './profile.js';\nimport { saveSession, getLastSeenTs, updateLastSeenTs } from './state.js';\nimport type { Match, ScreenshotOptions, ScrollOptions, Snapshot, ChatMessage, CaptchaOptions, CaptchaResult } from './types.js';\nimport type { Client } from './client.js';\n\nimport { Humanizer } from './humanize/humanizer.js';\nimport { HumanProfile } from './humanize/profile.js';\nimport { keymapForChar } from './humanize/keymap.js';\nexport type { Humanizer, HumanProfile };\n\ninterface PendingCdp {\n resolve: (value: unknown) => void;\n reject: (err: Error) => void;\n timer: ReturnType<typeof setTimeout>;\n}\n\ntype EventHandler = (method: string, params: Record<string, unknown>) => void;\ntype TabHandler = (url: string) => void;\ntype VoidHandler = () => void;\ntype UserEventHandler = (events: Record<string, unknown>[]) => void;\n\nexport class Browser {\n readonly sessionId: string;\n readonly browserId: number;\n readonly scheduleId: number;\n readonly chatTopicId: string | null;\n readonly browserInfo: Record<string, unknown>;\n readonly providerUserId: number | null;\n /** @internal */ _eventId: string | null;\n\n readonly chat: BrowserChat;\n readonly profile: BrowserProfile;\n\n /** @internal */ _client: Client;\n /** @internal */ _humanizer: Humanizer | null = null;\n /** @internal */ _lastPointer: [number, number] | null = null;\n /** @internal */ _lastSeenTs: string | null = null;\n /** @internal */ _cdpCounter = 1;\n /** @internal */ _pendingCdp: Map<number, PendingCdp> = new Map();\n /** @internal */ _ended: Promise<string>;\n /** @internal */ _endedReason: string | null = null;\n /** @internal */ _resolveEnded!: (reason: string) => void;\n\n private _eventHandlers: EventHandler[] = [];\n private _tabHandlers: TabHandler[] = [];\n private _disconnectHandlers: VoidHandler[] = [];\n private _reconnectHandlers: VoidHandler[] = [];\n private _userEventHandlers: UserEventHandler[] = [];\n\n /** @internal */\n get _apiKey(): string {\n return this._client._apiKey;\n }\n\n /** @internal */\n get _chatUrl(): string {\n return this._client._chatUrl;\n }\n\n /** @internal */\n get _basicAuth(): [string, string] | undefined {\n return this._client._basicAuth;\n }\n\n constructor(client: Client, match: Match, humanizer?: Humanizer | null) {\n this._client = client;\n this.sessionId = match.session_id;\n this.browserId = match.schedule_id;\n this.scheduleId = match.schedule_id;\n this.chatTopicId = match.chat_topic_id ?? null;\n this.browserInfo = match.browser_info ?? {};\n this.providerUserId = match.provider_user_id ?? null;\n this._eventId = match.event_id ?? null;\n this._humanizer = humanizer ?? null;\n\n this.chat = new BrowserChat(this);\n this.profile = new BrowserProfile(this);\n\n this._ended = new Promise<string>((resolve) => {\n this._resolveEnded = resolve;\n });\n\n // Load last_seen_ts from state\n this._lastSeenTs = getLastSeenTs(this.sessionId);\n\n // Save session state\n saveSession(this.sessionId, {\n session_id: this.sessionId,\n chat_topic_id: this.chatTopicId,\n schedule_id: this.scheduleId,\n last_seen_ts: this._lastSeenTs,\n });\n }\n\n /** @internal — send raw message via client WS */\n _sendRaw(msg: Record<string, unknown>): void {\n this._client._wsSend(msg);\n }\n\n async send(\n cdp: { method: string; params?: Record<string, unknown> },\n timeout = 30000,\n ): Promise<unknown> {\n if (this._endedReason) {\n throw new SessionEnded(this._endedReason);\n }\n\n const id = this._cdpCounter++;\n const msg = {\n type: 'cdp' as const,\n session_id: this.sessionId,\n id,\n method: cdp.method,\n params: cdp.params ?? {},\n };\n\n return new Promise<unknown>((resolve, reject) => {\n const timer = setTimeout(() => {\n this._pendingCdp.delete(id);\n reject(new TimeoutError(`CDP ${cdp.method} timed out after ${timeout}ms`));\n }, timeout);\n this._pendingCdp.set(id, { resolve, reject, timer });\n this._sendRaw(msg);\n });\n }\n\n async navigate(url: string, timeout = 30000): Promise<{ url: string; frameId?: string }> {\n if (this._humanizer) await this._humanizer.before('navigate');\n const result = await this.send({ method: 'Page.navigate', params: { url } }, timeout) as Record<string, unknown>;\n if (this._humanizer) await this._humanizer.after('navigate');\n return {\n url: String(result?.url ?? url),\n frameId: result?.frameId ? String(result.frameId) : undefined,\n };\n }\n\n async click(x: number, y: number): Promise<void> {\n if (this._humanizer) await this._humanizer.before('click');\n\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mousePressed', x, y, button: 'left', clickCount: 1 },\n });\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseReleased', x, y, button: 'left', clickCount: 1 },\n });\n\n this._lastPointer = [x, y];\n\n if (this._humanizer) await this._humanizer.after('click');\n }\n\n private async _sendKeystroke(char: string): Promise<void> {\n const mapping = keymapForChar(char);\n if (!mapping) {\n await this.send({ method: 'Input.insertText', params: { text: char } });\n return;\n }\n const { code, key, vk, needsShift } = mapping;\n if (needsShift) {\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: { type: 'keyDown', key: 'Shift', code: 'ShiftLeft', windowsVirtualKeyCode: 16, nativeVirtualKeyCode: 16 },\n });\n }\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: {\n type: 'keyDown', key, code, text: char,\n unmodifiedText: needsShift ? char.toLowerCase() : char,\n windowsVirtualKeyCode: vk, nativeVirtualKeyCode: vk,\n ...(needsShift ? { modifiers: 8 } : {}),\n },\n });\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: {\n type: 'keyUp', key, code,\n windowsVirtualKeyCode: vk, nativeVirtualKeyCode: vk,\n ...(needsShift ? { modifiers: 8 } : {}),\n },\n });\n if (needsShift) {\n await this.send({\n method: 'Input.dispatchKeyEvent',\n params: { type: 'keyUp', key: 'Shift', code: 'ShiftLeft', windowsVirtualKeyCode: 16, nativeVirtualKeyCode: 16 },\n });\n }\n }\n\n async type(text: string): Promise<void> {\n if (this._humanizer) {\n await this._humanizer.before('type');\n\n // Re-click last pointer position to focus\n if (this._lastPointer) {\n const [px, py] = this._lastPointer;\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mousePressed', x: px, y: py, button: 'left', clickCount: 1 },\n });\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseReleased', x: px, y: py, button: 'left', clickCount: 1 },\n });\n }\n\n // Type char-by-char with delays\n for (const char of text) {\n await this._sendKeystroke(char);\n const delay = this._humanizer.typeDelay();\n if (delay > 0) {\n await new Promise<void>(r => setTimeout(r, delay));\n }\n }\n\n await this._humanizer.after('type');\n } else {\n for (const char of text) {\n await this._sendKeystroke(char);\n }\n }\n }\n\n async scroll(opts?: ScrollOptions): Promise<void> {\n const x = opts?.x ?? 0;\n const y = opts?.y ?? 0;\n const deltaX = opts?.deltaX ?? 0;\n const deltaY = opts?.deltaY ?? -300;\n\n if (this._humanizer) await this._humanizer.before('scroll');\n\n await this.send({\n method: 'Input.dispatchMouseEvent',\n params: { type: 'mouseWheel', x, y, deltaX, deltaY },\n });\n\n this._lastPointer = [x, y];\n\n if (this._humanizer) await this._humanizer.after('scroll');\n }\n\n async screenshot(opts?: ScreenshotOptions): Promise<{ data: string } | Buffer> {\n const format = opts?.format ?? 'base64';\n const fullPage = opts?.fullPage ?? false;\n\n let clip: Record<string, unknown> | undefined;\n\n if (fullPage) {\n const metrics = await this.send({ method: 'Page.getLayoutMetrics' }) as Record<string, unknown>;\n const contentSize = metrics?.contentSize as Record<string, unknown> | undefined;\n if (contentSize) {\n const width = Number(contentSize.width ?? 1920);\n const height = Math.min(Number(contentSize.height ?? 1080), 16384);\n clip = { x: 0, y: 0, width, height, scale: 1 };\n }\n }\n\n const params: Record<string, unknown> = { format: 'png' };\n if (clip) params.clip = clip;\n\n const result = await this.send({ method: 'Page.captureScreenshot', params }) as Record<string, unknown>;\n const data = String(result?.data ?? '');\n\n if (format === 'png') {\n return Buffer.from(data, 'base64');\n }\n\n return { data };\n }\n\n async snapshot(): Promise<Snapshot> {\n const [ssResult, chatMessages] = await Promise.all([\n this.screenshot({ format: 'base64' }),\n this.chat.history({ since: this._lastSeenTs ?? undefined }),\n ]);\n\n const screenshotData = (ssResult as { data: string }).data;\n\n if (chatMessages.length > 0) {\n const lastMsg = chatMessages[chatMessages.length - 1];\n this._lastSeenTs = lastMsg.created_at;\n updateLastSeenTs(this.sessionId, this._lastSeenTs);\n }\n\n return {\n screenshot: screenshotData,\n chat: chatMessages,\n ts: new Date(),\n };\n }\n\n async upload(\n selector: string,\n source: string | Buffer,\n filename?: string,\n ): Promise<{ ok: boolean; filename: string; size: number }> {\n let buf: Buffer;\n let resolvedFilename: string;\n\n if (typeof source === 'string') {\n const fs = await import('node:fs');\n const path = await import('node:path');\n buf = fs.readFileSync(source);\n resolvedFilename = filename ?? path.basename(source);\n } else {\n buf = Buffer.isBuffer(source) ? source : Buffer.from(source);\n resolvedFilename = filename ?? 'file';\n }\n\n const b64 = buf.toString('base64');\n const size = buf.length;\n\n // Inject file via Runtime.evaluate + DataTransfer + File API\n const expression = `\n (function() {\n var input = document.querySelector(${JSON.stringify(selector)});\n if (!input) return JSON.stringify({ok: false, error: 'Element not found'});\n var b64 = ${JSON.stringify(b64)};\n var binary = atob(b64);\n var bytes = new Uint8Array(binary.length);\n for (var i = 0; i < binary.length; i++) bytes[i] = binary.charCodeAt(i);\n var file = new File([bytes], ${JSON.stringify(resolvedFilename)}, {type: 'application/octet-stream'});\n var dt = new DataTransfer();\n dt.items.add(file);\n input.files = dt.files;\n input.dispatchEvent(new Event('change', {bubbles: true}));\n return JSON.stringify({ok: true, filename: ${JSON.stringify(resolvedFilename)}, size: ${size}});\n })()\n `.trim();\n\n const result = await this.send({\n method: 'Runtime.evaluate',\n params: { expression, returnByValue: true },\n }) as Record<string, unknown>;\n\n const resultObj = result?.result as Record<string, unknown> | undefined;\n if (resultObj?.value) {\n return JSON.parse(String(resultObj.value)) as { ok: boolean; filename: string; size: number };\n }\n return { ok: true, filename: resolvedFilename, size };\n }\n\n async switchTab(): Promise<void> {\n this._sendRaw({ type: 'switch_tab', session_id: this.sessionId });\n }\n\n async configure(opts: { maskingMode?: boolean; fingerprint?: boolean | Record<string, unknown> }): Promise<void> {\n const msg: Record<string, unknown> = {\n type: 'session.configure',\n session_id: this.sessionId,\n };\n if (opts.maskingMode !== undefined) msg.masking_mode = opts.maskingMode;\n if (opts.fingerprint !== undefined) msg.fingerprint = opts.fingerprint;\n this._sendRaw(msg);\n }\n\n async close(timeout = 10000): Promise<void> {\n if (this._endedReason) return;\n\n this._sendRaw({\n type: 'session.end',\n session_id: this.sessionId,\n reason: 'user_stop',\n });\n\n await Promise.race([\n this._ended,\n new Promise<void>((_, reject) =>\n setTimeout(() => reject(new TimeoutError('Close timed out')), timeout)\n ),\n ]).catch(() => {\n // If timed out, force cleanup\n });\n\n this._cleanup();\n }\n\n async release(timeout?: number): Promise<void> {\n return this.close(timeout);\n }\n\n async waitUntilEnded(): Promise<string> {\n return this._ended;\n }\n\n onEvent(cb: EventHandler): void {\n this._eventHandlers.push(cb);\n }\n\n onTabOpened(cb: TabHandler): void {\n this._tabHandlers.push(cb);\n }\n\n onProviderDisconnected(cb: VoidHandler): void {\n this._disconnectHandlers.push(cb);\n }\n\n onProviderReconnected(cb: VoidHandler): void {\n this._reconnectHandlers.push(cb);\n }\n\n onUserEvent(cb: UserEventHandler): void {\n this._userEventHandlers.push(cb);\n }\n\n // --- Captcha / human action ---\n\n private _apiHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Authorization': `Bearer ${this._apiKey}`,\n 'Content-Type': 'application/json',\n };\n const basicAuth = this._basicAuth;\n if (basicAuth) {\n const encoded = Buffer.from(`${basicAuth[0]}:${basicAuth[1]}`).toString('base64');\n headers['X-Basic-Auth'] = `Basic ${encoded}`;\n }\n return headers;\n }\n\n async requestCaptcha(opts?: CaptchaOptions): Promise<CaptchaResult> {\n let acceptanceTimeout = opts?.acceptanceTimeout ?? 60;\n let completionTimeout = opts?.completionTimeout ?? 120;\n const autoAccept = opts?.autoAccept ?? true;\n\n if (acceptanceTimeout < 30) throw new Error('acceptanceTimeout must be >= 30 seconds');\n if (completionTimeout < 30) throw new Error('completionTimeout must be >= 30 seconds');\n\n acceptanceTimeout = Math.min(acceptanceTimeout, 300);\n completionTimeout = Math.min(completionTimeout, 600);\n\n const { id: childEventId } = await this._createCaptchaEvent(acceptanceTimeout, completionTimeout);\n const completionDeadline = Date.now() + completionTimeout * 1000;\n\n const buffer: Record<string, unknown>[] = [];\n let waiter: ((action: Record<string, unknown>) => void) | null = null;\n\n this.chat._actionCallbacks.set(childEventId, (action) => {\n if (waiter) {\n const w = waiter;\n waiter = null;\n w(action);\n } else {\n buffer.push(action);\n }\n });\n\n const nextAction = (timeoutMs: number): Promise<Record<string, unknown>> => {\n if (buffer.length > 0) return Promise.resolve(buffer.shift()!);\n return new Promise<Record<string, unknown>>((resolve, reject) => {\n const timer = setTimeout(() => {\n waiter = null;\n reject(new Error('timeout'));\n }, timeoutMs);\n waiter = (action) => {\n clearTimeout(timer);\n resolve(action);\n };\n });\n };\n\n const cleanup = () => {\n this.chat._actionCallbacks.delete(childEventId);\n waiter = null;\n };\n\n const makeResult = async (\n data: Record<string, unknown>,\n solved: boolean,\n ): Promise<CaptchaResult> => {\n const correctionId = data.correction_id != null ? Number(data.correction_id) : null;\n const proofMessageId = data.proof_message_id != null ? String(data.proof_message_id) : null;\n let voted = false;\n\n const result: CaptchaResult = {\n solved,\n proofMessageId,\n cancelReason: null,\n childEventId,\n correctionId,\n acceptWork: async () => {\n if (voted) return;\n if (!correctionId) throw new CaptchaError('no correction_id — provider has not proposed completion');\n voted = true;\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}/vote`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify({ ids: [correctionId], vote: true }),\n });\n },\n rejectWork: async (reason?: string) => {\n if (voted) return;\n if (!correctionId) throw new CaptchaError('no correction_id — provider has not proposed completion');\n voted = true;\n const body: Record<string, unknown> = { ids: [correctionId], vote: false };\n if (reason) body.reason = reason;\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}/vote`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify(body),\n });\n },\n };\n\n if (autoAccept && solved && correctionId) {\n await new Promise<void>(r => setTimeout(r, 2000));\n await result.acceptWork();\n }\n\n return result;\n };\n\n let accepted = false;\n\n try {\n // Phase 1: wait for acceptance\n const acceptDeadline = Date.now() + acceptanceTimeout * 1000;\n while (true) {\n const remaining = acceptDeadline - Date.now();\n if (remaining <= 0) throw new Error('timeout');\n const action = await nextAction(remaining);\n const kind = String(action.kind ?? '');\n const data = (action.data ?? {}) as Record<string, unknown>;\n\n if (kind === 'human_action_accepted') {\n accepted = true;\n break;\n }\n if (kind === 'human_action_completed') {\n cleanup();\n return await makeResult(data, true);\n }\n if (kind === 'human_action_failed' || kind === 'human_action_declined' || kind === 'human_action_withdrew') {\n cleanup();\n return {\n solved: false,\n proofMessageId: null,\n cancelReason: kind.replace('human_action_', ''),\n childEventId,\n correctionId: null,\n acceptWork: async () => {},\n rejectWork: async () => {},\n };\n }\n }\n\n // Phase 2: wait for completion\n while (true) {\n const remaining = completionDeadline - Date.now();\n if (remaining <= 0) throw new Error('timeout');\n const action = await nextAction(remaining);\n const kind = String(action.kind ?? '');\n const data = (action.data ?? {}) as Record<string, unknown>;\n\n if (kind === 'human_action_completed') {\n cleanup();\n return await makeResult(data, true);\n }\n if (kind === 'human_action_failed' || kind === 'human_action_withdrew') {\n cleanup();\n return {\n solved: false,\n proofMessageId: null,\n cancelReason: kind.replace('human_action_', ''),\n childEventId,\n correctionId: null,\n acceptWork: async () => {},\n rejectWork: async () => {},\n };\n }\n }\n } catch {\n cleanup();\n const phase = accepted ? 'completion' : 'acceptance';\n await this._expireCaptchaEvent(childEventId);\n throw new CaptchaTimeoutError(phase);\n }\n }\n\n private async _createCaptchaEvent(acceptanceTimeout: number, completionTimeout: number): Promise<{ id: number; amount: number }> {\n const body = {\n acceptance_deadline_at: Math.floor(acceptanceTimeout),\n completion_deadline_at: Math.floor(completionTimeout),\n };\n\n const resp = await fetch(`${this._client._apiUrl}/api/agent/sessions/${this._eventId}/captcha-request`, {\n method: 'POST',\n headers: this._apiHeaders(),\n body: JSON.stringify(body),\n });\n if (!resp.ok) {\n throw new Error(`Captcha request failed: ${resp.status}`);\n }\n const result = await resp.json() as { id: number; amount: number };\n if (!result.id) throw new Error('Captcha request did not return an id');\n return { id: result.id, amount: result.amount };\n }\n\n private async _expireCaptchaEvent(childEventId: number): Promise<void> {\n try {\n await fetch(`${this._client._apiUrl}/api/agent/kal/event/${childEventId}`, {\n method: 'PATCH',\n headers: this._apiHeaders(),\n body: JSON.stringify({ status_id: 777 }),\n });\n } catch { /* best effort */ }\n }\n\n // --- Internal handlers called by Client dispatch ---\n\n /** @internal */\n _onCdpResponse(msg: Record<string, unknown>): void {\n const id = Number(msg.id);\n const pending = this._pendingCdp.get(id);\n if (!pending) return;\n\n clearTimeout(pending.timer);\n this._pendingCdp.delete(id);\n\n if (msg.ok === false) {\n const error = msg.error as Record<string, unknown> | undefined;\n pending.reject(new Error(String(error?.message ?? error?.code ?? 'CDP error')));\n } else {\n pending.resolve(msg.result ?? null);\n }\n }\n\n /** @internal */\n _onCdpEvent(msg: Record<string, unknown>): void {\n const method = String(msg.method ?? '');\n const params = (msg.params ?? {}) as Record<string, unknown>;\n for (const h of this._eventHandlers) {\n try {\n h(method, params);\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onTabOpened(msg: Record<string, unknown>): void {\n const url = String(msg.url ?? '');\n for (const h of this._tabHandlers) {\n try {\n h(url);\n } catch {\n // handler errors should not break dispatch\n }\n }\n }\n\n /** @internal */\n _onSessionEnded(msg: Record<string, unknown>): void {\n const reason = String(msg.reason ?? 'unknown');\n this._endedReason = reason;\n this._resolveEnded(reason);\n this._rejectAllPending(new SessionEnded(reason));\n this._cleanup();\n }\n\n /** @internal */\n _onProviderDisconnected(): void {\n for (const h of this._disconnectHandlers) {\n try { h(); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onProviderReconnected(): void {\n for (const h of this._reconnectHandlers) {\n try { h(); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onError(msg: Record<string, unknown>): void {\n const reason = String(msg.reason ?? msg.message ?? 'unknown error');\n this._endedReason = reason;\n this._resolveEnded(reason);\n this._rejectAllPending(new SessionEnded(reason));\n this._cleanup();\n }\n\n /** @internal */\n _onUserEvents(msg: Record<string, unknown>): void {\n const events = (msg.events ?? []) as Record<string, unknown>[];\n for (const h of this._userEventHandlers) {\n try { h(events); } catch { /* ignore */ }\n }\n }\n\n /** @internal */\n _onChatMessage(payload: Record<string, unknown>): void {\n this.chat._onMessage(payload);\n }\n\n /** @internal */\n _onChatRead(payload: Record<string, unknown>): void {\n this.chat._onRead(payload);\n }\n\n /** @internal */\n _onChatSendAck(msg: Record<string, unknown>): void {\n this.chat._onSendAck(msg);\n }\n\n /** @internal */\n _onChatSendError(msg: Record<string, unknown>): void {\n this.chat._onSendError(msg);\n }\n\n private _rejectAllPending(err: Error): void {\n for (const [id, pending] of this._pendingCdp) {\n clearTimeout(pending.timer);\n pending.reject(err);\n }\n this._pendingCdp.clear();\n }\n\n private _cleanup(): void {\n this._client._activeBrowsers.delete(this.sessionId);\n }\n}\n","import { HumanProfile } from './profile.js';\n\nfunction seededRandom(seed: number | null): () => number {\n if (seed === null || seed === undefined) {\n return Math.random;\n }\n let s = seed;\n return () => {\n s = (s * 1664525 + 1013904223) & 0xffffffff;\n return (s >>> 0) / 0xffffffff;\n };\n}\n\nfunction gaussianRandom(rng: () => number, mean: number, sigma: number): number {\n let u1: number, u2: number;\n do { u1 = rng(); } while (u1 === 0);\n u2 = rng();\n const z = Math.sqrt(-2.0 * Math.log(u1)) * Math.cos(2.0 * Math.PI * u2);\n return mean + z * sigma;\n}\n\nexport class Humanizer {\n readonly profile: HumanProfile;\n private _rng: () => number;\n\n constructor(profile: HumanProfile) {\n this.profile = profile;\n this._rng = seededRandom(profile.raw.rng_seed ?? null);\n }\n\n async before(action: string): Promise<void> {\n const [lo, hi] = this.profile.getRange(action, 'pre');\n if (lo === 0 && hi === 0) return;\n const delay = lo + this._rng() * (hi - lo);\n await sleep(delay);\n }\n\n async after(action: string): Promise<void> {\n const [lo, hi] = this.profile.getRange(action, 'post');\n if (lo === 0 && hi === 0) return;\n const delay = lo + this._rng() * (hi - lo);\n await sleep(delay);\n }\n\n typeDelay(): number {\n const typing = this.profile.raw.typing ?? {};\n const wpm = typing.wpm ?? 110;\n const jitter = typing.jitter ?? 0.35;\n const thinkProb = typing.thinking_pause_prob ?? 0;\n const thinkMs = typing.thinking_pause_ms ?? [300, 1200];\n\n const meanInterval = 60_000 / (wpm * 5);\n const sigma = meanInterval * jitter;\n\n let delay = gaussianRandom(this._rng, meanInterval, sigma);\n delay = Math.max(delay, 20);\n\n if (thinkProb > 0 && this._rng() < thinkProb) {\n delay += thinkMs[0] + this._rng() * (thinkMs[1] - thinkMs[0]);\n }\n\n return delay;\n }\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(resolve => setTimeout(resolve, ms));\n}\n","import * as fs from 'node:fs';\n\nexport interface HumanProfileRaw {\n version?: number;\n name?: string;\n typing?: {\n wpm?: number;\n jitter?: number;\n thinking_pause_prob?: number;\n thinking_pause_ms?: [number, number];\n typo_prob?: number;\n };\n pre_action_ms?: Record<string, [number, number]>;\n post_action_ms?: Record<string, [number, number]>;\n mouse?: {\n move_before_click?: boolean;\n trajectory?: string;\n };\n rng_seed?: number | null;\n}\n\nconst PRESETS: Record<string, HumanProfileRaw> = {\n natural: {\n version: 1,\n name: 'natural',\n typing: { wpm: 110, jitter: 0.35, thinking_pause_prob: 0.012, thinking_pause_ms: [300, 1200], typo_prob: 0.0 },\n pre_action_ms: { click: [80, 350], type: [120, 500], scroll: [50, 250], navigate: [0, 0], screenshot: [0, 0] },\n post_action_ms: { click: [150, 800], type: [150, 800], scroll: [200, 900], navigate: [400, 1800], screenshot: [0, 0] },\n mouse: { move_before_click: false, trajectory: 'off' },\n rng_seed: null,\n },\n careful: {\n version: 1,\n name: 'careful',\n typing: { wpm: 80, jitter: 0.4, thinking_pause_prob: 0.025, thinking_pause_ms: [400, 1800], typo_prob: 0.0 },\n pre_action_ms: { click: [200, 600], type: [250, 800], scroll: [100, 400], navigate: [0, 0], screenshot: [0, 0] },\n post_action_ms: { click: [400, 1500], type: [300, 1200], scroll: [300, 1200], navigate: [800, 3000], screenshot: [0, 0] },\n mouse: { move_before_click: false, trajectory: 'off' },\n rng_seed: null,\n },\n};\n\nconst DEFAULTS: HumanProfileRaw = {\n version: 1,\n name: 'custom',\n typing: {\n wpm: 110,\n jitter: 0.35,\n thinking_pause_prob: 0.012,\n thinking_pause_ms: [300, 1200],\n typo_prob: 0.0,\n },\n pre_action_ms: {\n click: [80, 350],\n type: [120, 500],\n scroll: [50, 250],\n navigate: [0, 0],\n screenshot: [0, 0],\n },\n post_action_ms: {\n click: [150, 800],\n type: [150, 800],\n scroll: [200, 900],\n navigate: [400, 1800],\n screenshot: [0, 0],\n },\n mouse: {\n move_before_click: false,\n trajectory: 'off',\n },\n rng_seed: null,\n};\n\nfunction deepMerge(base: Record<string, unknown>, override: Record<string, unknown>): Record<string, unknown> {\n const result: Record<string, unknown> = { ...base };\n for (const [key, value] of Object.entries(override)) {\n if (\n key in result &&\n typeof result[key] === 'object' &&\n result[key] !== null &&\n !Array.isArray(result[key]) &&\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value)\n ) {\n result[key] = deepMerge(\n result[key] as Record<string, unknown>,\n value as Record<string, unknown>,\n );\n } else {\n result[key] = value;\n }\n }\n return result;\n}\n\nexport class HumanProfile {\n readonly name: string;\n readonly raw: HumanProfileRaw;\n\n constructor(name: string, raw: HumanProfileRaw) {\n this.name = name;\n this.raw = raw;\n }\n\n static fromDict(d: Record<string, unknown>): HumanProfile {\n const merged = deepMerge(\n DEFAULTS as unknown as Record<string, unknown>,\n d,\n ) as HumanProfileRaw;\n const name = (d.name as string) ?? 'custom';\n merged.name = name;\n return new HumanProfile(name, merged);\n }\n\n static load(filePath: string): HumanProfile {\n const raw = fs.readFileSync(filePath, 'utf-8');\n const data = JSON.parse(raw) as Record<string, unknown>;\n return HumanProfile.fromDict(data);\n }\n\n static loadPreset(name: string): HumanProfile {\n const preset = PRESETS[name];\n if (!preset) {\n throw new Error(`Preset '${name}' not found. Available: ${Object.keys(PRESETS).join(', ')}`);\n }\n return HumanProfile.fromDict(preset as unknown as Record<string, unknown>);\n }\n\n getRange(action: string, phase: 'pre' | 'post'): [number, number] {\n const key = `${phase}_action_ms` as keyof HumanProfileRaw;\n const mapping = this.raw[key] as Record<string, [number, number]> | undefined;\n const pair = mapping?.[action];\n if (Array.isArray(pair) && pair.length === 2) {\n return [pair[0], pair[1]];\n }\n return [0, 0];\n }\n\n typingInterval(): number {\n const wpm = this.raw.typing?.wpm ?? 110;\n return 60_000 / (wpm * 5);\n }\n\n toDict(): HumanProfileRaw {\n return JSON.parse(JSON.stringify(this.raw)) as HumanProfileRaw;\n }\n\n toJSON(indent = 2): string {\n return JSON.stringify(this.raw, null, indent);\n }\n}\n"],"mappings":"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","names":["fs","path","resolve","fs","path","err","resolve","fs","path","err","resolve","fs","resolve","err","resolve","msg"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ceki/sdk",
3
- "version": "1.9.0",
3
+ "version": "1.9.2",
4
4
  "description": "TypeScript SDK for browser.ceki.me — rent real browsers of real people",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -15,13 +15,22 @@
15
15
  }
16
16
  },
17
17
  "bin": {
18
- "ceki": "./dist/cli.js"
18
+ "ceki": "dist/cli.js"
19
19
  },
20
- "files": ["dist"],
21
- "keywords": ["browser", "automation", "websocket", "rpc", "ai-agent", "ceki"],
20
+ "files": [
21
+ "dist"
22
+ ],
23
+ "keywords": [
24
+ "browser",
25
+ "automation",
26
+ "websocket",
27
+ "rpc",
28
+ "ai-agent",
29
+ "ceki"
30
+ ],
22
31
  "repository": {
23
32
  "type": "git",
24
- "url": "https://github.com/Ceki-me/js-sdk"
33
+ "url": "git+https://github.com/Ceki-me/js-sdk.git"
25
34
  },
26
35
  "homepage": "https://browser.ceki.me",
27
36
  "author": "Ceki.me <hello@ceki.me>",