anchorbrowser 0.6.1__py3-none-any.whl → 0.7.0__py3-none-any.whl

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.
Files changed (36) hide show
  1. anchorbrowser/_base_client.py +134 -11
  2. anchorbrowser/_client.py +1 -2
  3. anchorbrowser/_models.py +16 -1
  4. anchorbrowser/_types.py +9 -0
  5. anchorbrowser/_version.py +1 -1
  6. anchorbrowser/resources/extensions.py +1 -278
  7. anchorbrowser/resources/sessions/agent/files.py +0 -83
  8. anchorbrowser/resources/sessions/clipboard.py +0 -79
  9. anchorbrowser/resources/sessions/mouse.py +1 -114
  10. anchorbrowser/resources/sessions/recordings/recordings.py +0 -158
  11. anchorbrowser/resources/sessions/sessions.py +0 -246
  12. anchorbrowser/resources/task.py +24 -8
  13. anchorbrowser/types/__init__.py +2 -8
  14. anchorbrowser/types/sessions/__init__.py +0 -5
  15. anchorbrowser/types/sessions/agent/__init__.py +0 -1
  16. anchorbrowser/types/task_run_params.py +8 -2
  17. anchorbrowser/types/task_run_response.py +2 -2
  18. {anchorbrowser-0.6.1.dist-info → anchorbrowser-0.7.0.dist-info}/METADATA +1 -1
  19. {anchorbrowser-0.6.1.dist-info → anchorbrowser-0.7.0.dist-info}/RECORD +21 -36
  20. anchorbrowser/resources/task/run.py +0 -217
  21. anchorbrowser/types/extension_delete_response.py +0 -12
  22. anchorbrowser/types/extension_retrieve_response.py +0 -27
  23. anchorbrowser/types/extension_upload_params.py +0 -17
  24. anchorbrowser/types/extension_upload_response.py +0 -31
  25. anchorbrowser/types/session_copy_response.py +0 -12
  26. anchorbrowser/types/session_list_pages_response.py +0 -25
  27. anchorbrowser/types/session_paste_params.py +0 -12
  28. anchorbrowser/types/session_paste_response.py +0 -11
  29. anchorbrowser/types/sessions/agent/file_list_response.py +0 -32
  30. anchorbrowser/types/sessions/clipboard_get_response.py +0 -16
  31. anchorbrowser/types/sessions/mouse_double_click_params.py +0 -18
  32. anchorbrowser/types/sessions/mouse_double_click_response.py +0 -11
  33. anchorbrowser/types/sessions/recording_pause_response.py +0 -12
  34. anchorbrowser/types/sessions/recording_resume_response.py +0 -12
  35. {anchorbrowser-0.6.1.dist-info → anchorbrowser-0.7.0.dist-info}/WHEEL +0 -0
  36. {anchorbrowser-0.6.1.dist-info → anchorbrowser-0.7.0.dist-info}/licenses/LICENSE +0 -0
@@ -25,7 +25,6 @@ from .mouse import (
25
25
  )
26
26
  from ...types import (
27
27
  session_goto_params,
28
- session_paste_params,
29
28
  session_create_params,
30
29
  session_scroll_params,
31
30
  session_upload_file_params,
@@ -83,14 +82,11 @@ from .recordings.recordings import (
83
82
  RecordingsResourceWithStreamingResponse,
84
83
  AsyncRecordingsResourceWithStreamingResponse,
85
84
  )
86
- from ...types.session_copy_response import SessionCopyResponse
87
85
  from ...types.session_goto_response import SessionGotoResponse
88
- from ...types.session_paste_response import SessionPasteResponse
89
86
  from ...types.session_create_response import SessionCreateResponse
90
87
  from ...types.session_scroll_response import SessionScrollResponse
91
88
  from ...types.shared.success_response import SuccessResponse
92
89
  from ...types.session_retrieve_response import SessionRetrieveResponse
93
- from ...types.session_list_pages_response import SessionListPagesResponse
94
90
  from ...types.session_upload_file_response import SessionUploadFileResponse
95
91
  from ...types.session_drag_and_drop_response import SessionDragAndDropResponse
96
92
  from ...types.session_retrieve_downloads_response import SessionRetrieveDownloadsResponse
@@ -272,39 +268,6 @@ class SessionsResource(SyncAPIResource):
272
268
  cast_to=SuccessResponse,
273
269
  )
274
270
 
275
- def copy(
276
- self,
277
- session_id: str,
278
- *,
279
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
280
- # The extra values given here take precedence over values defined on the client or passed to this method.
281
- extra_headers: Headers | None = None,
282
- extra_query: Query | None = None,
283
- extra_body: Body | None = None,
284
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
285
- ) -> SessionCopyResponse:
286
- """
287
- Copies the currently selected text to the clipboard
288
-
289
- Args:
290
- extra_headers: Send extra headers
291
-
292
- extra_query: Add additional query parameters to the request
293
-
294
- extra_body: Add additional JSON properties to the request
295
-
296
- timeout: Override the client-level default timeout for this request, in seconds
297
- """
298
- if not session_id:
299
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
300
- return self._post(
301
- f"/v1/sessions/{session_id}/copy",
302
- options=make_request_options(
303
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
304
- ),
305
- cast_to=SessionCopyResponse,
306
- )
307
-
308
271
  def drag_and_drop(
309
272
  self,
310
273
  session_id: str,
@@ -400,76 +363,6 @@ class SessionsResource(SyncAPIResource):
400
363
  cast_to=SessionGotoResponse,
401
364
  )
402
365
 
403
- def list_pages(
404
- self,
405
- session_id: str,
406
- *,
407
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
408
- # The extra values given here take precedence over values defined on the client or passed to this method.
409
- extra_headers: Headers | None = None,
410
- extra_query: Query | None = None,
411
- extra_body: Body | None = None,
412
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
413
- ) -> SessionListPagesResponse:
414
- """
415
- Retrieves a list of pages associated with a specific browser session.
416
-
417
- Args:
418
- extra_headers: Send extra headers
419
-
420
- extra_query: Add additional query parameters to the request
421
-
422
- extra_body: Add additional JSON properties to the request
423
-
424
- timeout: Override the client-level default timeout for this request, in seconds
425
- """
426
- if not session_id:
427
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
428
- return self._get(
429
- f"/v1/sessions/{session_id}/pages",
430
- options=make_request_options(
431
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
432
- ),
433
- cast_to=SessionListPagesResponse,
434
- )
435
-
436
- def paste(
437
- self,
438
- session_id: str,
439
- *,
440
- text: str,
441
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
442
- # The extra values given here take precedence over values defined on the client or passed to this method.
443
- extra_headers: Headers | None = None,
444
- extra_query: Query | None = None,
445
- extra_body: Body | None = None,
446
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
447
- ) -> SessionPasteResponse:
448
- """
449
- Pastes text at the current cursor position
450
-
451
- Args:
452
- text: Text to paste
453
-
454
- extra_headers: Send extra headers
455
-
456
- extra_query: Add additional query parameters to the request
457
-
458
- extra_body: Add additional JSON properties to the request
459
-
460
- timeout: Override the client-level default timeout for this request, in seconds
461
- """
462
- if not session_id:
463
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
464
- return self._post(
465
- f"/v1/sessions/{session_id}/paste",
466
- body=maybe_transform({"text": text}, session_paste_params.SessionPasteParams),
467
- options=make_request_options(
468
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
469
- ),
470
- cast_to=SessionPasteResponse,
471
- )
472
-
473
366
  def retrieve_downloads(
474
367
  self,
475
368
  session_id: str,
@@ -824,39 +717,6 @@ class AsyncSessionsResource(AsyncAPIResource):
824
717
  cast_to=SuccessResponse,
825
718
  )
826
719
 
827
- async def copy(
828
- self,
829
- session_id: str,
830
- *,
831
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
832
- # The extra values given here take precedence over values defined on the client or passed to this method.
833
- extra_headers: Headers | None = None,
834
- extra_query: Query | None = None,
835
- extra_body: Body | None = None,
836
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
837
- ) -> SessionCopyResponse:
838
- """
839
- Copies the currently selected text to the clipboard
840
-
841
- Args:
842
- extra_headers: Send extra headers
843
-
844
- extra_query: Add additional query parameters to the request
845
-
846
- extra_body: Add additional JSON properties to the request
847
-
848
- timeout: Override the client-level default timeout for this request, in seconds
849
- """
850
- if not session_id:
851
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
852
- return await self._post(
853
- f"/v1/sessions/{session_id}/copy",
854
- options=make_request_options(
855
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
856
- ),
857
- cast_to=SessionCopyResponse,
858
- )
859
-
860
720
  async def drag_and_drop(
861
721
  self,
862
722
  session_id: str,
@@ -952,76 +812,6 @@ class AsyncSessionsResource(AsyncAPIResource):
952
812
  cast_to=SessionGotoResponse,
953
813
  )
954
814
 
955
- async def list_pages(
956
- self,
957
- session_id: str,
958
- *,
959
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
960
- # The extra values given here take precedence over values defined on the client or passed to this method.
961
- extra_headers: Headers | None = None,
962
- extra_query: Query | None = None,
963
- extra_body: Body | None = None,
964
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
965
- ) -> SessionListPagesResponse:
966
- """
967
- Retrieves a list of pages associated with a specific browser session.
968
-
969
- Args:
970
- extra_headers: Send extra headers
971
-
972
- extra_query: Add additional query parameters to the request
973
-
974
- extra_body: Add additional JSON properties to the request
975
-
976
- timeout: Override the client-level default timeout for this request, in seconds
977
- """
978
- if not session_id:
979
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
980
- return await self._get(
981
- f"/v1/sessions/{session_id}/pages",
982
- options=make_request_options(
983
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
984
- ),
985
- cast_to=SessionListPagesResponse,
986
- )
987
-
988
- async def paste(
989
- self,
990
- session_id: str,
991
- *,
992
- text: str,
993
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
994
- # The extra values given here take precedence over values defined on the client or passed to this method.
995
- extra_headers: Headers | None = None,
996
- extra_query: Query | None = None,
997
- extra_body: Body | None = None,
998
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
999
- ) -> SessionPasteResponse:
1000
- """
1001
- Pastes text at the current cursor position
1002
-
1003
- Args:
1004
- text: Text to paste
1005
-
1006
- extra_headers: Send extra headers
1007
-
1008
- extra_query: Add additional query parameters to the request
1009
-
1010
- extra_body: Add additional JSON properties to the request
1011
-
1012
- timeout: Override the client-level default timeout for this request, in seconds
1013
- """
1014
- if not session_id:
1015
- raise ValueError(f"Expected a non-empty value for `session_id` but received {session_id!r}")
1016
- return await self._post(
1017
- f"/v1/sessions/{session_id}/paste",
1018
- body=await async_maybe_transform({"text": text}, session_paste_params.SessionPasteParams),
1019
- options=make_request_options(
1020
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
1021
- ),
1022
- cast_to=SessionPasteResponse,
1023
- )
1024
-
1025
815
  async def retrieve_downloads(
1026
816
  self,
1027
817
  session_id: str,
@@ -1215,21 +1005,12 @@ class SessionsResourceWithRawResponse:
1215
1005
  self.delete = to_raw_response_wrapper(
1216
1006
  sessions.delete,
1217
1007
  )
1218
- self.copy = to_raw_response_wrapper(
1219
- sessions.copy,
1220
- )
1221
1008
  self.drag_and_drop = to_raw_response_wrapper(
1222
1009
  sessions.drag_and_drop,
1223
1010
  )
1224
1011
  self.goto = to_raw_response_wrapper(
1225
1012
  sessions.goto,
1226
1013
  )
1227
- self.list_pages = to_raw_response_wrapper(
1228
- sessions.list_pages,
1229
- )
1230
- self.paste = to_raw_response_wrapper(
1231
- sessions.paste,
1232
- )
1233
1014
  self.retrieve_downloads = to_raw_response_wrapper(
1234
1015
  sessions.retrieve_downloads,
1235
1016
  )
@@ -1282,21 +1063,12 @@ class AsyncSessionsResourceWithRawResponse:
1282
1063
  self.delete = async_to_raw_response_wrapper(
1283
1064
  sessions.delete,
1284
1065
  )
1285
- self.copy = async_to_raw_response_wrapper(
1286
- sessions.copy,
1287
- )
1288
1066
  self.drag_and_drop = async_to_raw_response_wrapper(
1289
1067
  sessions.drag_and_drop,
1290
1068
  )
1291
1069
  self.goto = async_to_raw_response_wrapper(
1292
1070
  sessions.goto,
1293
1071
  )
1294
- self.list_pages = async_to_raw_response_wrapper(
1295
- sessions.list_pages,
1296
- )
1297
- self.paste = async_to_raw_response_wrapper(
1298
- sessions.paste,
1299
- )
1300
1072
  self.retrieve_downloads = async_to_raw_response_wrapper(
1301
1073
  sessions.retrieve_downloads,
1302
1074
  )
@@ -1348,21 +1120,12 @@ class SessionsResourceWithStreamingResponse:
1348
1120
  self.delete = to_streamed_response_wrapper(
1349
1121
  sessions.delete,
1350
1122
  )
1351
- self.copy = to_streamed_response_wrapper(
1352
- sessions.copy,
1353
- )
1354
1123
  self.drag_and_drop = to_streamed_response_wrapper(
1355
1124
  sessions.drag_and_drop,
1356
1125
  )
1357
1126
  self.goto = to_streamed_response_wrapper(
1358
1127
  sessions.goto,
1359
1128
  )
1360
- self.list_pages = to_streamed_response_wrapper(
1361
- sessions.list_pages,
1362
- )
1363
- self.paste = to_streamed_response_wrapper(
1364
- sessions.paste,
1365
- )
1366
1129
  self.retrieve_downloads = to_streamed_response_wrapper(
1367
1130
  sessions.retrieve_downloads,
1368
1131
  )
@@ -1414,21 +1177,12 @@ class AsyncSessionsResourceWithStreamingResponse:
1414
1177
  self.delete = async_to_streamed_response_wrapper(
1415
1178
  sessions.delete,
1416
1179
  )
1417
- self.copy = async_to_streamed_response_wrapper(
1418
- sessions.copy,
1419
- )
1420
1180
  self.drag_and_drop = async_to_streamed_response_wrapper(
1421
1181
  sessions.drag_and_drop,
1422
1182
  )
1423
1183
  self.goto = async_to_streamed_response_wrapper(
1424
1184
  sessions.goto,
1425
1185
  )
1426
- self.list_pages = async_to_streamed_response_wrapper(
1427
- sessions.list_pages,
1428
- )
1429
- self.paste = async_to_streamed_response_wrapper(
1430
- sessions.paste,
1431
- )
1432
1186
  self.retrieve_downloads = async_to_streamed_response_wrapper(
1433
1187
  sessions.retrieve_downloads,
1434
1188
  )
@@ -19,7 +19,7 @@ from .._response import (
19
19
  async_to_streamed_response_wrapper,
20
20
  )
21
21
  from .._base_client import make_request_options
22
- from ..types.task_run_response import RunExecuteResponse
22
+ from ..types.task_run_response import TaskRunResponse
23
23
  from ..types.task_list_response import TaskListResponse
24
24
  from ..types.task_create_response import TaskCreateResponse
25
25
 
@@ -157,8 +157,10 @@ class TaskResource(SyncAPIResource):
157
157
  *,
158
158
  task_id: str,
159
159
  async_: bool | Omit = omit,
160
+ cleanup_sessions: bool | Omit = omit,
160
161
  inputs: Dict[str, str] | Omit = omit,
161
162
  override_browser_configuration: task_run_params.OverrideBrowserConfiguration | Omit = omit,
163
+ session_id: str | Omit = omit,
162
164
  version: str | Omit = omit,
163
165
  # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
164
166
  # The extra values given here take precedence over values defined on the client or passed to this method.
@@ -166,7 +168,7 @@ class TaskResource(SyncAPIResource):
166
168
  extra_query: Query | None = None,
167
169
  extra_body: Body | None = None,
168
170
  timeout: float | httpx.Timeout | None | NotGiven = not_given,
169
- ) -> RunExecuteResponse:
171
+ ) -> TaskRunResponse:
170
172
  """Executes a task in a browser session.
171
173
 
172
174
  The task can be run with a specific
@@ -178,10 +180,14 @@ class TaskResource(SyncAPIResource):
178
180
 
179
181
  async_: Whether to run the task asynchronously.
180
182
 
183
+ cleanup_sessions: Whether to cleanup browser sessions after task execution. Defaults to true.
184
+
181
185
  inputs: Environment variables for task execution (keys must start with ANCHOR\\__)
182
186
 
183
187
  override_browser_configuration: Override browser configuration for this execution
184
188
 
189
+ session_id: Optional existing browser session ID to use for task execution
190
+
185
191
  version: Version to run (draft, latest, or version number)
186
192
 
187
193
  extra_headers: Send extra headers
@@ -197,17 +203,19 @@ class TaskResource(SyncAPIResource):
197
203
  body=maybe_transform(
198
204
  {
199
205
  "task_id": task_id,
200
- "async_": async_,
206
+ "async": async_,
207
+ "cleanup_sessions": cleanup_sessions,
201
208
  "inputs": inputs,
202
209
  "override_browser_configuration": override_browser_configuration,
210
+ "session_id": session_id,
203
211
  "version": version,
204
212
  },
205
- task_run_params.RunExecuteParams,
213
+ task_run_params.TaskRunParams,
206
214
  ),
207
215
  options=make_request_options(
208
216
  extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
209
217
  ),
210
- cast_to=RunExecuteResponse,
218
+ cast_to=TaskRunResponse,
211
219
  )
212
220
 
213
221
 
@@ -342,8 +350,10 @@ class AsyncTaskResource(AsyncAPIResource):
342
350
  *,
343
351
  task_id: str,
344
352
  async_: bool | Omit = omit,
353
+ cleanup_sessions: bool | Omit = omit,
345
354
  inputs: Dict[str, str] | Omit = omit,
346
355
  override_browser_configuration: task_run_params.OverrideBrowserConfiguration | Omit = omit,
356
+ session_id: str | Omit = omit,
347
357
  version: str | Omit = omit,
348
358
  # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
349
359
  # The extra values given here take precedence over values defined on the client or passed to this method.
@@ -351,7 +361,7 @@ class AsyncTaskResource(AsyncAPIResource):
351
361
  extra_query: Query | None = None,
352
362
  extra_body: Body | None = None,
353
363
  timeout: float | httpx.Timeout | None | NotGiven = not_given,
354
- ) -> RunExecuteResponse:
364
+ ) -> TaskRunResponse:
355
365
  """Executes a task in a browser session.
356
366
 
357
367
  The task can be run with a specific
@@ -363,10 +373,14 @@ class AsyncTaskResource(AsyncAPIResource):
363
373
 
364
374
  async_: Whether to run the task asynchronously.
365
375
 
376
+ cleanup_sessions: Whether to cleanup browser sessions after task execution. Defaults to true.
377
+
366
378
  inputs: Environment variables for task execution (keys must start with ANCHOR\\__)
367
379
 
368
380
  override_browser_configuration: Override browser configuration for this execution
369
381
 
382
+ session_id: Optional existing browser session ID to use for task execution
383
+
370
384
  version: Version to run (draft, latest, or version number)
371
385
 
372
386
  extra_headers: Send extra headers
@@ -383,16 +397,18 @@ class AsyncTaskResource(AsyncAPIResource):
383
397
  {
384
398
  "task_id": task_id,
385
399
  "async": async_,
400
+ "cleanup_sessions": cleanup_sessions,
386
401
  "inputs": inputs,
387
402
  "override_browser_configuration": override_browser_configuration,
403
+ "session_id": session_id,
388
404
  "version": version,
389
405
  },
390
- task_run_params.RunExecuteParams,
406
+ task_run_params.TaskRunParams,
391
407
  ),
392
408
  options=make_request_options(
393
409
  extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
394
410
  ),
395
- cast_to=RunExecuteResponse,
411
+ cast_to=TaskRunResponse,
396
412
  )
397
413
 
398
414
 
@@ -3,28 +3,26 @@
3
3
  from __future__ import annotations
4
4
 
5
5
  from .shared import SuccessResponse as SuccessResponse
6
+ from .task_run_params import TaskRunParams as TaskRunParams
6
7
  from .task_list_params import TaskListParams as TaskListParams
8
+ from .task_run_response import TaskRunResponse as TaskRunResponse
7
9
  from .extension_manifest import ExtensionManifest as ExtensionManifest
8
10
  from .task_create_params import TaskCreateParams as TaskCreateParams
9
11
  from .task_list_response import TaskListResponse as TaskListResponse
10
12
  from .event_signal_params import EventSignalParams as EventSignalParams
11
13
  from .session_goto_params import SessionGotoParams as SessionGotoParams
12
- from .session_paste_params import SessionPasteParams as SessionPasteParams
13
14
  from .task_create_response import TaskCreateResponse as TaskCreateResponse
14
15
  from .event_wait_for_params import EventWaitForParams as EventWaitForParams
15
16
  from .profile_create_params import ProfileCreateParams as ProfileCreateParams
16
17
  from .profile_list_response import ProfileListResponse as ProfileListResponse
17
- from .session_copy_response import SessionCopyResponse as SessionCopyResponse
18
18
  from .session_create_params import SessionCreateParams as SessionCreateParams
19
19
  from .session_goto_response import SessionGotoResponse as SessionGotoResponse
20
20
  from .session_scroll_params import SessionScrollParams as SessionScrollParams
21
21
  from .identity_create_params import IdentityCreateParams as IdentityCreateParams
22
22
  from .identity_update_params import IdentityUpdateParams as IdentityUpdateParams
23
- from .session_paste_response import SessionPasteResponse as SessionPasteResponse
24
23
  from .application_list_params import ApplicationListParams as ApplicationListParams
25
24
  from .event_wait_for_response import EventWaitForResponse as EventWaitForResponse
26
25
  from .extension_list_response import ExtensionListResponse as ExtensionListResponse
27
- from .extension_upload_params import ExtensionUploadParams as ExtensionUploadParams
28
26
  from .session_create_response import SessionCreateResponse as SessionCreateResponse
29
27
  from .session_scroll_response import SessionScrollResponse as SessionScrollResponse
30
28
  from .identity_create_response import IdentityCreateResponse as IdentityCreateResponse
@@ -32,8 +30,6 @@ from .identity_delete_response import IdentityDeleteResponse as IdentityDeleteRe
32
30
  from .identity_update_response import IdentityUpdateResponse as IdentityUpdateResponse
33
31
  from .application_create_params import ApplicationCreateParams as ApplicationCreateParams
34
32
  from .application_list_response import ApplicationListResponse as ApplicationListResponse
35
- from .extension_delete_response import ExtensionDeleteResponse as ExtensionDeleteResponse
36
- from .extension_upload_response import ExtensionUploadResponse as ExtensionUploadResponse
37
33
  from .profile_retrieve_response import ProfileRetrieveResponse as ProfileRetrieveResponse
38
34
  from .session_retrieve_response import SessionRetrieveResponse as SessionRetrieveResponse
39
35
  from .tool_fetch_webpage_params import ToolFetchWebpageParams as ToolFetchWebpageParams
@@ -41,8 +37,6 @@ from .identity_retrieve_response import IdentityRetrieveResponse as IdentityRetr
41
37
  from .session_upload_file_params import SessionUploadFileParams as SessionUploadFileParams
42
38
  from .application_create_response import ApplicationCreateResponse as ApplicationCreateResponse
43
39
  from .application_delete_response import ApplicationDeleteResponse as ApplicationDeleteResponse
44
- from .extension_retrieve_response import ExtensionRetrieveResponse as ExtensionRetrieveResponse
45
- from .session_list_pages_response import SessionListPagesResponse as SessionListPagesResponse
46
40
  from .tool_fetch_webpage_response import ToolFetchWebpageResponse as ToolFetchWebpageResponse
47
41
  from .session_drag_and_drop_params import SessionDragAndDropParams as SessionDragAndDropParams
48
42
  from .session_upload_file_response import SessionUploadFileResponse as SessionUploadFileResponse
@@ -9,13 +9,8 @@ from .mouse_move_response import MouseMoveResponse as MouseMoveResponse
9
9
  from .clipboard_set_params import ClipboardSetParams as ClipboardSetParams
10
10
  from .keyboard_type_params import KeyboardTypeParams as KeyboardTypeParams
11
11
  from .mouse_click_response import MouseClickResponse as MouseClickResponse
12
- from .clipboard_get_response import ClipboardGetResponse as ClipboardGetResponse
13
12
  from .clipboard_set_response import ClipboardSetResponse as ClipboardSetResponse
14
13
  from .keyboard_type_response import KeyboardTypeResponse as KeyboardTypeResponse
15
14
  from .recording_list_response import RecordingListResponse as RecordingListResponse
16
15
  from .keyboard_shortcut_params import KeyboardShortcutParams as KeyboardShortcutParams
17
- from .recording_pause_response import RecordingPauseResponse as RecordingPauseResponse
18
- from .mouse_double_click_params import MouseDoubleClickParams as MouseDoubleClickParams
19
- from .recording_resume_response import RecordingResumeResponse as RecordingResumeResponse
20
16
  from .keyboard_shortcut_response import KeyboardShortcutResponse as KeyboardShortcutResponse
21
- from .mouse_double_click_response import MouseDoubleClickResponse as MouseDoubleClickResponse
@@ -2,6 +2,5 @@
2
2
 
3
3
  from __future__ import annotations
4
4
 
5
- from .file_list_response import FileListResponse as FileListResponse
6
5
  from .file_upload_params import FileUploadParams as FileUploadParams
7
6
  from .file_upload_response import FileUploadResponse as FileUploadResponse
@@ -8,7 +8,7 @@ from typing_extensions import Literal, Required, Annotated, TypeAlias, TypedDict
8
8
  from .._utils import PropertyInfo
9
9
 
10
10
  __all__ = [
11
- "RunExecuteParams",
11
+ "TaskRunParams",
12
12
  "OverrideBrowserConfiguration",
13
13
  "OverrideBrowserConfigurationLiveView",
14
14
  "OverrideBrowserConfigurationProxy",
@@ -19,13 +19,16 @@ __all__ = [
19
19
  ]
20
20
 
21
21
 
22
- class RunExecuteParams(TypedDict, total=False):
22
+ class TaskRunParams(TypedDict, total=False):
23
23
  task_id: Required[Annotated[str, PropertyInfo(alias="taskId")]]
24
24
  """Task identifier"""
25
25
 
26
26
  async_: Annotated[bool, PropertyInfo(alias="async")]
27
27
  """Whether to run the task asynchronously."""
28
28
 
29
+ cleanup_sessions: Annotated[bool, PropertyInfo(alias="cleanupSessions")]
30
+ """Whether to cleanup browser sessions after task execution. Defaults to true."""
31
+
29
32
  inputs: Dict[str, str]
30
33
  """Environment variables for task execution (keys must start with ANCHOR\\__)"""
31
34
 
@@ -34,6 +37,9 @@ class RunExecuteParams(TypedDict, total=False):
34
37
  ]
35
38
  """Override browser configuration for this execution"""
36
39
 
40
+ session_id: Annotated[str, PropertyInfo(alias="sessionId")]
41
+ """Optional existing browser session ID to use for task execution"""
42
+
37
43
  version: str
38
44
  """Version to run (draft, latest, or version number)"""
39
45
 
@@ -8,7 +8,7 @@ from pydantic import Field as FieldInfo
8
8
 
9
9
  from .._models import BaseModel
10
10
 
11
- __all__ = ["RunExecuteResponse", "Data"]
11
+ __all__ = ["TaskRunResponse", "Data"]
12
12
 
13
13
 
14
14
  class Data(BaseModel):
@@ -31,6 +31,6 @@ class Data(BaseModel):
31
31
  """Task execution output"""
32
32
 
33
33
 
34
- class RunExecuteResponse(BaseModel):
34
+ class TaskRunResponse(BaseModel):
35
35
  data: Optional[Data] = None
36
36
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: anchorbrowser
3
- Version: 0.6.1
3
+ Version: 0.7.0
4
4
  Summary: The official Python library for the anchorbrowser API
5
5
  Project-URL: Homepage, https://github.com/anchorbrowser/AnchorBrowser-SDK-Python
6
6
  Project-URL: Repository, https://github.com/anchorbrowser/AnchorBrowser-SDK-Python