simplex-ts 1.0.7 → 1.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +2 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.js +21 -24
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +21 -24
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.d.mts
CHANGED
|
@@ -16,7 +16,6 @@ declare class Simplex {
|
|
|
16
16
|
createSession(showInConsole?: boolean, proxies?: boolean, workflowName?: string, sessionData?: SessionData | string): Promise<[string, string]>;
|
|
17
17
|
goto(url: string, cdpUrl?: string): Promise<void>;
|
|
18
18
|
click(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
19
|
-
scrollToElement(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
20
19
|
hover(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
21
20
|
type(text: string, cdpUrl?: string): Promise<void>;
|
|
22
21
|
pressEnter(cdpUrl?: string): Promise<void>;
|
|
@@ -31,6 +30,8 @@ declare class Simplex {
|
|
|
31
30
|
clickAndDownload(elementDescription: string): Promise<[string, string]>;
|
|
32
31
|
exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]>;
|
|
33
32
|
getNetworkResponse(url: string, cdpUrl?: string): Promise<string>;
|
|
33
|
+
getPageURL(cdpUrl?: string): Promise<string>;
|
|
34
|
+
getStorageState(cdpUrl?: string): Promise<string>;
|
|
34
35
|
closeSession(): Promise<void>;
|
|
35
36
|
}
|
|
36
37
|
|
package/dist/index.d.ts
CHANGED
|
@@ -16,7 +16,6 @@ declare class Simplex {
|
|
|
16
16
|
createSession(showInConsole?: boolean, proxies?: boolean, workflowName?: string, sessionData?: SessionData | string): Promise<[string, string]>;
|
|
17
17
|
goto(url: string, cdpUrl?: string): Promise<void>;
|
|
18
18
|
click(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
19
|
-
scrollToElement(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
20
19
|
hover(elementDescription: string, cdpUrl?: string): Promise<string>;
|
|
21
20
|
type(text: string, cdpUrl?: string): Promise<void>;
|
|
22
21
|
pressEnter(cdpUrl?: string): Promise<void>;
|
|
@@ -31,6 +30,8 @@ declare class Simplex {
|
|
|
31
30
|
clickAndDownload(elementDescription: string): Promise<[string, string]>;
|
|
32
31
|
exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]>;
|
|
33
32
|
getNetworkResponse(url: string, cdpUrl?: string): Promise<string>;
|
|
33
|
+
getPageURL(cdpUrl?: string): Promise<string>;
|
|
34
|
+
getStorageState(cdpUrl?: string): Promise<string>;
|
|
34
35
|
closeSession(): Promise<void>;
|
|
35
36
|
}
|
|
36
37
|
|
package/dist/index.js
CHANGED
|
@@ -67,19 +67,7 @@ var Simplex = class {
|
|
|
67
67
|
}
|
|
68
68
|
});
|
|
69
69
|
const responseData = response.data;
|
|
70
|
-
if (endpoint == "/
|
|
71
|
-
if (!("succeeded" in responseData)) {
|
|
72
|
-
console.error("Response data missing 'succeeded' property:", responseData);
|
|
73
|
-
throw new Error("Invalid API response: missing 'succeeded' property");
|
|
74
|
-
} else {
|
|
75
|
-
if (responseData.succeeded) {
|
|
76
|
-
return responseData;
|
|
77
|
-
} else {
|
|
78
|
-
throw new Error(responseData.error || "Request failed");
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
if (endpoint == "/goto") {
|
|
70
|
+
if (endpoint == "/goto" || endpoint == "/hover") {
|
|
83
71
|
if (!("succeeded" in responseData)) {
|
|
84
72
|
console.error('Response data missing "succeeded" property:', responseData);
|
|
85
73
|
throw new Error('Invalid API response: missing "succeeded" property');
|
|
@@ -172,17 +160,6 @@ var Simplex = class {
|
|
|
172
160
|
const response = await this.makeRequest("post", "/click", data);
|
|
173
161
|
return response.element_clicked || "";
|
|
174
162
|
}
|
|
175
|
-
async scrollToElement(elementDescription, cdpUrl) {
|
|
176
|
-
if (!cdpUrl && !this.sessionId) {
|
|
177
|
-
throw new Error(`Must call createSession before calling scrollToElement with elementDescription='${elementDescription}'`);
|
|
178
|
-
}
|
|
179
|
-
const data = {
|
|
180
|
-
element_description: elementDescription,
|
|
181
|
-
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
182
|
-
};
|
|
183
|
-
const response = await this.makeRequest("post", "/scroll_to_element", data);
|
|
184
|
-
return response.element_info || "";
|
|
185
|
-
}
|
|
186
163
|
async hover(elementDescription, cdpUrl) {
|
|
187
164
|
if (!cdpUrl && !this.sessionId) {
|
|
188
165
|
throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);
|
|
@@ -329,6 +306,26 @@ var Simplex = class {
|
|
|
329
306
|
const response = await this.makeRequest("post", "/get_network_response", data);
|
|
330
307
|
return response.response || "";
|
|
331
308
|
}
|
|
309
|
+
async getPageURL(cdpUrl) {
|
|
310
|
+
if (!cdpUrl && !this.sessionId) {
|
|
311
|
+
throw new Error(`Must call createSession before calling getPageURL`);
|
|
312
|
+
}
|
|
313
|
+
const data = {
|
|
314
|
+
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
315
|
+
};
|
|
316
|
+
const response = await this.makeRequest("post", "/get_page_url", data);
|
|
317
|
+
return response.url || "";
|
|
318
|
+
}
|
|
319
|
+
async getStorageState(cdpUrl) {
|
|
320
|
+
if (!cdpUrl && !this.sessionId) {
|
|
321
|
+
throw new Error(`Must call createSession before calling getStorageState`);
|
|
322
|
+
}
|
|
323
|
+
const data = {
|
|
324
|
+
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
325
|
+
};
|
|
326
|
+
const response = await this.makeRequest("post", "/get_storage_state", data);
|
|
327
|
+
return response.storage_state || "";
|
|
328
|
+
}
|
|
332
329
|
async closeSession() {
|
|
333
330
|
if (!this.sessionId) {
|
|
334
331
|
return;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * Example function to demonstrate package usage\n * @param name - The name to greet\n * @returns A greeting message\n */\nexport function greet(name: string): string {\n return `Hello, ${name}!`;\n}\n\n// Export other functions and types here \nimport axios from 'axios';\n\n// const BASE_URL = \"https://api.simplex.sh\"\nconst BASE_URL = \"https://simplex-dev-shreya--api-server-fastapi-app.modal.run\"\n\ninterface SessionData {\n [key: string]: any;\n}\n\ninterface PlaywrightClickOptions {\n locator: string;\n locatorType: string;\n exact?: boolean;\n elementIndex?: 'first' | 'last' | 'nth';\n nthIndex?: number;\n locatorOptions?: Record<string, any>;\n}\n\ninterface SimplexResponse {\n succeeded: boolean;\n error?: string;\n session_id?: string;\n livestream_url?: string;\n connect_url?: string;\n element_clicked?: string;\n element_info?: string;\n text?: string;\n image?: string;\n bbox?: any;\n b64?: string;\n filename?: string;\n exists?: boolean;\n reasoning?: string;\n response?: string;\n}\n\nexport class Simplex {\n private apiKey: string;\n private sessionId: string | null = null;\n private connectUrl: string | null = null;\n\n constructor(apiKey: string) {\n this.apiKey = apiKey;\n }\n\n private async makeRequest<T>(\n method: 'get' | 'post',\n endpoint: string,\n data?: any,\n params?: any\n ): Promise<T> {\n try {\n console.log(`Making ${method.toUpperCase()} request to ${endpoint}`);\n \n // Convert data to FormData\n const formData = new FormData();\n if (data) {\n Object.entries(data).forEach(([key, value]) => {\n if (value !== undefined && value !== null) {\n formData.append(key, value.toString());\n }\n });\n }\n\n // console.log('Request data:', Object.fromEntries(formData.entries()));\n \n const response = await axios({\n method,\n url: `${BASE_URL}${endpoint}`,\n data: method === 'post' ? formData : undefined,\n params: method === 'get' ? params : undefined,\n headers: {\n 'x-api-key': this.apiKey,\n ...(method === 'post' ? { 'Content-Type': 'multipart/form-data' } : {})\n }\n });\n\n // console.log('Response status:', response.status);\n // console.log('Response data:', JSON.stringify(response.data, null, 2));\n\n const responseData = response.data as SimplexResponse;\n \n // Consider response successful if:\n // 1. It has succeeded: true, or\n // 2. It's a create_session response with a session_id\n // Check if 'succeeded' property exists in responseData\n // console.log('Response data:', responseData);\n\n if (endpoint == \"/hover\" || endpoint == \"/scroll_to_element\") {\n if (!('succeeded' in responseData)) {\n console.error(\"Response data missing 'succeeded' property:\", responseData);\n throw new Error(\"Invalid API response: missing 'succeeded' property\");\n } else {\n if (responseData.succeeded) {\n return responseData as T;\n } else {\n throw new Error(responseData.error || 'Request failed');\n }\n }\n }\n\n if (endpoint == \"/goto\") {\n if (!('succeeded' in responseData)) {\n console.error('Response data missing \"succeeded\" property:', responseData);\n throw new Error('Invalid API response: missing \"succeeded\" property');\n } else {\n return responseData as T;\n }\n }\n\n if (endpoint == \"/get_network_response\") {\n if (!('status' in responseData)) {\n console.error('Response data missing \"status\" property:', responseData);\n throw new Error('Invalid API response: missing \"status\" property');\n } else if (responseData.status == \"success\") {\n return responseData as T;\n } else {\n throw new Error('Failed to get network response');\n }\n }\n\n if (!responseData.succeeded && !(endpoint === '/create_session' && responseData.session_id)) {\n const errorMessage = responseData.error || 'Request failed';\n console.error('API request failed:', errorMessage);\n throw new Error(errorMessage);\n }\n return responseData as T;\n } catch (error) {\n if (axios.isAxiosError(error)) {\n const errorMessage = error.response?.data?.error || error.message;\n console.error('Axios error:', {\n status: error.response?.status,\n statusText: error.response?.statusText,\n data: error.response?.data,\n message: errorMessage\n });\n throw new Error(`Request failed: ${errorMessage}`);\n }\n console.error('Unexpected error:', error);\n throw error;\n }\n }\n\n async createSession(\n showInConsole: boolean = true,\n proxies: boolean = true,\n workflowName?: string,\n sessionData?: SessionData | string\n ): Promise<[string, string]> {\n const data: any = {\n proxies,\n workflow_name: workflowName\n };\n\n if (this.sessionId) {\n throw new Error(\"A session is already active. Please close the current session before creating a new one.\");\n }\n if (sessionData) {\n if (typeof sessionData === 'string') {\n try {\n data.session_data = JSON.stringify(JSON.parse(sessionData));\n } catch {\n // If parsing fails, treat as file path\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n }\n } else {\n data.session_data = JSON.stringify(sessionData);\n }\n }\n\n const response = await this.makeRequest<SimplexResponse>('post', '/create_session', data);\n \n if (!response.session_id) {\n throw new Error('Session creation failed: No session ID returned');\n }\n\n this.sessionId = response.session_id;\n this.connectUrl = response.connect_url || null;\n\n if (showInConsole && response.livestream_url) {\n console.log(`Livestream URL: ${response.livestream_url}`);\n }\n\n return [response.session_id, response.livestream_url || ''];\n }\n\n async goto(url: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling goto with url='${url}'`);\n }\n\n if (!url.startsWith('http://') && !url.startsWith('https://')) {\n url = 'https://' + url;\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/goto', data);\n }\n\n async click(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling click with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click', data);\n return response.element_clicked || '';\n }\n\n async scrollToElement(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scrollToElement with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/scroll_to_element', data);\n return response.element_info || '';\n }\n\n async hover(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/hover', data);\n return response.element_info || '';\n }\n\n async type(text: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling type with text='${text}'`);\n }\n\n const data = {\n text,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/type', data);\n }\n\n async pressEnter(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressEnter');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_enter', data);\n }\n\n async pressTab(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressTab');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_tab', data);\n }\n\n async deleteText(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling deleteText');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/delete_text', data);\n }\n\n async extractBbox(elementDescription: string, cdpUrl?: string): Promise<any> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractBbox with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-bbox', undefined, params);\n return response.bbox;\n }\n\n async extractText(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractText with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/extract-text', data);\n return response.text || '';\n }\n\n async extractImage(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractImage with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-image', undefined, params);\n return response.image || '';\n }\n\n async scroll(pixels: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scroll with pixels=${pixels}`);\n }\n\n const data = {\n pixels,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/scroll', data);\n }\n\n async wait(milliseconds: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling wait with milliseconds=${milliseconds}`);\n }\n\n const data = {\n milliseconds,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/wait', data);\n }\n\n async clickAndUpload(\n elementDescription: string,\n filePathOrCallable: string | (() => Blob)\n ): Promise<void> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndUpload with elementDescription='${elementDescription}'`);\n }\n\n if (typeof filePathOrCallable !== 'string' && typeof filePathOrCallable !== 'function') {\n throw new TypeError(`filePathOrCallable must be either a string or a callable, not a ${typeof filePathOrCallable}`);\n }\n\n const formData = new FormData();\n formData.append('element_description', elementDescription);\n formData.append('session_id', this.sessionId);\n\n if (typeof filePathOrCallable === 'string') {\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n } else {\n const blob = filePathOrCallable();\n formData.append('file', blob, 'file'); // Add filename for the blob\n }\n\n await this.makeRequest('post', '/click_and_upload', formData, undefined);\n }\n\n async clickAndDownload(elementDescription: string): Promise<[string, string]> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndDownload with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n session_id: this.sessionId\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click_and_download', data);\n return [response.b64 || '', response.filename || ''];\n }\n\n async exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling exists with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/exists', data);\n return [response.exists || false, response.reasoning || ''];\n }\n\n async getNetworkResponse(url: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getNetworkResponse with url='${url}'`);\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_network_response', data);\n return response.response || '';\n }\n\n async closeSession(): Promise<void> {\n if (!this.sessionId) {\n return;\n }\n\n await this.makeRequest('post', '/close_session', { session_id: this.sessionId });\n this.sessionId = null;\n this.connectUrl = null;\n }\n} "],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUA,mBAAkB;AALX,SAAS,MAAM,MAAsB;AAC1C,SAAO,UAAU,IAAI;AACvB;AAMA,IAAM,WAAW;AAiCV,IAAM,UAAN,MAAc;AAAA,EAKnB,YAAY,QAAgB;AAH5B,SAAQ,YAA2B;AACnC,SAAQ,aAA4B;AAGlC,SAAK,SAAS;AAAA,EAChB;AAAA,EAEA,MAAc,YACZ,QACA,UACA,MACA,QACY;AACZ,QAAI;AACF,cAAQ,IAAI,UAAU,OAAO,YAAY,CAAC,eAAe,QAAQ,EAAE;AAGnE,YAAM,WAAW,IAAI,SAAS;AAC9B,UAAI,MAAM;AACR,eAAO,QAAQ,IAAI,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AAC7C,cAAI,UAAU,UAAa,UAAU,MAAM;AACzC,qBAAS,OAAO,KAAK,MAAM,SAAS,CAAC;AAAA,UACvC;AAAA,QACF,CAAC;AAAA,MACH;AAIA,YAAM,WAAW,UAAM,aAAAA,SAAM;AAAA,QAC3B;AAAA,QACA,KAAK,GAAG,QAAQ,GAAG,QAAQ;AAAA,QAC3B,MAAM,WAAW,SAAS,WAAW;AAAA,QACrC,QAAQ,WAAW,QAAQ,SAAS;AAAA,QACpC,SAAS;AAAA,UACP,aAAa,KAAK;AAAA,UAClB,GAAI,WAAW,SAAS,EAAE,gBAAgB,sBAAsB,IAAI,CAAC;AAAA,QACvE;AAAA,MACF,CAAC;AAKD,YAAM,eAAe,SAAS;AAQ9B,UAAI,YAAY,YAAY,YAAY,sBAAsB;AAC5D,YAAI,EAAE,eAAe,eAAe;AAClC,kBAAQ,MAAM,+CAA+C,YAAY;AACzE,gBAAM,IAAI,MAAM,oDAAoD;AAAA,QACtE,OAAO;AACL,cAAI,aAAa,WAAW;AAC1B,mBAAO;AAAA,UACT,OAAO;AACL,kBAAM,IAAI,MAAM,aAAa,SAAS,gBAAgB;AAAA,UACxD;AAAA,QACF;AAAA,MACF;AAEA,UAAI,YAAY,SAAS;AACvB,YAAI,EAAE,eAAe,eAAe;AAClC,kBAAQ,MAAM,+CAA+C,YAAY;AACzE,gBAAM,IAAI,MAAM,oDAAoD;AAAA,QACtE,OAAO;AACL,iBAAO;AAAA,QACT;AAAA,MACF;AAEA,UAAI,YAAY,yBAAyB;AACvC,YAAI,EAAE,YAAY,eAAe;AAC/B,kBAAQ,MAAM,4CAA4C,YAAY;AACtE,gBAAM,IAAI,MAAM,iDAAiD;AAAA,QACnE,WAAW,aAAa,UAAU,WAAW;AAC3C,iBAAO;AAAA,QACT,OAAO;AACL,gBAAM,IAAI,MAAM,gCAAgC;AAAA,QAClD;AAAA,MACF;AAEA,UAAI,CAAC,aAAa,aAAa,EAAE,aAAa,qBAAqB,aAAa,aAAa;AAC3F,cAAM,eAAe,aAAa,SAAS;AAC3C,gBAAQ,MAAM,uBAAuB,YAAY;AACjD,cAAM,IAAI,MAAM,YAAY;AAAA,MAC9B;AACA,aAAO;AAAA,IACT,SAAS,OAAO;AACd,UAAI,aAAAA,QAAM,aAAa,KAAK,GAAG;AAC7B,cAAM,eAAe,MAAM,UAAU,MAAM,SAAS,MAAM;AAC1D,gBAAQ,MAAM,gBAAgB;AAAA,UAC5B,QAAQ,MAAM,UAAU;AAAA,UACxB,YAAY,MAAM,UAAU;AAAA,UAC5B,MAAM,MAAM,UAAU;AAAA,UACtB,SAAS;AAAA,QACX,CAAC;AACD,cAAM,IAAI,MAAM,mBAAmB,YAAY,EAAE;AAAA,MACnD;AACA,cAAQ,MAAM,qBAAqB,KAAK;AACxC,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,MAAM,cACJ,gBAAyB,MACzB,UAAmB,MACnB,cACA,aAC2B;AAC3B,UAAM,OAAY;AAAA,MAChB;AAAA,MACA,eAAe;AAAA,IACjB;AAEA,QAAI,KAAK,WAAW;AAClB,YAAM,IAAI,MAAM,0FAA0F;AAAA,IAC5G;AACA,QAAI,aAAa;AACf,UAAI,OAAO,gBAAgB,UAAU;AACnC,YAAI;AACF,eAAK,eAAe,KAAK,UAAU,KAAK,MAAM,WAAW,CAAC;AAAA,QAC5D,QAAQ;AAGN,gBAAM,IAAI,MAAM,8DAA8D;AAAA,QAChF;AAAA,MACF,OAAO;AACL,aAAK,eAAe,KAAK,UAAU,WAAW;AAAA,MAChD;AAAA,IACF;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,mBAAmB,IAAI;AAExF,QAAI,CAAC,SAAS,YAAY;AACxB,YAAM,IAAI,MAAM,iDAAiD;AAAA,IACnE;AAEA,SAAK,YAAY,SAAS;AAC1B,SAAK,aAAa,SAAS,eAAe;AAE1C,QAAI,iBAAiB,SAAS,gBAAgB;AAC5C,cAAQ,IAAI,mBAAmB,SAAS,cAAc,EAAE;AAAA,IAC1D;AAEA,WAAO,CAAC,SAAS,YAAY,SAAS,kBAAkB,EAAE;AAAA,EAC5D;AAAA,EAEA,MAAM,KAAK,KAAa,QAAgC;AACtD,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,yDAAyD,GAAG,GAAG;AAAA,IACjF;AAEA,QAAI,CAAC,IAAI,WAAW,SAAS,KAAK,CAAC,IAAI,WAAW,UAAU,GAAG;AAC7D,YAAM,aAAa;AAAA,IACrB;AAEA,UAAM,OAAO;AAAA,MACX;AAAA,MACA,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,KAAK,YAAY,QAAQ,SAAS,IAAI;AAAA,EAC9C;AAAA,EAEA,MAAM,MAAM,oBAA4B,QAAkC;AACxE,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,yEAAyE,kBAAkB,GAAG;AAAA,IAChH;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,UAAU,IAAI;AAC/E,WAAO,SAAS,mBAAmB;AAAA,EACrC;AAAA,EAEA,MAAM,gBAAgB,oBAA4B,QAAkC;AAClF,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,mFAAmF,kBAAkB,GAAG;AAAA,IAC1H;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,sBAAsB,IAAI;AAC3F,WAAO,SAAS,gBAAgB;AAAA,EAClC;AAAA,EAEA,MAAM,MAAM,oBAA4B,QAAkC;AACxE,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,yEAAyE,kBAAkB,GAAG;AAAA,IAChH;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,UAAU,IAAI;AAC/E,WAAO,SAAS,gBAAgB;AAAA,EAClC;AAAA,EAEA,MAAM,KAAK,MAAc,QAAgC;AACvD,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,0DAA0D,IAAI,GAAG;AAAA,IACnF;AAEA,UAAM,OAAO;AAAA,MACX;AAAA,MACA,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,KAAK,YAAY,QAAQ,SAAS,IAAI;AAAA,EAC9C;AAAA,EAEA,MAAM,WAAW,QAAgC;AAC/C,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,mDAAmD;AAAA,IACrE;AAEA,UAAM,OAAO,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AACzE,UAAM,KAAK,YAAY,QAAQ,gBAAgB,IAAI;AAAA,EACrD;AAAA,EAEA,MAAM,SAAS,QAAgC;AAC7C,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,iDAAiD;AAAA,IACnE;AAEA,UAAM,OAAO,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AACzE,UAAM,KAAK,YAAY,QAAQ,cAAc,IAAI;AAAA,EACnD;AAAA,EAEA,MAAM,WAAW,QAAgC;AAC/C,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,mDAAmD;AAAA,IACrE;AAEA,UAAM,OAAO,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AACzE,UAAM,KAAK,YAAY,QAAQ,gBAAgB,IAAI;AAAA,EACrD;AAAA,EAEA,MAAM,YAAY,oBAA4B,QAA+B;AAC3E,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,+EAA+E,kBAAkB,GAAG;AAAA,IACtH;AAEA,UAAM,SAAS;AAAA,MACb,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,OAAO,iBAAiB,QAAW,MAAM;AAClG,WAAO,SAAS;AAAA,EAClB;AAAA,EAEA,MAAM,YAAY,oBAA4B,QAAkC;AAC9E,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,+EAA+E,kBAAkB,GAAG;AAAA,IACtH;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,iBAAiB,IAAI;AACtF,WAAO,SAAS,QAAQ;AAAA,EAC1B;AAAA,EAEA,MAAM,aAAa,oBAA4B,QAAkC;AAC/E,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,gFAAgF,kBAAkB,GAAG;AAAA,IACvH;AAEA,UAAM,SAAS;AAAA,MACb,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,OAAO,kBAAkB,QAAW,MAAM;AACnG,WAAO,SAAS,SAAS;AAAA,EAC3B;AAAA,EAEA,MAAM,OAAO,QAAgB,QAAgC;AAC3D,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,6DAA6D,MAAM,EAAE;AAAA,IACvF;AAEA,UAAM,OAAO;AAAA,MACX;AAAA,MACA,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,KAAK,YAAY,QAAQ,WAAW,IAAI;AAAA,EAChD;AAAA,EAEA,MAAM,KAAK,cAAsB,QAAgC;AAC/D,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,iEAAiE,YAAY,EAAE;AAAA,IACjG;AAEA,UAAM,OAAO;AAAA,MACX;AAAA,MACA,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,KAAK,YAAY,QAAQ,SAAS,IAAI;AAAA,EAC9C;AAAA,EAEA,MAAM,eACJ,oBACA,oBACe;AACf,QAAI,CAAC,KAAK,WAAW;AACnB,YAAM,IAAI,MAAM,kFAAkF,kBAAkB,GAAG;AAAA,IACzH;AAEA,QAAI,OAAO,uBAAuB,YAAY,OAAO,uBAAuB,YAAY;AACtF,YAAM,IAAI,UAAU,mEAAmE,OAAO,kBAAkB,EAAE;AAAA,IACpH;AAEA,UAAM,WAAW,IAAI,SAAS;AAC9B,aAAS,OAAO,uBAAuB,kBAAkB;AACzD,aAAS,OAAO,cAAc,KAAK,SAAS;AAE5C,QAAI,OAAO,uBAAuB,UAAU;AAE1C,YAAM,IAAI,MAAM,8DAA8D;AAAA,IAChF,OAAO;AACL,YAAM,OAAO,mBAAmB;AAChC,eAAS,OAAO,QAAQ,MAAM,MAAM;AAAA,IACtC;AAEA,UAAM,KAAK,YAAY,QAAQ,qBAAqB,UAAU,MAAS;AAAA,EACzE;AAAA,EAEA,MAAM,iBAAiB,oBAAuD;AAC5E,QAAI,CAAC,KAAK,WAAW;AACnB,YAAM,IAAI,MAAM,oFAAoF,kBAAkB,GAAG;AAAA,IAC3H;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,YAAY,KAAK;AAAA,IACnB;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,uBAAuB,IAAI;AAC5F,WAAO,CAAC,SAAS,OAAO,IAAI,SAAS,YAAY,EAAE;AAAA,EACrD;AAAA,EAEA,MAAM,OAAO,oBAA4B,QAA6C;AACpF,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,0EAA0E,kBAAkB,GAAG;AAAA,IACjH;AAEA,UAAM,OAAO;AAAA,MACX,qBAAqB;AAAA,MACrB,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,WAAW,IAAI;AAChF,WAAO,CAAC,SAAS,UAAU,OAAO,SAAS,aAAa,EAAE;AAAA,EAC5D;AAAA,EAEA,MAAM,mBAAmB,KAAa,QAAkC;AACtE,QAAI,CAAC,UAAU,CAAC,KAAK,WAAW;AAC9B,YAAM,IAAI,MAAM,uEAAuE,GAAG,GAAG;AAAA,IAC/F;AAEA,UAAM,OAAO;AAAA,MACX;AAAA,MACA,GAAI,SAAS,EAAE,SAAS,OAAO,IAAI,EAAE,YAAY,KAAK,UAAU;AAAA,IAClE;AAEA,UAAM,WAAW,MAAM,KAAK,YAA6B,QAAQ,yBAAyB,IAAI;AAC9F,WAAO,SAAS,YAAY;AAAA,EAC9B;AAAA,EAEA,MAAM,eAA8B;AAClC,QAAI,CAAC,KAAK,WAAW;AACnB;AAAA,IACF;AAEA,UAAM,KAAK,YAAY,QAAQ,kBAAkB,EAAE,YAAY,KAAK,UAAU,CAAC;AAC/E,SAAK,YAAY;AACjB,SAAK,aAAa;AAAA,EACpB;AACF;","names":["axios"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * Example function to demonstrate package usage\n * @param name - The name to greet\n * @returns A greeting message\n */\nexport function greet(name: string): string {\n return `Hello, ${name}!`;\n}\n\n// Export other functions and types here \n\nimport axios from 'axios';\n\nconst BASE_URL = \"https://simplex-dev-shreya--api-server-fastapi-app.modal.run\"\n\ninterface SessionData {\n [key: string]: any;\n}\n\ninterface PlaywrightClickOptions {\n locator: string;\n locatorType: string;\n exact?: boolean;\n elementIndex?: 'first' | 'last' | 'nth';\n nthIndex?: number;\n locatorOptions?: Record<string, any>;\n}\n\ninterface SimplexResponse {\n succeeded: boolean;\n error?: string;\n session_id?: string;\n livestream_url?: string;\n connect_url?: string;\n element_clicked?: string;\n element_info?: string;\n text?: string;\n image?: string;\n bbox?: any;\n b64?: string;\n filename?: string;\n exists?: boolean;\n reasoning?: string;\n response?: string;\n url?: string;\n storage_state?: string;\n}\n\nexport class Simplex {\n private apiKey: string;\n private sessionId: string | null = null;\n private connectUrl: string | null = null;\n\n constructor(apiKey: string) {\n this.apiKey = apiKey;\n }\n\n private async makeRequest<T>(\n method: 'get' | 'post',\n endpoint: string,\n data?: any,\n params?: any\n ): Promise<T> {\n try {\n console.log(`Making ${method.toUpperCase()} request to ${endpoint}`);\n \n // Convert data to FormData\n const formData = new FormData();\n if (data) {\n Object.entries(data).forEach(([key, value]) => {\n if (value !== undefined && value !== null) {\n formData.append(key, value.toString());\n }\n });\n }\n\n // console.log('Request data:', Object.fromEntries(formData.entries()));\n \n const response = await axios({\n method,\n url: `${BASE_URL}${endpoint}`,\n data: method === 'post' ? formData : undefined,\n params: method === 'get' ? params : undefined,\n headers: {\n 'x-api-key': this.apiKey,\n ...(method === 'post' ? { 'Content-Type': 'multipart/form-data' } : {})\n }\n });\n\n // console.log('Response status:', response.status);\n // console.log('Response data:', JSON.stringify(response.data, null, 2));\n\n const responseData = response.data as SimplexResponse;\n \n // Consider response successful if:\n // 1. It has succeeded: true, or\n // 2. It's a create_session response with a session_id\n // Check if 'succeeded' property exists in responseData\n // console.log('Response data:', responseData);\n\n\n if (endpoint == \"/goto\" || endpoint == \"/hover\") {\n if (!('succeeded' in responseData)) {\n console.error('Response data missing \"succeeded\" property:', responseData);\n throw new Error('Invalid API response: missing \"succeeded\" property');\n } else {\n return responseData as T;\n }\n }\n\n if (endpoint == \"/get_network_response\") {\n if (!('status' in responseData)) {\n console.error('Response data missing \"status\" property:', responseData);\n throw new Error('Invalid API response: missing \"status\" property');\n } else if (responseData.status == \"success\") {\n return responseData as T;\n } else {\n throw new Error('Failed to get network response');\n }\n }\n\n if (!responseData.succeeded && !(endpoint === '/create_session' && responseData.session_id)) {\n const errorMessage = responseData.error || 'Request failed';\n console.error('API request failed:', errorMessage);\n throw new Error(errorMessage);\n }\n return responseData as T;\n } catch (error) {\n if (axios.isAxiosError(error)) {\n const errorMessage = error.response?.data?.error || error.message;\n console.error('Axios error:', {\n status: error.response?.status,\n statusText: error.response?.statusText,\n data: error.response?.data,\n message: errorMessage\n });\n throw new Error(`Request failed: ${errorMessage}`);\n }\n console.error('Unexpected error:', error);\n throw error;\n }\n }\n\n async createSession(\n showInConsole: boolean = true,\n proxies: boolean = true,\n workflowName?: string,\n sessionData?: SessionData | string\n ): Promise<[string, string]> {\n const data: any = {\n proxies,\n workflow_name: workflowName\n };\n\n if (this.sessionId) {\n throw new Error(\"A session is already active. Please close the current session before creating a new one.\");\n }\n if (sessionData) {\n if (typeof sessionData === 'string') {\n try {\n data.session_data = JSON.stringify(JSON.parse(sessionData));\n } catch {\n // If parsing fails, treat as file path\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n }\n } else {\n data.session_data = JSON.stringify(sessionData);\n }\n }\n\n const response = await this.makeRequest<SimplexResponse>('post', '/create_session', data);\n \n if (!response.session_id) {\n throw new Error('Session creation failed: No session ID returned');\n }\n\n this.sessionId = response.session_id;\n this.connectUrl = response.connect_url || null;\n\n if (showInConsole && response.livestream_url) {\n console.log(`Livestream URL: ${response.livestream_url}`);\n }\n\n return [response.session_id, response.livestream_url || ''];\n }\n\n async goto(url: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling goto with url='${url}'`);\n }\n\n if (!url.startsWith('http://') && !url.startsWith('https://')) {\n url = 'https://' + url;\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/goto', data);\n }\n\n async click(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling click with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click', data);\n return response.element_clicked || '';\n }\n\n async hover(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/hover', data);\n return response.element_info || '';\n }\n\n async type(text: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling type with text='${text}'`);\n }\n\n const data = {\n text,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/type', data);\n }\n\n async pressEnter(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressEnter');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_enter', data);\n }\n\n async pressTab(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressTab');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_tab', data);\n }\n\n async deleteText(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling deleteText');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/delete_text', data);\n }\n\n async extractBbox(elementDescription: string, cdpUrl?: string): Promise<any> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractBbox with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-bbox', undefined, params);\n return response.bbox;\n }\n\n async extractText(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractText with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/extract-text', data);\n return response.text || '';\n }\n\n async extractImage(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractImage with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-image', undefined, params);\n return response.image || '';\n }\n\n async scroll(pixels: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scroll with pixels=${pixels}`);\n }\n\n const data = {\n pixels,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/scroll', data);\n }\n\n async wait(milliseconds: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling wait with milliseconds=${milliseconds}`);\n }\n\n const data = {\n milliseconds,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/wait', data);\n }\n\n async clickAndUpload(\n elementDescription: string,\n filePathOrCallable: string | (() => Blob)\n ): Promise<void> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndUpload with elementDescription='${elementDescription}'`);\n }\n\n if (typeof filePathOrCallable !== 'string' && typeof filePathOrCallable !== 'function') {\n throw new TypeError(`filePathOrCallable must be either a string or a callable, not a ${typeof filePathOrCallable}`);\n }\n\n const formData = new FormData();\n formData.append('element_description', elementDescription);\n formData.append('session_id', this.sessionId);\n\n if (typeof filePathOrCallable === 'string') {\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n } else {\n const blob = filePathOrCallable();\n formData.append('file', blob, 'file'); // Add filename for the blob\n }\n\n await this.makeRequest('post', '/click_and_upload', formData, undefined);\n }\n\n async clickAndDownload(elementDescription: string): Promise<[string, string]> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndDownload with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n session_id: this.sessionId\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click_and_download', data);\n return [response.b64 || '', response.filename || ''];\n }\n\n async exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling exists with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/exists', data);\n return [response.exists || false, response.reasoning || ''];\n }\n\n async getNetworkResponse(url: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getNetworkResponse with url='${url}'`);\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_network_response', data);\n return response.response || '';\n }\n\n async getPageURL(cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getPageURL`);\n }\n\n const data = {\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_page_url', data);\n return response.url || '';\n }\n\n async getStorageState(cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getStorageState`);\n }\n \n const data = {\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_storage_state', data);\n return response.storage_state || '';\n }\n\n async closeSession(): Promise<void> {\n if (!this.sessionId) {\n return;\n }\n\n await this.makeRequest('post', '/close_session', { session_id: this.sessionId });\n this.sessionId = null;\n this.connectUrl = null;\n }\n} "],"mappings":"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","names":["axios"]}
|
package/dist/index.mjs
CHANGED
|
@@ -32,19 +32,7 @@ var Simplex = class {
|
|
|
32
32
|
}
|
|
33
33
|
});
|
|
34
34
|
const responseData = response.data;
|
|
35
|
-
if (endpoint == "/
|
|
36
|
-
if (!("succeeded" in responseData)) {
|
|
37
|
-
console.error("Response data missing 'succeeded' property:", responseData);
|
|
38
|
-
throw new Error("Invalid API response: missing 'succeeded' property");
|
|
39
|
-
} else {
|
|
40
|
-
if (responseData.succeeded) {
|
|
41
|
-
return responseData;
|
|
42
|
-
} else {
|
|
43
|
-
throw new Error(responseData.error || "Request failed");
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
if (endpoint == "/goto") {
|
|
35
|
+
if (endpoint == "/goto" || endpoint == "/hover") {
|
|
48
36
|
if (!("succeeded" in responseData)) {
|
|
49
37
|
console.error('Response data missing "succeeded" property:', responseData);
|
|
50
38
|
throw new Error('Invalid API response: missing "succeeded" property');
|
|
@@ -137,17 +125,6 @@ var Simplex = class {
|
|
|
137
125
|
const response = await this.makeRequest("post", "/click", data);
|
|
138
126
|
return response.element_clicked || "";
|
|
139
127
|
}
|
|
140
|
-
async scrollToElement(elementDescription, cdpUrl) {
|
|
141
|
-
if (!cdpUrl && !this.sessionId) {
|
|
142
|
-
throw new Error(`Must call createSession before calling scrollToElement with elementDescription='${elementDescription}'`);
|
|
143
|
-
}
|
|
144
|
-
const data = {
|
|
145
|
-
element_description: elementDescription,
|
|
146
|
-
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
147
|
-
};
|
|
148
|
-
const response = await this.makeRequest("post", "/scroll_to_element", data);
|
|
149
|
-
return response.element_info || "";
|
|
150
|
-
}
|
|
151
128
|
async hover(elementDescription, cdpUrl) {
|
|
152
129
|
if (!cdpUrl && !this.sessionId) {
|
|
153
130
|
throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);
|
|
@@ -294,6 +271,26 @@ var Simplex = class {
|
|
|
294
271
|
const response = await this.makeRequest("post", "/get_network_response", data);
|
|
295
272
|
return response.response || "";
|
|
296
273
|
}
|
|
274
|
+
async getPageURL(cdpUrl) {
|
|
275
|
+
if (!cdpUrl && !this.sessionId) {
|
|
276
|
+
throw new Error(`Must call createSession before calling getPageURL`);
|
|
277
|
+
}
|
|
278
|
+
const data = {
|
|
279
|
+
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
280
|
+
};
|
|
281
|
+
const response = await this.makeRequest("post", "/get_page_url", data);
|
|
282
|
+
return response.url || "";
|
|
283
|
+
}
|
|
284
|
+
async getStorageState(cdpUrl) {
|
|
285
|
+
if (!cdpUrl && !this.sessionId) {
|
|
286
|
+
throw new Error(`Must call createSession before calling getStorageState`);
|
|
287
|
+
}
|
|
288
|
+
const data = {
|
|
289
|
+
...cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId }
|
|
290
|
+
};
|
|
291
|
+
const response = await this.makeRequest("post", "/get_storage_state", data);
|
|
292
|
+
return response.storage_state || "";
|
|
293
|
+
}
|
|
297
294
|
async closeSession() {
|
|
298
295
|
if (!this.sessionId) {
|
|
299
296
|
return;
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * Example function to demonstrate package usage\n * @param name - The name to greet\n * @returns A greeting message\n */\nexport function greet(name: string): string {\n return `Hello, ${name}!`;\n}\n\n// Export other functions and types here \nimport axios from 'axios';\n\n// const BASE_URL = \"https://api.simplex.sh\"\nconst BASE_URL = \"https://simplex-dev-shreya--api-server-fastapi-app.modal.run\"\n\ninterface SessionData {\n [key: string]: any;\n}\n\ninterface PlaywrightClickOptions {\n locator: string;\n locatorType: string;\n exact?: boolean;\n elementIndex?: 'first' | 'last' | 'nth';\n nthIndex?: number;\n locatorOptions?: Record<string, any>;\n}\n\ninterface SimplexResponse {\n succeeded: boolean;\n error?: string;\n session_id?: string;\n livestream_url?: string;\n connect_url?: string;\n element_clicked?: string;\n element_info?: string;\n text?: string;\n image?: string;\n bbox?: any;\n b64?: string;\n filename?: string;\n exists?: boolean;\n reasoning?: string;\n response?: string;\n}\n\nexport class Simplex {\n private apiKey: string;\n private sessionId: string | null = null;\n private connectUrl: string | null = null;\n\n constructor(apiKey: string) {\n this.apiKey = apiKey;\n }\n\n private async makeRequest<T>(\n method: 'get' | 'post',\n endpoint: string,\n data?: any,\n params?: any\n ): Promise<T> {\n try {\n console.log(`Making ${method.toUpperCase()} request to ${endpoint}`);\n \n // Convert data to FormData\n const formData = new FormData();\n if (data) {\n Object.entries(data).forEach(([key, value]) => {\n if (value !== undefined && value !== null) {\n formData.append(key, value.toString());\n }\n });\n }\n\n // console.log('Request data:', Object.fromEntries(formData.entries()));\n \n const response = await axios({\n method,\n url: `${BASE_URL}${endpoint}`,\n data: method === 'post' ? formData : undefined,\n params: method === 'get' ? params : undefined,\n headers: {\n 'x-api-key': this.apiKey,\n ...(method === 'post' ? { 'Content-Type': 'multipart/form-data' } : {})\n }\n });\n\n // console.log('Response status:', response.status);\n // console.log('Response data:', JSON.stringify(response.data, null, 2));\n\n const responseData = response.data as SimplexResponse;\n \n // Consider response successful if:\n // 1. It has succeeded: true, or\n // 2. It's a create_session response with a session_id\n // Check if 'succeeded' property exists in responseData\n // console.log('Response data:', responseData);\n\n if (endpoint == \"/hover\" || endpoint == \"/scroll_to_element\") {\n if (!('succeeded' in responseData)) {\n console.error(\"Response data missing 'succeeded' property:\", responseData);\n throw new Error(\"Invalid API response: missing 'succeeded' property\");\n } else {\n if (responseData.succeeded) {\n return responseData as T;\n } else {\n throw new Error(responseData.error || 'Request failed');\n }\n }\n }\n\n if (endpoint == \"/goto\") {\n if (!('succeeded' in responseData)) {\n console.error('Response data missing \"succeeded\" property:', responseData);\n throw new Error('Invalid API response: missing \"succeeded\" property');\n } else {\n return responseData as T;\n }\n }\n\n if (endpoint == \"/get_network_response\") {\n if (!('status' in responseData)) {\n console.error('Response data missing \"status\" property:', responseData);\n throw new Error('Invalid API response: missing \"status\" property');\n } else if (responseData.status == \"success\") {\n return responseData as T;\n } else {\n throw new Error('Failed to get network response');\n }\n }\n\n if (!responseData.succeeded && !(endpoint === '/create_session' && responseData.session_id)) {\n const errorMessage = responseData.error || 'Request failed';\n console.error('API request failed:', errorMessage);\n throw new Error(errorMessage);\n }\n return responseData as T;\n } catch (error) {\n if (axios.isAxiosError(error)) {\n const errorMessage = error.response?.data?.error || error.message;\n console.error('Axios error:', {\n status: error.response?.status,\n statusText: error.response?.statusText,\n data: error.response?.data,\n message: errorMessage\n });\n throw new Error(`Request failed: ${errorMessage}`);\n }\n console.error('Unexpected error:', error);\n throw error;\n }\n }\n\n async createSession(\n showInConsole: boolean = true,\n proxies: boolean = true,\n workflowName?: string,\n sessionData?: SessionData | string\n ): Promise<[string, string]> {\n const data: any = {\n proxies,\n workflow_name: workflowName\n };\n\n if (this.sessionId) {\n throw new Error(\"A session is already active. Please close the current session before creating a new one.\");\n }\n if (sessionData) {\n if (typeof sessionData === 'string') {\n try {\n data.session_data = JSON.stringify(JSON.parse(sessionData));\n } catch {\n // If parsing fails, treat as file path\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n }\n } else {\n data.session_data = JSON.stringify(sessionData);\n }\n }\n\n const response = await this.makeRequest<SimplexResponse>('post', '/create_session', data);\n \n if (!response.session_id) {\n throw new Error('Session creation failed: No session ID returned');\n }\n\n this.sessionId = response.session_id;\n this.connectUrl = response.connect_url || null;\n\n if (showInConsole && response.livestream_url) {\n console.log(`Livestream URL: ${response.livestream_url}`);\n }\n\n return [response.session_id, response.livestream_url || ''];\n }\n\n async goto(url: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling goto with url='${url}'`);\n }\n\n if (!url.startsWith('http://') && !url.startsWith('https://')) {\n url = 'https://' + url;\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/goto', data);\n }\n\n async click(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling click with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click', data);\n return response.element_clicked || '';\n }\n\n async scrollToElement(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scrollToElement with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/scroll_to_element', data);\n return response.element_info || '';\n }\n\n async hover(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/hover', data);\n return response.element_info || '';\n }\n\n async type(text: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling type with text='${text}'`);\n }\n\n const data = {\n text,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/type', data);\n }\n\n async pressEnter(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressEnter');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_enter', data);\n }\n\n async pressTab(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressTab');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_tab', data);\n }\n\n async deleteText(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling deleteText');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/delete_text', data);\n }\n\n async extractBbox(elementDescription: string, cdpUrl?: string): Promise<any> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractBbox with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-bbox', undefined, params);\n return response.bbox;\n }\n\n async extractText(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractText with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/extract-text', data);\n return response.text || '';\n }\n\n async extractImage(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractImage with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-image', undefined, params);\n return response.image || '';\n }\n\n async scroll(pixels: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scroll with pixels=${pixels}`);\n }\n\n const data = {\n pixels,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/scroll', data);\n }\n\n async wait(milliseconds: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling wait with milliseconds=${milliseconds}`);\n }\n\n const data = {\n milliseconds,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/wait', data);\n }\n\n async clickAndUpload(\n elementDescription: string,\n filePathOrCallable: string | (() => Blob)\n ): Promise<void> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndUpload with elementDescription='${elementDescription}'`);\n }\n\n if (typeof filePathOrCallable !== 'string' && typeof filePathOrCallable !== 'function') {\n throw new TypeError(`filePathOrCallable must be either a string or a callable, not a ${typeof filePathOrCallable}`);\n }\n\n const formData = new FormData();\n formData.append('element_description', elementDescription);\n formData.append('session_id', this.sessionId);\n\n if (typeof filePathOrCallable === 'string') {\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n } else {\n const blob = filePathOrCallable();\n formData.append('file', blob, 'file'); // Add filename for the blob\n }\n\n await this.makeRequest('post', '/click_and_upload', formData, undefined);\n }\n\n async clickAndDownload(elementDescription: string): Promise<[string, string]> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndDownload with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n session_id: this.sessionId\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click_and_download', data);\n return [response.b64 || '', response.filename || ''];\n }\n\n async exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling exists with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/exists', data);\n return [response.exists || false, response.reasoning || ''];\n }\n\n async getNetworkResponse(url: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getNetworkResponse with url='${url}'`);\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_network_response', data);\n return response.response || '';\n }\n\n async closeSession(): Promise<void> {\n if (!this.sessionId) {\n return;\n }\n\n await this.makeRequest('post', '/close_session', { session_id: this.sessionId });\n this.sessionId = null;\n this.connectUrl = null;\n }\n} "],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * Example function to demonstrate package usage\n * @param name - The name to greet\n * @returns A greeting message\n */\nexport function greet(name: string): string {\n return `Hello, ${name}!`;\n}\n\n// Export other functions and types here \n\nimport axios from 'axios';\n\nconst BASE_URL = \"https://simplex-dev-shreya--api-server-fastapi-app.modal.run\"\n\ninterface SessionData {\n [key: string]: any;\n}\n\ninterface PlaywrightClickOptions {\n locator: string;\n locatorType: string;\n exact?: boolean;\n elementIndex?: 'first' | 'last' | 'nth';\n nthIndex?: number;\n locatorOptions?: Record<string, any>;\n}\n\ninterface SimplexResponse {\n succeeded: boolean;\n error?: string;\n session_id?: string;\n livestream_url?: string;\n connect_url?: string;\n element_clicked?: string;\n element_info?: string;\n text?: string;\n image?: string;\n bbox?: any;\n b64?: string;\n filename?: string;\n exists?: boolean;\n reasoning?: string;\n response?: string;\n url?: string;\n storage_state?: string;\n}\n\nexport class Simplex {\n private apiKey: string;\n private sessionId: string | null = null;\n private connectUrl: string | null = null;\n\n constructor(apiKey: string) {\n this.apiKey = apiKey;\n }\n\n private async makeRequest<T>(\n method: 'get' | 'post',\n endpoint: string,\n data?: any,\n params?: any\n ): Promise<T> {\n try {\n console.log(`Making ${method.toUpperCase()} request to ${endpoint}`);\n \n // Convert data to FormData\n const formData = new FormData();\n if (data) {\n Object.entries(data).forEach(([key, value]) => {\n if (value !== undefined && value !== null) {\n formData.append(key, value.toString());\n }\n });\n }\n\n // console.log('Request data:', Object.fromEntries(formData.entries()));\n \n const response = await axios({\n method,\n url: `${BASE_URL}${endpoint}`,\n data: method === 'post' ? formData : undefined,\n params: method === 'get' ? params : undefined,\n headers: {\n 'x-api-key': this.apiKey,\n ...(method === 'post' ? { 'Content-Type': 'multipart/form-data' } : {})\n }\n });\n\n // console.log('Response status:', response.status);\n // console.log('Response data:', JSON.stringify(response.data, null, 2));\n\n const responseData = response.data as SimplexResponse;\n \n // Consider response successful if:\n // 1. It has succeeded: true, or\n // 2. It's a create_session response with a session_id\n // Check if 'succeeded' property exists in responseData\n // console.log('Response data:', responseData);\n\n\n if (endpoint == \"/goto\" || endpoint == \"/hover\") {\n if (!('succeeded' in responseData)) {\n console.error('Response data missing \"succeeded\" property:', responseData);\n throw new Error('Invalid API response: missing \"succeeded\" property');\n } else {\n return responseData as T;\n }\n }\n\n if (endpoint == \"/get_network_response\") {\n if (!('status' in responseData)) {\n console.error('Response data missing \"status\" property:', responseData);\n throw new Error('Invalid API response: missing \"status\" property');\n } else if (responseData.status == \"success\") {\n return responseData as T;\n } else {\n throw new Error('Failed to get network response');\n }\n }\n\n if (!responseData.succeeded && !(endpoint === '/create_session' && responseData.session_id)) {\n const errorMessage = responseData.error || 'Request failed';\n console.error('API request failed:', errorMessage);\n throw new Error(errorMessage);\n }\n return responseData as T;\n } catch (error) {\n if (axios.isAxiosError(error)) {\n const errorMessage = error.response?.data?.error || error.message;\n console.error('Axios error:', {\n status: error.response?.status,\n statusText: error.response?.statusText,\n data: error.response?.data,\n message: errorMessage\n });\n throw new Error(`Request failed: ${errorMessage}`);\n }\n console.error('Unexpected error:', error);\n throw error;\n }\n }\n\n async createSession(\n showInConsole: boolean = true,\n proxies: boolean = true,\n workflowName?: string,\n sessionData?: SessionData | string\n ): Promise<[string, string]> {\n const data: any = {\n proxies,\n workflow_name: workflowName\n };\n\n if (this.sessionId) {\n throw new Error(\"A session is already active. Please close the current session before creating a new one.\");\n }\n if (sessionData) {\n if (typeof sessionData === 'string') {\n try {\n data.session_data = JSON.stringify(JSON.parse(sessionData));\n } catch {\n // If parsing fails, treat as file path\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n }\n } else {\n data.session_data = JSON.stringify(sessionData);\n }\n }\n\n const response = await this.makeRequest<SimplexResponse>('post', '/create_session', data);\n \n if (!response.session_id) {\n throw new Error('Session creation failed: No session ID returned');\n }\n\n this.sessionId = response.session_id;\n this.connectUrl = response.connect_url || null;\n\n if (showInConsole && response.livestream_url) {\n console.log(`Livestream URL: ${response.livestream_url}`);\n }\n\n return [response.session_id, response.livestream_url || ''];\n }\n\n async goto(url: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling goto with url='${url}'`);\n }\n\n if (!url.startsWith('http://') && !url.startsWith('https://')) {\n url = 'https://' + url;\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/goto', data);\n }\n\n async click(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling click with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click', data);\n return response.element_clicked || '';\n }\n\n async hover(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling hover with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/hover', data);\n return response.element_info || '';\n }\n\n async type(text: string, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling type with text='${text}'`);\n }\n\n const data = {\n text,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/type', data);\n }\n\n async pressEnter(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressEnter');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_enter', data);\n }\n\n async pressTab(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling pressTab');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/press_tab', data);\n }\n\n async deleteText(cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error('Must call createSession before calling deleteText');\n }\n\n const data = cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId };\n await this.makeRequest('post', '/delete_text', data);\n }\n\n async extractBbox(elementDescription: string, cdpUrl?: string): Promise<any> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractBbox with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-bbox', undefined, params);\n return response.bbox;\n }\n\n async extractText(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractText with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/extract-text', data);\n return response.text || '';\n }\n\n async extractImage(elementDescription: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling extractImage with elementDescription='${elementDescription}'`);\n }\n\n const params = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('get', '/extract-image', undefined, params);\n return response.image || '';\n }\n\n async scroll(pixels: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling scroll with pixels=${pixels}`);\n }\n\n const data = {\n pixels,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/scroll', data);\n }\n\n async wait(milliseconds: number, cdpUrl?: string): Promise<void> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling wait with milliseconds=${milliseconds}`);\n }\n\n const data = {\n milliseconds,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n await this.makeRequest('post', '/wait', data);\n }\n\n async clickAndUpload(\n elementDescription: string,\n filePathOrCallable: string | (() => Blob)\n ): Promise<void> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndUpload with elementDescription='${elementDescription}'`);\n }\n\n if (typeof filePathOrCallable !== 'string' && typeof filePathOrCallable !== 'function') {\n throw new TypeError(`filePathOrCallable must be either a string or a callable, not a ${typeof filePathOrCallable}`);\n }\n\n const formData = new FormData();\n formData.append('element_description', elementDescription);\n formData.append('session_id', this.sessionId);\n\n if (typeof filePathOrCallable === 'string') {\n // Note: File system operations are not available in browser environment\n throw new Error('File system operations are not supported in this environment');\n } else {\n const blob = filePathOrCallable();\n formData.append('file', blob, 'file'); // Add filename for the blob\n }\n\n await this.makeRequest('post', '/click_and_upload', formData, undefined);\n }\n\n async clickAndDownload(elementDescription: string): Promise<[string, string]> {\n if (!this.sessionId) {\n throw new Error(`Must call createSession before calling clickAndDownload with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n session_id: this.sessionId\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/click_and_download', data);\n return [response.b64 || '', response.filename || ''];\n }\n\n async exists(elementDescription: string, cdpUrl?: string): Promise<[boolean, string]> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling exists with elementDescription='${elementDescription}'`);\n }\n\n const data = {\n element_description: elementDescription,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/exists', data);\n return [response.exists || false, response.reasoning || ''];\n }\n\n async getNetworkResponse(url: string, cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getNetworkResponse with url='${url}'`);\n }\n\n const data = {\n url,\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_network_response', data);\n return response.response || '';\n }\n\n async getPageURL(cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getPageURL`);\n }\n\n const data = {\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_page_url', data);\n return response.url || '';\n }\n\n async getStorageState(cdpUrl?: string): Promise<string> {\n if (!cdpUrl && !this.sessionId) {\n throw new Error(`Must call createSession before calling getStorageState`);\n }\n \n const data = {\n ...(cdpUrl ? { cdp_url: cdpUrl } : { session_id: this.sessionId })\n };\n\n const response = await this.makeRequest<SimplexResponse>('post', '/get_storage_state', data);\n return response.storage_state || '';\n }\n\n async closeSession(): Promise<void> {\n if (!this.sessionId) {\n return;\n }\n\n await this.makeRequest('post', '/close_session', { session_id: this.sessionId });\n this.sessionId = null;\n this.connectUrl = null;\n }\n} "],"mappings":"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","names":[]}
|