anchorbrowser 0.6.1__py3-none-any.whl → 0.6.2__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.
@@ -9,6 +9,7 @@ import asyncio
9
9
  import inspect
10
10
  import logging
11
11
  import platform
12
+ import warnings
12
13
  import email.utils
13
14
  from types import TracebackType
14
15
  from random import random
@@ -51,9 +52,11 @@ from ._types import (
51
52
  ResponseT,
52
53
  AnyMapping,
53
54
  PostParser,
55
+ BinaryTypes,
54
56
  RequestFiles,
55
57
  HttpxSendArgs,
56
58
  RequestOptions,
59
+ AsyncBinaryTypes,
57
60
  HttpxRequestFiles,
58
61
  ModelBuilderProtocol,
59
62
  not_given,
@@ -477,8 +480,19 @@ class BaseClient(Generic[_HttpxClientT, _DefaultStreamT]):
477
480
  retries_taken: int = 0,
478
481
  ) -> httpx.Request:
479
482
  if log.isEnabledFor(logging.DEBUG):
480
- log.debug("Request options: %s", model_dump(options, exclude_unset=True))
481
-
483
+ log.debug(
484
+ "Request options: %s",
485
+ model_dump(
486
+ options,
487
+ exclude_unset=True,
488
+ # Pydantic v1 can't dump every type we support in content, so we exclude it for now.
489
+ exclude={
490
+ "content",
491
+ }
492
+ if PYDANTIC_V1
493
+ else {},
494
+ ),
495
+ )
482
496
  kwargs: dict[str, Any] = {}
483
497
 
484
498
  json_data = options.json_data
@@ -532,7 +546,13 @@ class BaseClient(Generic[_HttpxClientT, _DefaultStreamT]):
532
546
  is_body_allowed = options.method.lower() != "get"
533
547
 
534
548
  if is_body_allowed:
535
- if isinstance(json_data, bytes):
549
+ if options.content is not None and json_data is not None:
550
+ raise TypeError("Passing both `content` and `json_data` is not supported")
551
+ if options.content is not None and files is not None:
552
+ raise TypeError("Passing both `content` and `files` is not supported")
553
+ if options.content is not None:
554
+ kwargs["content"] = options.content
555
+ elif isinstance(json_data, bytes):
536
556
  kwargs["content"] = json_data
537
557
  else:
538
558
  kwargs["json"] = json_data if is_given(json_data) else None
@@ -1194,6 +1214,7 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1194
1214
  *,
1195
1215
  cast_to: Type[ResponseT],
1196
1216
  body: Body | None = None,
1217
+ content: BinaryTypes | None = None,
1197
1218
  options: RequestOptions = {},
1198
1219
  files: RequestFiles | None = None,
1199
1220
  stream: Literal[False] = False,
@@ -1206,6 +1227,7 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1206
1227
  *,
1207
1228
  cast_to: Type[ResponseT],
1208
1229
  body: Body | None = None,
1230
+ content: BinaryTypes | None = None,
1209
1231
  options: RequestOptions = {},
1210
1232
  files: RequestFiles | None = None,
1211
1233
  stream: Literal[True],
@@ -1219,6 +1241,7 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1219
1241
  *,
1220
1242
  cast_to: Type[ResponseT],
1221
1243
  body: Body | None = None,
1244
+ content: BinaryTypes | None = None,
1222
1245
  options: RequestOptions = {},
1223
1246
  files: RequestFiles | None = None,
1224
1247
  stream: bool,
@@ -1231,13 +1254,25 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1231
1254
  *,
1232
1255
  cast_to: Type[ResponseT],
1233
1256
  body: Body | None = None,
1257
+ content: BinaryTypes | None = None,
1234
1258
  options: RequestOptions = {},
1235
1259
  files: RequestFiles | None = None,
1236
1260
  stream: bool = False,
1237
1261
  stream_cls: type[_StreamT] | None = None,
1238
1262
  ) -> ResponseT | _StreamT:
1263
+ if body is not None and content is not None:
1264
+ raise TypeError("Passing both `body` and `content` is not supported")
1265
+ if files is not None and content is not None:
1266
+ raise TypeError("Passing both `files` and `content` is not supported")
1267
+ if isinstance(body, bytes):
1268
+ warnings.warn(
1269
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1270
+ "Please pass raw bytes via the `content` parameter instead.",
1271
+ DeprecationWarning,
1272
+ stacklevel=2,
1273
+ )
1239
1274
  opts = FinalRequestOptions.construct(
1240
- method="post", url=path, json_data=body, files=to_httpx_files(files), **options
1275
+ method="post", url=path, json_data=body, content=content, files=to_httpx_files(files), **options
1241
1276
  )
1242
1277
  return cast(ResponseT, self.request(cast_to, opts, stream=stream, stream_cls=stream_cls))
1243
1278
 
@@ -1247,11 +1282,23 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1247
1282
  *,
1248
1283
  cast_to: Type[ResponseT],
1249
1284
  body: Body | None = None,
1285
+ content: BinaryTypes | None = None,
1250
1286
  files: RequestFiles | None = None,
1251
1287
  options: RequestOptions = {},
1252
1288
  ) -> ResponseT:
1289
+ if body is not None and content is not None:
1290
+ raise TypeError("Passing both `body` and `content` is not supported")
1291
+ if files is not None and content is not None:
1292
+ raise TypeError("Passing both `files` and `content` is not supported")
1293
+ if isinstance(body, bytes):
1294
+ warnings.warn(
1295
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1296
+ "Please pass raw bytes via the `content` parameter instead.",
1297
+ DeprecationWarning,
1298
+ stacklevel=2,
1299
+ )
1253
1300
  opts = FinalRequestOptions.construct(
1254
- method="patch", url=path, json_data=body, files=to_httpx_files(files), **options
1301
+ method="patch", url=path, json_data=body, content=content, files=to_httpx_files(files), **options
1255
1302
  )
1256
1303
  return self.request(cast_to, opts)
1257
1304
 
@@ -1261,11 +1308,23 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1261
1308
  *,
1262
1309
  cast_to: Type[ResponseT],
1263
1310
  body: Body | None = None,
1311
+ content: BinaryTypes | None = None,
1264
1312
  files: RequestFiles | None = None,
1265
1313
  options: RequestOptions = {},
1266
1314
  ) -> ResponseT:
1315
+ if body is not None and content is not None:
1316
+ raise TypeError("Passing both `body` and `content` is not supported")
1317
+ if files is not None and content is not None:
1318
+ raise TypeError("Passing both `files` and `content` is not supported")
1319
+ if isinstance(body, bytes):
1320
+ warnings.warn(
1321
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1322
+ "Please pass raw bytes via the `content` parameter instead.",
1323
+ DeprecationWarning,
1324
+ stacklevel=2,
1325
+ )
1267
1326
  opts = FinalRequestOptions.construct(
1268
- method="put", url=path, json_data=body, files=to_httpx_files(files), **options
1327
+ method="put", url=path, json_data=body, content=content, files=to_httpx_files(files), **options
1269
1328
  )
1270
1329
  return self.request(cast_to, opts)
1271
1330
 
@@ -1275,9 +1334,19 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1275
1334
  *,
1276
1335
  cast_to: Type[ResponseT],
1277
1336
  body: Body | None = None,
1337
+ content: BinaryTypes | None = None,
1278
1338
  options: RequestOptions = {},
1279
1339
  ) -> ResponseT:
1280
- opts = FinalRequestOptions.construct(method="delete", url=path, json_data=body, **options)
1340
+ if body is not None and content is not None:
1341
+ raise TypeError("Passing both `body` and `content` is not supported")
1342
+ if isinstance(body, bytes):
1343
+ warnings.warn(
1344
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1345
+ "Please pass raw bytes via the `content` parameter instead.",
1346
+ DeprecationWarning,
1347
+ stacklevel=2,
1348
+ )
1349
+ opts = FinalRequestOptions.construct(method="delete", url=path, json_data=body, content=content, **options)
1281
1350
  return self.request(cast_to, opts)
1282
1351
 
1283
1352
  def get_api_list(
@@ -1717,6 +1786,7 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1717
1786
  *,
1718
1787
  cast_to: Type[ResponseT],
1719
1788
  body: Body | None = None,
1789
+ content: AsyncBinaryTypes | None = None,
1720
1790
  files: RequestFiles | None = None,
1721
1791
  options: RequestOptions = {},
1722
1792
  stream: Literal[False] = False,
@@ -1729,6 +1799,7 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1729
1799
  *,
1730
1800
  cast_to: Type[ResponseT],
1731
1801
  body: Body | None = None,
1802
+ content: AsyncBinaryTypes | None = None,
1732
1803
  files: RequestFiles | None = None,
1733
1804
  options: RequestOptions = {},
1734
1805
  stream: Literal[True],
@@ -1742,6 +1813,7 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1742
1813
  *,
1743
1814
  cast_to: Type[ResponseT],
1744
1815
  body: Body | None = None,
1816
+ content: AsyncBinaryTypes | None = None,
1745
1817
  files: RequestFiles | None = None,
1746
1818
  options: RequestOptions = {},
1747
1819
  stream: bool,
@@ -1754,13 +1826,25 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1754
1826
  *,
1755
1827
  cast_to: Type[ResponseT],
1756
1828
  body: Body | None = None,
1829
+ content: AsyncBinaryTypes | None = None,
1757
1830
  files: RequestFiles | None = None,
1758
1831
  options: RequestOptions = {},
1759
1832
  stream: bool = False,
1760
1833
  stream_cls: type[_AsyncStreamT] | None = None,
1761
1834
  ) -> ResponseT | _AsyncStreamT:
1835
+ if body is not None and content is not None:
1836
+ raise TypeError("Passing both `body` and `content` is not supported")
1837
+ if files is not None and content is not None:
1838
+ raise TypeError("Passing both `files` and `content` is not supported")
1839
+ if isinstance(body, bytes):
1840
+ warnings.warn(
1841
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1842
+ "Please pass raw bytes via the `content` parameter instead.",
1843
+ DeprecationWarning,
1844
+ stacklevel=2,
1845
+ )
1762
1846
  opts = FinalRequestOptions.construct(
1763
- method="post", url=path, json_data=body, files=await async_to_httpx_files(files), **options
1847
+ method="post", url=path, json_data=body, content=content, files=await async_to_httpx_files(files), **options
1764
1848
  )
1765
1849
  return await self.request(cast_to, opts, stream=stream, stream_cls=stream_cls)
1766
1850
 
@@ -1770,11 +1854,28 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1770
1854
  *,
1771
1855
  cast_to: Type[ResponseT],
1772
1856
  body: Body | None = None,
1857
+ content: AsyncBinaryTypes | None = None,
1773
1858
  files: RequestFiles | None = None,
1774
1859
  options: RequestOptions = {},
1775
1860
  ) -> ResponseT:
1861
+ if body is not None and content is not None:
1862
+ raise TypeError("Passing both `body` and `content` is not supported")
1863
+ if files is not None and content is not None:
1864
+ raise TypeError("Passing both `files` and `content` is not supported")
1865
+ if isinstance(body, bytes):
1866
+ warnings.warn(
1867
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1868
+ "Please pass raw bytes via the `content` parameter instead.",
1869
+ DeprecationWarning,
1870
+ stacklevel=2,
1871
+ )
1776
1872
  opts = FinalRequestOptions.construct(
1777
- method="patch", url=path, json_data=body, files=await async_to_httpx_files(files), **options
1873
+ method="patch",
1874
+ url=path,
1875
+ json_data=body,
1876
+ content=content,
1877
+ files=await async_to_httpx_files(files),
1878
+ **options,
1778
1879
  )
1779
1880
  return await self.request(cast_to, opts)
1780
1881
 
@@ -1784,11 +1885,23 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1784
1885
  *,
1785
1886
  cast_to: Type[ResponseT],
1786
1887
  body: Body | None = None,
1888
+ content: AsyncBinaryTypes | None = None,
1787
1889
  files: RequestFiles | None = None,
1788
1890
  options: RequestOptions = {},
1789
1891
  ) -> ResponseT:
1892
+ if body is not None and content is not None:
1893
+ raise TypeError("Passing both `body` and `content` is not supported")
1894
+ if files is not None and content is not None:
1895
+ raise TypeError("Passing both `files` and `content` is not supported")
1896
+ if isinstance(body, bytes):
1897
+ warnings.warn(
1898
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1899
+ "Please pass raw bytes via the `content` parameter instead.",
1900
+ DeprecationWarning,
1901
+ stacklevel=2,
1902
+ )
1790
1903
  opts = FinalRequestOptions.construct(
1791
- method="put", url=path, json_data=body, files=await async_to_httpx_files(files), **options
1904
+ method="put", url=path, json_data=body, content=content, files=await async_to_httpx_files(files), **options
1792
1905
  )
1793
1906
  return await self.request(cast_to, opts)
1794
1907
 
@@ -1798,9 +1911,19 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1798
1911
  *,
1799
1912
  cast_to: Type[ResponseT],
1800
1913
  body: Body | None = None,
1914
+ content: AsyncBinaryTypes | None = None,
1801
1915
  options: RequestOptions = {},
1802
1916
  ) -> ResponseT:
1803
- opts = FinalRequestOptions.construct(method="delete", url=path, json_data=body, **options)
1917
+ if body is not None and content is not None:
1918
+ raise TypeError("Passing both `body` and `content` is not supported")
1919
+ if isinstance(body, bytes):
1920
+ warnings.warn(
1921
+ "Passing raw bytes as `body` is deprecated and will be removed in a future version. "
1922
+ "Please pass raw bytes via the `content` parameter instead.",
1923
+ DeprecationWarning,
1924
+ stacklevel=2,
1925
+ )
1926
+ opts = FinalRequestOptions.construct(method="delete", url=path, json_data=body, content=content, **options)
1804
1927
  return await self.request(cast_to, opts)
1805
1928
 
1806
1929
  def get_api_list(
anchorbrowser/_models.py CHANGED
@@ -3,7 +3,20 @@ from __future__ import annotations
3
3
  import os
4
4
  import inspect
5
5
  import weakref
6
- from typing import TYPE_CHECKING, Any, Type, Union, Generic, TypeVar, Callable, Optional, cast
6
+ from typing import (
7
+ IO,
8
+ TYPE_CHECKING,
9
+ Any,
10
+ Type,
11
+ Union,
12
+ Generic,
13
+ TypeVar,
14
+ Callable,
15
+ Iterable,
16
+ Optional,
17
+ AsyncIterable,
18
+ cast,
19
+ )
7
20
  from datetime import date, datetime
8
21
  from typing_extensions import (
9
22
  List,
@@ -787,6 +800,7 @@ class FinalRequestOptionsInput(TypedDict, total=False):
787
800
  timeout: float | Timeout | None
788
801
  files: HttpxRequestFiles | None
789
802
  idempotency_key: str
803
+ content: Union[bytes, bytearray, IO[bytes], Iterable[bytes], AsyncIterable[bytes], None]
790
804
  json_data: Body
791
805
  extra_json: AnyMapping
792
806
  follow_redirects: bool
@@ -805,6 +819,7 @@ class FinalRequestOptions(pydantic.BaseModel):
805
819
  post_parser: Union[Callable[[Any], Any], NotGiven] = NotGiven()
806
820
  follow_redirects: Union[bool, None] = None
807
821
 
822
+ content: Union[bytes, bytearray, IO[bytes], Iterable[bytes], AsyncIterable[bytes], None] = None
808
823
  # It should be noted that we cannot use `json` here as that would override
809
824
  # a BaseModel method in an incompatible fashion.
810
825
  json_data: Union[Body, None] = None
anchorbrowser/_types.py CHANGED
@@ -13,9 +13,11 @@ from typing import (
13
13
  Mapping,
14
14
  TypeVar,
15
15
  Callable,
16
+ Iterable,
16
17
  Iterator,
17
18
  Optional,
18
19
  Sequence,
20
+ AsyncIterable,
19
21
  )
20
22
  from typing_extensions import (
21
23
  Set,
@@ -56,6 +58,13 @@ if TYPE_CHECKING:
56
58
  else:
57
59
  Base64FileInput = Union[IO[bytes], PathLike]
58
60
  FileContent = Union[IO[bytes], bytes, PathLike] # PathLike is not subscriptable in Python 3.8.
61
+
62
+
63
+ # Used for sending raw binary data / streaming data in request bodies
64
+ # e.g. for file uploads without multipart encoding
65
+ BinaryTypes = Union[bytes, bytearray, IO[bytes], Iterable[bytes]]
66
+ AsyncBinaryTypes = Union[bytes, bytearray, IO[bytes], AsyncIterable[bytes]]
67
+
59
68
  FileTypes = Union[
60
69
  # file (or bytes)
61
70
  FileContent,
anchorbrowser/_version.py CHANGED
@@ -1,4 +1,4 @@
1
1
  # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
3
  __title__ = "anchorbrowser"
4
- __version__ = "0.6.1" # x-release-please-version
4
+ __version__ = "0.6.2" # x-release-please-version
@@ -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.
@@ -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
@@ -198,8 +204,10 @@ class TaskResource(SyncAPIResource):
198
204
  {
199
205
  "task_id": task_id,
200
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
213
  task_run_params.RunExecuteParams,
@@ -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.
@@ -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,8 +397,10 @@ 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
406
  task_run_params.RunExecuteParams,
@@ -26,6 +26,9 @@ class RunExecuteParams(TypedDict, total=False):
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
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: anchorbrowser
3
- Version: 0.6.1
3
+ Version: 0.6.2
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
@@ -1,17 +1,17 @@
1
1
  anchorbrowser/__init__.py,sha256=Wl16NhVAsaRBCpDtHZjZXDY31QMKfCIRNjzJcfb8D9E,2728
2
- anchorbrowser/_base_client.py,sha256=pfPT47zcYQABinhwqxooCtHN3QxePomTWcwdri8YOsA,67254
2
+ anchorbrowser/_base_client.py,sha256=ghFcD3ZWWwVEz34nfpk8S-AEghNchnHdyLpHPUsfSqk,73416
3
3
  anchorbrowser/_client.py,sha256=nFDDwX0r00CnsUvi4dtVLZBXwP2YAvN8AYDiybXkrMc,20277
4
4
  anchorbrowser/_compat.py,sha256=DQBVORjFb33zch24jzkhM14msvnzY7mmSmgDLaVFUM8,6562
5
5
  anchorbrowser/_constants.py,sha256=5PS9gNlT7aVkf5APKjCI8lcWqII_saRiroEzDScVKEU,470
6
6
  anchorbrowser/_exceptions.py,sha256=Qz7WOsYUFZ3bEoN28V-C9Wk-EvYerqP83-fMUINlZKQ,3234
7
7
  anchorbrowser/_files.py,sha256=l2iwVskD9JQ4iZJU9ZcsucF4VBARg5nEFWpiFfPcT-M,3630
8
- anchorbrowser/_models.py,sha256=_qXPD2dQpvS5hqULjyh4V6J6ejhmMMnSkgCZx5BWZYc,31836
8
+ anchorbrowser/_models.py,sha256=r3tGH3RakTyVD_5zppTdpnTQyMvzB8Xg6dH1BlNW9lM,32111
9
9
  anchorbrowser/_qs.py,sha256=craIKyvPktJ94cvf9zn8j8ekG9dWJzhWv0ob34lIOv4,4828
10
10
  anchorbrowser/_resource.py,sha256=7lE1EgpVj5kwckk-27umtigTOf9nKTyRl97cgNwRbRQ,1142
11
11
  anchorbrowser/_response.py,sha256=xsiyWOC8LWW-NvbFtZ-MJD4f7eI9RnivKwtKImZ-8o4,28860
12
12
  anchorbrowser/_streaming.py,sha256=ey2jst1hntYHV6HDiCFfHhWr_dUCSG4dG-VUqQkmCQ4,10249
13
- anchorbrowser/_types.py,sha256=nAsmJDL_VDIWprgQ9LdTLnW1NtUssCOAD8OKIqeaHQ8,7302
14
- anchorbrowser/_version.py,sha256=EtbiLF95cOIdGY8TC00atm4PvxzyBm30f4R4iVK2LSQ,165
13
+ anchorbrowser/_types.py,sha256=QvYWm0TMkfoauZj7cJwLtTrdnHfy0Wl7490nj7RFC9I,7601
14
+ anchorbrowser/_version.py,sha256=QJJ7I00Fc1N0R-EK5AaSKATkS6ckgoiL0yMyXxndjzE,165
15
15
  anchorbrowser/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
16
16
  anchorbrowser/_utils/__init__.py,sha256=7fch0GT9zpNnErbciSpUNa-SjTxxjY6kxHxKMOM4AGs,2305
17
17
  anchorbrowser/_utils/_compat.py,sha256=D8gtAvjJQrDWt9upS0XaG9Rr5l1QhiAx_I_1utT_tt0,1195
@@ -35,7 +35,7 @@ anchorbrowser/resources/events.py,sha256=B6TwziBmOVMjWwoFO7OJR2X_Jt_3jtzNhQg4lgY
35
35
  anchorbrowser/resources/extensions.py,sha256=KWySN-tu8Cxy-LbY3TXLNMPs1s5Hzwwk7Rmr1AYLVeU,15943
36
36
  anchorbrowser/resources/identities.py,sha256=Dm5H4oVpZQVJT2xVocrKaTfd9fUzYFa74uOz6xiX8Fo,23696
37
37
  anchorbrowser/resources/profiles.py,sha256=g6xLjfmdXfRM5QV-N-omShpSPO_jMvRRmxKjOllq5RQ,16206
38
- anchorbrowser/resources/task.py,sha256=mimwjwBWvSDbXUYhjq7fVpbmGbsxDkBVEmxDTHiVeTQ,16580
38
+ anchorbrowser/resources/task.py,sha256=rZm7ngBnq6rmrHL7LbPNoQMXGwYfKZG9uz1RQZ54HGM,17340
39
39
  anchorbrowser/resources/tools.py,sha256=P9PQ8Md08RCCD1l4jbjuo-2C-SKxVPnHBuqkzOKrKjc,26384
40
40
  anchorbrowser/resources/applications/__init__.py,sha256=l-NtHBcE8rngI0MYy5C56dxZxgVx_Jeq3i3TVLpo0Xk,1120
41
41
  anchorbrowser/resources/applications/applications.py,sha256=lhQIjdp0SKYeLkmTau0BLg7t_33ZNSHQ1CUjHUWyAr0,27666
@@ -52,7 +52,6 @@ anchorbrowser/resources/sessions/agent/files.py,sha256=E5pFDXEeaqJAN7DfE774WWJMf
52
52
  anchorbrowser/resources/sessions/recordings/__init__.py,sha256=MRWTb2Kwpc-wGBrcaa5YnTntQ9Z85Zd0McKS5K_mG00,1067
53
53
  anchorbrowser/resources/sessions/recordings/primary.py,sha256=p739aM0tU6CUx2KAgbo2O0oS-5T438Ho7SeUH9eSKXI,6569
54
54
  anchorbrowser/resources/sessions/recordings/recordings.py,sha256=LtaT51hX5GWdl21ypu2SGKzEHJHfsjWhJkqAy_fjWGo,13746
55
- anchorbrowser/resources/task/run.py,sha256=wgh4guYSaeysvEmbnxBZtrrZXTJGv62aiacXPqxM3MU,7919
56
55
  anchorbrowser/types/__init__.py,sha256=_qp2JNZonkiTurIEgiSvkRParlv5mFJArE98rGFV7FE,5052
57
56
  anchorbrowser/types/application_create_identity_token_params.py,sha256=eLDfH8aT1nr_-qW6kmaq_5ilZr1YukWz1JMioShktE8,534
58
57
  anchorbrowser/types/application_create_identity_token_response.py,sha256=P1BrPeb0DlIq8DluP-QxA3WsetpNIM4xgwUV5kqZihM,630
@@ -103,7 +102,7 @@ anchorbrowser/types/task_create_params.py,sha256=3a55Cu-r8fslLooQEsFqcliJBl1_Z9q
103
102
  anchorbrowser/types/task_create_response.py,sha256=zYqfjOnibXTh7TvtPY5_aiXVXMCpK9N6WiO6cllt0Yc,8033
104
103
  anchorbrowser/types/task_list_params.py,sha256=pu0gLGBp5UxKLpbEpSEz-J-kSRrY6VIvzjc-A0sOUFc,328
105
104
  anchorbrowser/types/task_list_response.py,sha256=4hSdAkWJXqMErtqbsuHX4wBuEJywMkvREcSOAkqrr7U,8348
106
- anchorbrowser/types/task_run_params.py,sha256=U-5fDfwftOkHNBbnMDkQTK0qWVpUT4EdEb8O7ug1u8U,6790
105
+ anchorbrowser/types/task_run_params.py,sha256=ahQD5lERBzxWdYY52tI7j2nhvmwXZLjnhiiqE68Dibw,7092
107
106
  anchorbrowser/types/task_run_response.py,sha256=Vy33PwbYTneLeAe0rAi_K6nr4M4uwMg4fzgvf0bBe3w,830
108
107
  anchorbrowser/types/tool_fetch_webpage_params.py,sha256=g_C7tLpyFx4I2r7-iizM7ZiQ71-VfowCj9aufaSHjmg,1181
109
108
  anchorbrowser/types/tool_fetch_webpage_response.py,sha256=hdbrNgPz_LeWa3_aVbtck-n-SRvO4moFDbGoSf_2_tU,210
@@ -142,7 +141,7 @@ anchorbrowser/types/sessions/agent/file_upload_response.py,sha256=9DnqplfvEud89U
142
141
  anchorbrowser/types/sessions/recordings/__init__.py,sha256=OKfJYcKb4NObdiRObqJV_dOyDQ8feXekDUge2o_4pXQ,122
143
142
  anchorbrowser/types/shared/__init__.py,sha256=FQKjY3VDxI8T0feNRazdY5TOqb2KDeEwZaoJjsxuEl4,152
144
143
  anchorbrowser/types/shared/success_response.py,sha256=l9OWrucXoSjBdsx5QKdvBPFtxv8d0YdpYY6iL5cWWuc,314
145
- anchorbrowser-0.6.1.dist-info/METADATA,sha256=DuTT0AdJ03BkVM0mvGTewfi9DQbvwC801yOxz-caFyc,15407
146
- anchorbrowser-0.6.1.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
147
- anchorbrowser-0.6.1.dist-info/licenses/LICENSE,sha256=RDcfjK9SJCPlF8nKJnQ33ZQqG4pFl5sBT9AOoTQXK5Q,11343
148
- anchorbrowser-0.6.1.dist-info/RECORD,,
144
+ anchorbrowser-0.6.2.dist-info/METADATA,sha256=JmppWqN4Vgw7AuAQ0gRoTLShGeWfjpPcjG45YdUDlX4,15407
145
+ anchorbrowser-0.6.2.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
146
+ anchorbrowser-0.6.2.dist-info/licenses/LICENSE,sha256=RDcfjK9SJCPlF8nKJnQ33ZQqG4pFl5sBT9AOoTQXK5Q,11343
147
+ anchorbrowser-0.6.2.dist-info/RECORD,,
@@ -1,217 +0,0 @@
1
- # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- from __future__ import annotations
4
-
5
- from typing import Dict
6
-
7
- import httpx
8
-
9
- from ...types import task_run_params
10
- from ..._types import Body, Omit, Query, Headers, NotGiven, omit, not_given
11
- from ..._utils import maybe_transform, async_maybe_transform
12
- from ..._compat import cached_property
13
- from ..._resource import SyncAPIResource, AsyncAPIResource
14
- from ..._response import (
15
- to_raw_response_wrapper,
16
- to_streamed_response_wrapper,
17
- async_to_raw_response_wrapper,
18
- async_to_streamed_response_wrapper,
19
- )
20
- from ..._base_client import make_request_options
21
- from ...types.task_run_response import RunExecuteResponse
22
-
23
- __all__ = ["RunResource", "AsyncRunResource"]
24
-
25
-
26
- class RunResource(SyncAPIResource):
27
- @cached_property
28
- def with_raw_response(self) -> RunResourceWithRawResponse:
29
- """
30
- This property can be used as a prefix for any HTTP method call to return
31
- the raw response object instead of the parsed content.
32
-
33
- For more information, see https://www.github.com/anchorbrowser/AnchorBrowser-SDK-Python#accessing-raw-response-data-eg-headers
34
- """
35
- return RunResourceWithRawResponse(self)
36
-
37
- @cached_property
38
- def with_streaming_response(self) -> RunResourceWithStreamingResponse:
39
- """
40
- An alternative to `.with_raw_response` that doesn't eagerly read the response body.
41
-
42
- For more information, see https://www.github.com/anchorbrowser/AnchorBrowser-SDK-Python#with_streaming_response
43
- """
44
- return RunResourceWithStreamingResponse(self)
45
-
46
- def execute(
47
- self,
48
- *,
49
- task_id: str,
50
- async_: bool | Omit = omit,
51
- inputs: Dict[str, str] | Omit = omit,
52
- override_browser_configuration: task_run_params.OverrideBrowserConfiguration | Omit = omit,
53
- version: str | Omit = omit,
54
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
55
- # The extra values given here take precedence over values defined on the client or passed to this method.
56
- extra_headers: Headers | None = None,
57
- extra_query: Query | None = None,
58
- extra_body: Body | None = None,
59
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
60
- ) -> RunExecuteResponse:
61
- """Executes a task in a browser session.
62
-
63
- The task can be run with a specific
64
- version or the latest version. Optionally, you can provide an existing session
65
- ID or let the system create a new one.
66
-
67
- Args:
68
- task_id: Task identifier
69
-
70
- async_: Whether to run the task asynchronously.
71
-
72
- inputs: Environment variables for task execution (keys must start with ANCHOR\\__)
73
-
74
- override_browser_configuration: Override browser configuration for this execution
75
-
76
- version: Version to run (draft, latest, or version number)
77
-
78
- extra_headers: Send extra headers
79
-
80
- extra_query: Add additional query parameters to the request
81
-
82
- extra_body: Add additional JSON properties to the request
83
-
84
- timeout: Override the client-level default timeout for this request, in seconds
85
- """
86
- return self._post(
87
- "/v1/task/run",
88
- body=maybe_transform(
89
- {
90
- "task_id": task_id,
91
- "async_": async_,
92
- "inputs": inputs,
93
- "override_browser_configuration": override_browser_configuration,
94
- "version": version,
95
- },
96
- task_run_params.RunExecuteParams,
97
- ),
98
- options=make_request_options(
99
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
100
- ),
101
- cast_to=RunExecuteResponse,
102
- )
103
-
104
-
105
- class AsyncRunResource(AsyncAPIResource):
106
- @cached_property
107
- def with_raw_response(self) -> AsyncRunResourceWithRawResponse:
108
- """
109
- This property can be used as a prefix for any HTTP method call to return
110
- the raw response object instead of the parsed content.
111
-
112
- For more information, see https://www.github.com/anchorbrowser/AnchorBrowser-SDK-Python#accessing-raw-response-data-eg-headers
113
- """
114
- return AsyncRunResourceWithRawResponse(self)
115
-
116
- @cached_property
117
- def with_streaming_response(self) -> AsyncRunResourceWithStreamingResponse:
118
- """
119
- An alternative to `.with_raw_response` that doesn't eagerly read the response body.
120
-
121
- For more information, see https://www.github.com/anchorbrowser/AnchorBrowser-SDK-Python#with_streaming_response
122
- """
123
- return AsyncRunResourceWithStreamingResponse(self)
124
-
125
- async def execute(
126
- self,
127
- *,
128
- task_id: str,
129
- async_: bool | Omit = omit,
130
- inputs: Dict[str, str] | Omit = omit,
131
- override_browser_configuration: task_run_params.OverrideBrowserConfiguration | Omit = omit,
132
- version: str | Omit = omit,
133
- # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
134
- # The extra values given here take precedence over values defined on the client or passed to this method.
135
- extra_headers: Headers | None = None,
136
- extra_query: Query | None = None,
137
- extra_body: Body | None = None,
138
- timeout: float | httpx.Timeout | None | NotGiven = not_given,
139
- ) -> RunExecuteResponse:
140
- """Executes a task in a browser session.
141
-
142
- The task can be run with a specific
143
- version or the latest version. Optionally, you can provide an existing session
144
- ID or let the system create a new one.
145
-
146
- Args:
147
- task_id: Task identifier
148
-
149
- async_: Whether to run the task asynchronously.
150
-
151
- inputs: Environment variables for task execution (keys must start with ANCHOR\\__)
152
-
153
- override_browser_configuration: Override browser configuration for this execution
154
-
155
- version: Version to run (draft, latest, or version number)
156
-
157
- extra_headers: Send extra headers
158
-
159
- extra_query: Add additional query parameters to the request
160
-
161
- extra_body: Add additional JSON properties to the request
162
-
163
- timeout: Override the client-level default timeout for this request, in seconds
164
- """
165
- return await self._post(
166
- "/v1/task/run",
167
- body=await async_maybe_transform(
168
- {
169
- "task_id": task_id,
170
- "async_": async_,
171
- "inputs": inputs,
172
- "override_browser_configuration": override_browser_configuration,
173
- "version": version,
174
- },
175
- task_run_params.RunExecuteParams,
176
- ),
177
- options=make_request_options(
178
- extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
179
- ),
180
- cast_to=RunExecuteResponse,
181
- )
182
-
183
-
184
- class RunResourceWithRawResponse:
185
- def __init__(self, run: RunResource) -> None:
186
- self._run = run
187
-
188
- self.execute = to_raw_response_wrapper(
189
- run.execute,
190
- )
191
-
192
-
193
- class AsyncRunResourceWithRawResponse:
194
- def __init__(self, run: AsyncRunResource) -> None:
195
- self._run = run
196
-
197
- self.execute = async_to_raw_response_wrapper(
198
- run.execute,
199
- )
200
-
201
-
202
- class RunResourceWithStreamingResponse:
203
- def __init__(self, run: RunResource) -> None:
204
- self._run = run
205
-
206
- self.execute = to_streamed_response_wrapper(
207
- run.execute,
208
- )
209
-
210
-
211
- class AsyncRunResourceWithStreamingResponse:
212
- def __init__(self, run: AsyncRunResource) -> None:
213
- self._run = run
214
-
215
- self.execute = async_to_streamed_response_wrapper(
216
- run.execute,
217
- )