nothing-browser 0.1.1 → 0.1.3

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.
@@ -1,35 +0,0 @@
1
- // piggy/captcha/index.d.ts
2
- import { PiggyClient } from "../client";
3
-
4
- export interface CaptchaState {
5
- detected: boolean;
6
- paused: boolean;
7
- type: string;
8
- }
9
-
10
- export interface BlockState {
11
- detected: boolean;
12
- type: string;
13
- }
14
-
15
- export declare class CaptchaClient {
16
- constructor(client: PiggyClient);
17
-
18
- status(tabId?: string): Promise<CaptchaState>;
19
- resolve(tabId?: string): Promise<void>;
20
- pause(tabId?: string): Promise<void>;
21
- check(tabId?: string): Promise<void>;
22
- setAutoRetry(enabled: boolean): Promise<void>;
23
-
24
- blockStatus(tabId?: string): Promise<BlockState>;
25
- blockRetry(tabId?: string): Promise<void>;
26
-
27
- onCaptcha(tabId: string, handler: (data: { captchaType: string; tabId: string }) => void): () => void;
28
- onCaptchaResolved(tabId: string, handler: (data: { tabId: string }) => void): () => void;
29
- onBlocked(tabId: string, handler: (data: { blockType: string; tabId: string }) => void): () => void;
30
- onBlockRetry(tabId: string, handler: (data: { tabId: string; proxy: string }) => void): () => void;
31
-
32
- waitForResolution(tabId?: string, timeoutMs?: number): Promise<void>;
33
- }
34
-
35
- export declare function createCaptchaAPI(client: PiggyClient): CaptchaClient;
@@ -1,79 +0,0 @@
1
- export declare class PiggyClient {
2
- private socketPath;
3
- private socket;
4
- private reqId;
5
- private pending;
6
- private buf;
7
- private eventBuffer;
8
- private eventHandlers;
9
- private globalEventHandlers;
10
- constructor(socketPath?: string);
11
- connect(): Promise<void>;
12
- private handleEvent;
13
- onEvent(eventName: string, tabId: string, handler: (data: any) => void): () => void;
14
- disconnect(): void;
15
- send<T = any>(cmd: string, payload?: Record<string, any>): Promise<T>;
16
- newTab(): Promise<string>;
17
- closeTab(tabId: string): Promise<void>;
18
- listTabs(): Promise<string[]>;
19
- navigate(url: string, tabId?: string): Promise<void>;
20
- reload(tabId?: string): Promise<void>;
21
- goBack(tabId?: string): Promise<void>;
22
- goForward(tabId?: string): Promise<void>;
23
- getTitle(tabId?: string): Promise<string>;
24
- getUrl(tabId?: string): Promise<string>;
25
- content(tabId?: string): Promise<string>;
26
- evaluate(js: string, tabId?: string): Promise<any>;
27
- addInitScript(js: string, tabId?: string): Promise<void>;
28
- click(selector: string, tabId?: string): Promise<boolean>;
29
- doubleClick(selector: string, tabId?: string): Promise<boolean>;
30
- hover(selector: string, tabId?: string): Promise<boolean>;
31
- type(selector: string, text: string, tabId?: string): Promise<boolean>;
32
- select(selector: string, value: string, tabId?: string): Promise<boolean>;
33
- keyPress(key: string, tabId?: string): Promise<boolean>;
34
- keyCombo(combo: string, tabId?: string): Promise<boolean>;
35
- mouseMove(x: number, y: number, tabId?: string): Promise<boolean>;
36
- mouseDrag(from: {
37
- x: number;
38
- y: number;
39
- }, to: {
40
- x: number;
41
- y: number;
42
- }, tabId?: string): Promise<boolean>;
43
- scrollTo(selector: string, tabId?: string): Promise<boolean>;
44
- scrollBy(px: number, tabId?: string): Promise<boolean>;
45
- fetchText(query: string, tabId?: string): Promise<string | null>;
46
- fetchLinks(query: string, tabId?: string): Promise<string[]>;
47
- fetchImages(query: string, tabId?: string): Promise<string[]>;
48
- searchCss(query: string, tabId?: string): Promise<any>;
49
- searchId(query: string, tabId?: string): Promise<any>;
50
- waitForSelector(selector: string, timeout?: number, tabId?: string): Promise<void>;
51
- waitForNavigation(tabId?: string): Promise<void>;
52
- waitForResponse(urlPattern: string, timeout?: number, tabId?: string): Promise<void>;
53
- screenshot(filePath?: string, tabId?: string): Promise<string>;
54
- pdf(filePath?: string, tabId?: string): Promise<string>;
55
- blockImages(tabId?: string): Promise<void>;
56
- unblockImages(tabId?: string): Promise<void>;
57
- setCookie(name: string, value: string, domain: string, path?: string, tabId?: string): Promise<void>;
58
- getCookie(name: string, tabId?: string): Promise<any>;
59
- deleteCookie(name: string, tabId?: string): Promise<void>;
60
- listCookies(tabId?: string): Promise<any[]>;
61
- addInterceptRule(action: "block" | "redirect" | "modifyHeaders", pattern: string, options?: {
62
- redirectUrl?: string;
63
- headers?: Record<string, string>;
64
- }, tabId?: string): Promise<void>;
65
- clearInterceptRules(tabId?: string): Promise<void>;
66
- captureStart(tabId?: string): Promise<void>;
67
- captureStop(tabId?: string): Promise<void>;
68
- captureRequests(tabId?: string): Promise<any[]>;
69
- captureWs(tabId?: string): Promise<any[]>;
70
- captureCookies(tabId?: string): Promise<any[]>;
71
- captureStorage(tabId?: string): Promise<any>;
72
- captureClear(tabId?: string): Promise<void>;
73
- sessionExport(tabId?: string): Promise<any>;
74
- sessionImport(data: any, tabId?: string): Promise<void>;
75
- exposeFunction(name: string, handler: (data: any) => Promise<any> | any, tabId?: string): Promise<void>;
76
- unexposeFunction(name: string, tabId?: string): Promise<void>;
77
- clearExposedFunctions(tabId?: string): Promise<void>;
78
- }
79
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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"}
@@ -1,29 +0,0 @@
1
- // piggy/dialog/index.d.ts
2
- import { PiggyClient } from "../client";
3
-
4
- export interface DialogState {
5
- pending: boolean;
6
- type: string;
7
- message: string;
8
- defaultValue: string;
9
- }
10
-
11
- export declare class DialogClient {
12
- constructor(client: PiggyClient);
13
-
14
- accept(tabId?: string, text?: string): Promise<void>;
15
- dismiss(tabId?: string): Promise<void>;
16
- status(tabId?: string): Promise<DialogState>;
17
- setAutoAction(tabId?: string, action: "accept" | "dismiss" | ""): Promise<void>;
18
- upload(selector: string, filePath: string, tabId?: string): Promise<void>;
19
-
20
- onDialog(
21
- tabId: string,
22
- handler: (data: { dialogType: string; message: string; defaultValue: string; tabId: string }) => void
23
- ): () => void;
24
-
25
- waitAndAccept(tabId?: string, text?: string, timeoutMs?: number): Promise<DialogState>;
26
- waitAndDismiss(tabId?: string, timeoutMs?: number): Promise<DialogState>;
27
- }
28
-
29
- export declare function createDialogAPI(client: PiggyClient): DialogClient;
@@ -1,7 +0,0 @@
1
- export declare function randomDelay(min: number, max: number): Promise<void>;
2
- /**
3
- * Simulates human typing by introducing ~2 random typos and correcting them.
4
- * Returns an array of { char, isBackspace } actions to replay.
5
- */
6
- export declare function humanTypeSequence(text: string): string[];
7
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAEA,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAEnE;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CA0CxD"}
@@ -1,7 +0,0 @@
1
- import { PiggyClient } from "../client";
2
- export declare let humanMode: boolean;
3
- export declare function setClient(c: PiggyClient | null): void;
4
- export declare function setHumanMode(v: boolean): void;
5
- export declare function createSiteObject(name: string, registeredUrl: string, client: PiggyClient, tabId: string): any;
6
- export declare function createExposedAPI<T extends Record<string, (data: any) => any>>(site: any, apiName: string, handlers: T): Promise<void>;
7
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAOxC,eAAO,IAAI,SAAS,SAAQ,CAAC;AAE7B,wBAAgB,SAAS,CAAC,CAAC,EAAE,WAAW,GAAG,IAAI,QAAuB;AACtE,wBAAgB,YAAY,CAAC,CAAC,EAAE,OAAO,QAAoB;AAgB3D,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,OAmcvG;AAED,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CASrI"}
@@ -1,58 +0,0 @@
1
- // piggy/server/index.d.ts
2
- import { Elysia } from "elysia";
3
-
4
- export type BeforeMiddleware = (ctx: {
5
- params: Record<string, string>;
6
- query: Record<string, string>;
7
- body: any;
8
- headers: Record<string, string>;
9
- set: any;
10
- }) => void | Promise<void>;
11
-
12
- export type RouteHandler = (
13
- params: Record<string, string>,
14
- query: Record<string, string>,
15
- body: any
16
- ) => Promise<any>;
17
-
18
- export interface RouteParameter {
19
- name: string;
20
- in: "query" | "path" | "header" | "cookie";
21
- description?: string;
22
- required?: boolean;
23
- schema?: Record<string, any>;
24
- }
25
-
26
- export interface RouteDetail {
27
- tags?: string[];
28
- summary?: string;
29
- description?: string;
30
- deprecated?: boolean;
31
- hide?: boolean;
32
- parameters?: RouteParameter[];
33
- }
34
-
35
- export interface RouteConfig {
36
- path: string;
37
- method: "GET" | "POST" | "PUT" | "DELETE";
38
- handler: RouteHandler;
39
- ttl: number;
40
- before: BeforeMiddleware[];
41
- detail?: RouteDetail;
42
- }
43
-
44
- export declare const routeRegistry: Map<string, RouteConfig>;
45
- export declare const keepAliveSites: Set<string>;
46
-
47
- export declare function startServer(
48
- port: number,
49
- hostname?: string,
50
- openapiOpts?: {
51
- title?: string;
52
- version?: string;
53
- description?: string;
54
- path?: string;
55
- }
56
- ): Promise<Elysia>;
57
-
58
- export declare function stopServer(): void;
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAIhC,MAAM,MAAM,gBAAgB,GAAG,CAAC,GAAG,EAAE;IACnC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,IAAI,EAAE,GAAG,CAAC;IACV,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,GAAG,EAAE,GAAG,CAAC;CACV,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAE3B,MAAM,MAAM,YAAY,GAAG,CACzB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC9B,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC7B,IAAI,EAAE,GAAG,KACN,OAAO,CAAC,GAAG,CAAC,CAAC;AAElB,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,QAAQ,CAAC;IAC1C,OAAO,EAAE,YAAY,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,gBAAgB,EAAE,CAAC;CAC5B;AAED,eAAO,MAAM,aAAa,0BAAiC,CAAC;AAC5D,eAAO,MAAM,cAAc,aAAoB,CAAC;AAmBhD,wBAAsB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,SAAY,GAAG,OAAO,CAAC,MAAM,CAAC,CAoFrF;AAED,wBAAgB,UAAU,SAGzB"}