SDK: download files (#4196)
This commit is contained in:
committed by
GitHub
parent
b30f3b09c8
commit
4665f8907d
@@ -42,7 +42,10 @@ if typing.TYPE_CHECKING:
|
||||
BitwardenSensitiveInformationParameterYaml,
|
||||
BlockType,
|
||||
BranchCondition,
|
||||
BranchCriteria,
|
||||
BranchConditionCriteria,
|
||||
BranchConditionCriteria_Jinja2Template,
|
||||
BranchConditionYaml,
|
||||
BranchCriteriaYaml,
|
||||
BrowserProfile,
|
||||
BrowserSessionResponse,
|
||||
ClickAction,
|
||||
@@ -63,6 +66,7 @@ if typing.TYPE_CHECKING:
|
||||
CodeBlockParametersItem_Workflow,
|
||||
CodeBlockYaml,
|
||||
ConditionalBlock,
|
||||
ConditionalBlockYaml,
|
||||
ContextParameter,
|
||||
ContextParameterSource,
|
||||
ContextParameterSource_AwsSecret,
|
||||
@@ -172,6 +176,7 @@ if typing.TYPE_CHECKING:
|
||||
ForLoopBlockYamlLoopBlocksItem,
|
||||
ForLoopBlockYamlLoopBlocksItem_Action,
|
||||
ForLoopBlockYamlLoopBlocksItem_Code,
|
||||
ForLoopBlockYamlLoopBlocksItem_Conditional,
|
||||
ForLoopBlockYamlLoopBlocksItem_DownloadToS3,
|
||||
ForLoopBlockYamlLoopBlocksItem_Extraction,
|
||||
ForLoopBlockYamlLoopBlocksItem_FileDownload,
|
||||
@@ -232,6 +237,7 @@ if typing.TYPE_CHECKING:
|
||||
InputOrSelectContext,
|
||||
InputTextAction,
|
||||
InputTextActionData,
|
||||
JinjaBranchCriteria,
|
||||
LocateElementAction,
|
||||
LoginBlock,
|
||||
LoginBlockDataSchema,
|
||||
@@ -431,6 +437,7 @@ if typing.TYPE_CHECKING:
|
||||
WorkflowDefinitionYamlBlocksItem,
|
||||
WorkflowDefinitionYamlBlocksItem_Action,
|
||||
WorkflowDefinitionYamlBlocksItem_Code,
|
||||
WorkflowDefinitionYamlBlocksItem_Conditional,
|
||||
WorkflowDefinitionYamlBlocksItem_DownloadToS3,
|
||||
WorkflowDefinitionYamlBlocksItem_Extraction,
|
||||
WorkflowDefinitionYamlBlocksItem_FileDownload,
|
||||
@@ -523,7 +530,10 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"BitwardenSensitiveInformationParameterYaml": ".types",
|
||||
"BlockType": ".types",
|
||||
"BranchCondition": ".types",
|
||||
"BranchCriteria": ".types",
|
||||
"BranchConditionCriteria": ".types",
|
||||
"BranchConditionCriteria_Jinja2Template": ".types",
|
||||
"BranchConditionYaml": ".types",
|
||||
"BranchCriteriaYaml": ".types",
|
||||
"BrowserProfile": ".types",
|
||||
"BrowserSessionResponse": ".types",
|
||||
"ClickAction": ".types",
|
||||
@@ -544,6 +554,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"CodeBlockParametersItem_Workflow": ".types",
|
||||
"CodeBlockYaml": ".types",
|
||||
"ConditionalBlock": ".types",
|
||||
"ConditionalBlockYaml": ".types",
|
||||
"ConflictError": ".errors",
|
||||
"ContextParameter": ".types",
|
||||
"ContextParameterSource": ".types",
|
||||
@@ -654,6 +665,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"ForLoopBlockYamlLoopBlocksItem": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Action": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Code": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Conditional": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_DownloadToS3": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Extraction": ".types",
|
||||
"ForLoopBlockYamlLoopBlocksItem_FileDownload": ".types",
|
||||
@@ -715,6 +727,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"InputOrSelectContext": ".types",
|
||||
"InputTextAction": ".types",
|
||||
"InputTextActionData": ".types",
|
||||
"JinjaBranchCriteria": ".types",
|
||||
"LocateElementAction": ".types",
|
||||
"LoginBlock": ".types",
|
||||
"LoginBlockDataSchema": ".types",
|
||||
@@ -918,6 +931,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"WorkflowDefinitionYamlBlocksItem": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_Action": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_Code": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_Conditional": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_DownloadToS3": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_Extraction": ".types",
|
||||
"WorkflowDefinitionYamlBlocksItem_FileDownload": ".types",
|
||||
@@ -1031,7 +1045,10 @@ __all__ = [
|
||||
"BitwardenSensitiveInformationParameterYaml",
|
||||
"BlockType",
|
||||
"BranchCondition",
|
||||
"BranchCriteria",
|
||||
"BranchConditionCriteria",
|
||||
"BranchConditionCriteria_Jinja2Template",
|
||||
"BranchConditionYaml",
|
||||
"BranchCriteriaYaml",
|
||||
"BrowserProfile",
|
||||
"BrowserSessionResponse",
|
||||
"ClickAction",
|
||||
@@ -1052,6 +1069,7 @@ __all__ = [
|
||||
"CodeBlockParametersItem_Workflow",
|
||||
"CodeBlockYaml",
|
||||
"ConditionalBlock",
|
||||
"ConditionalBlockYaml",
|
||||
"ConflictError",
|
||||
"ContextParameter",
|
||||
"ContextParameterSource",
|
||||
@@ -1162,6 +1180,7 @@ __all__ = [
|
||||
"ForLoopBlockYamlLoopBlocksItem",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Action",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Code",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Conditional",
|
||||
"ForLoopBlockYamlLoopBlocksItem_DownloadToS3",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Extraction",
|
||||
"ForLoopBlockYamlLoopBlocksItem_FileDownload",
|
||||
@@ -1223,6 +1242,7 @@ __all__ = [
|
||||
"InputOrSelectContext",
|
||||
"InputTextAction",
|
||||
"InputTextActionData",
|
||||
"JinjaBranchCriteria",
|
||||
"LocateElementAction",
|
||||
"LoginBlock",
|
||||
"LoginBlockDataSchema",
|
||||
@@ -1426,6 +1446,7 @@ __all__ = [
|
||||
"WorkflowDefinitionYamlBlocksItem",
|
||||
"WorkflowDefinitionYamlBlocksItem_Action",
|
||||
"WorkflowDefinitionYamlBlocksItem_Code",
|
||||
"WorkflowDefinitionYamlBlocksItem_Conditional",
|
||||
"WorkflowDefinitionYamlBlocksItem_DownloadToS3",
|
||||
"WorkflowDefinitionYamlBlocksItem_Extraction",
|
||||
"WorkflowDefinitionYamlBlocksItem_FileDownload",
|
||||
|
||||
@@ -1391,7 +1391,6 @@ class Skyvern:
|
||||
*,
|
||||
credential_type: SkyvernSchemasRunBlocksCredentialType,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
@@ -1401,6 +1400,7 @@ class Skyvern:
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
credential_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_collection_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_item_id: typing.Optional[str] = OMIT,
|
||||
@@ -1421,13 +1421,10 @@ class Skyvern:
|
||||
Where to get the credential from
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website url
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send login status updates
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
@@ -1453,6 +1450,9 @@ class Skyvern:
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
|
||||
credential_id : typing.Optional[str]
|
||||
ID of the Skyvern credential to use for login.
|
||||
|
||||
@@ -1502,7 +1502,6 @@ class Skyvern:
|
||||
_response = self._raw_client.login(
|
||||
credential_type=credential_type,
|
||||
url=url,
|
||||
prompt=prompt,
|
||||
webhook_url=webhook_url,
|
||||
proxy_location=proxy_location,
|
||||
totp_identifier=totp_identifier,
|
||||
@@ -1512,6 +1511,7 @@ class Skyvern:
|
||||
browser_address=browser_address,
|
||||
extra_http_headers=extra_http_headers,
|
||||
max_screenshot_scrolling_times=max_screenshot_scrolling_times,
|
||||
prompt=prompt,
|
||||
credential_id=credential_id,
|
||||
bitwarden_collection_id=bitwarden_collection_id,
|
||||
bitwarden_item_id=bitwarden_item_id,
|
||||
@@ -1525,6 +1525,115 @@ class Skyvern:
|
||||
)
|
||||
return _response.data
|
||||
|
||||
def file_download(
|
||||
self,
|
||||
*,
|
||||
navigation_goal: str,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
totp_url: typing.Optional[str] = OMIT,
|
||||
browser_session_id: typing.Optional[str] = OMIT,
|
||||
browser_profile_id: typing.Optional[str] = OMIT,
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
download_suffix: typing.Optional[str] = OMIT,
|
||||
download_timeout: typing.Optional[float] = OMIT,
|
||||
max_steps_per_run: typing.Optional[int] = OMIT,
|
||||
parameter_keys: typing.Optional[typing.Sequence[str]] = OMIT,
|
||||
request_options: typing.Optional[RequestOptions] = None,
|
||||
) -> WorkflowRunResponse:
|
||||
"""
|
||||
Download a file from a website by navigating and clicking download buttons
|
||||
|
||||
Parameters
|
||||
----------
|
||||
navigation_goal : str
|
||||
Instructions for navigating to and downloading the file
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
|
||||
totp_identifier : typing.Optional[str]
|
||||
Identifier for TOTP (Time-based One-Time Password) if required
|
||||
|
||||
totp_url : typing.Optional[str]
|
||||
TOTP URL to fetch one-time passwords
|
||||
|
||||
browser_session_id : typing.Optional[str]
|
||||
ID of the browser session to use, which is prefixed by `pbs_` e.g. `pbs_123456`
|
||||
|
||||
browser_profile_id : typing.Optional[str]
|
||||
ID of a browser profile to reuse for this run
|
||||
|
||||
browser_address : typing.Optional[str]
|
||||
The CDP address for the task.
|
||||
|
||||
extra_http_headers : typing.Optional[typing.Dict[str, typing.Optional[str]]]
|
||||
Additional HTTP headers to include in requests
|
||||
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
download_suffix : typing.Optional[str]
|
||||
Suffix or complete filename for the downloaded file
|
||||
|
||||
download_timeout : typing.Optional[float]
|
||||
Timeout in seconds for the download operation
|
||||
|
||||
max_steps_per_run : typing.Optional[int]
|
||||
Maximum number of steps to execute
|
||||
|
||||
parameter_keys : typing.Optional[typing.Sequence[str]]
|
||||
List of parameter keys to use in the workflow
|
||||
|
||||
request_options : typing.Optional[RequestOptions]
|
||||
Request-specific configuration.
|
||||
|
||||
Returns
|
||||
-------
|
||||
WorkflowRunResponse
|
||||
Successful Response
|
||||
|
||||
Examples
|
||||
--------
|
||||
from skyvern import Skyvern
|
||||
|
||||
client = Skyvern(
|
||||
api_key="YOUR_API_KEY",
|
||||
)
|
||||
client.file_download(
|
||||
navigation_goal="navigation_goal",
|
||||
)
|
||||
"""
|
||||
_response = self._raw_client.file_download(
|
||||
navigation_goal=navigation_goal,
|
||||
url=url,
|
||||
webhook_url=webhook_url,
|
||||
proxy_location=proxy_location,
|
||||
totp_identifier=totp_identifier,
|
||||
totp_url=totp_url,
|
||||
browser_session_id=browser_session_id,
|
||||
browser_profile_id=browser_profile_id,
|
||||
browser_address=browser_address,
|
||||
extra_http_headers=extra_http_headers,
|
||||
max_screenshot_scrolling_times=max_screenshot_scrolling_times,
|
||||
download_suffix=download_suffix,
|
||||
download_timeout=download_timeout,
|
||||
max_steps_per_run=max_steps_per_run,
|
||||
parameter_keys=parameter_keys,
|
||||
request_options=request_options,
|
||||
)
|
||||
return _response.data
|
||||
|
||||
def get_scripts(
|
||||
self,
|
||||
*,
|
||||
@@ -3317,7 +3426,6 @@ class AsyncSkyvern:
|
||||
*,
|
||||
credential_type: SkyvernSchemasRunBlocksCredentialType,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
@@ -3327,6 +3435,7 @@ class AsyncSkyvern:
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
credential_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_collection_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_item_id: typing.Optional[str] = OMIT,
|
||||
@@ -3347,13 +3456,10 @@ class AsyncSkyvern:
|
||||
Where to get the credential from
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website url
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send login status updates
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
@@ -3379,6 +3485,9 @@ class AsyncSkyvern:
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
|
||||
credential_id : typing.Optional[str]
|
||||
ID of the Skyvern credential to use for login.
|
||||
|
||||
@@ -3436,7 +3545,6 @@ class AsyncSkyvern:
|
||||
_response = await self._raw_client.login(
|
||||
credential_type=credential_type,
|
||||
url=url,
|
||||
prompt=prompt,
|
||||
webhook_url=webhook_url,
|
||||
proxy_location=proxy_location,
|
||||
totp_identifier=totp_identifier,
|
||||
@@ -3446,6 +3554,7 @@ class AsyncSkyvern:
|
||||
browser_address=browser_address,
|
||||
extra_http_headers=extra_http_headers,
|
||||
max_screenshot_scrolling_times=max_screenshot_scrolling_times,
|
||||
prompt=prompt,
|
||||
credential_id=credential_id,
|
||||
bitwarden_collection_id=bitwarden_collection_id,
|
||||
bitwarden_item_id=bitwarden_item_id,
|
||||
@@ -3459,6 +3568,123 @@ class AsyncSkyvern:
|
||||
)
|
||||
return _response.data
|
||||
|
||||
async def file_download(
|
||||
self,
|
||||
*,
|
||||
navigation_goal: str,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
totp_url: typing.Optional[str] = OMIT,
|
||||
browser_session_id: typing.Optional[str] = OMIT,
|
||||
browser_profile_id: typing.Optional[str] = OMIT,
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
download_suffix: typing.Optional[str] = OMIT,
|
||||
download_timeout: typing.Optional[float] = OMIT,
|
||||
max_steps_per_run: typing.Optional[int] = OMIT,
|
||||
parameter_keys: typing.Optional[typing.Sequence[str]] = OMIT,
|
||||
request_options: typing.Optional[RequestOptions] = None,
|
||||
) -> WorkflowRunResponse:
|
||||
"""
|
||||
Download a file from a website by navigating and clicking download buttons
|
||||
|
||||
Parameters
|
||||
----------
|
||||
navigation_goal : str
|
||||
Instructions for navigating to and downloading the file
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
|
||||
totp_identifier : typing.Optional[str]
|
||||
Identifier for TOTP (Time-based One-Time Password) if required
|
||||
|
||||
totp_url : typing.Optional[str]
|
||||
TOTP URL to fetch one-time passwords
|
||||
|
||||
browser_session_id : typing.Optional[str]
|
||||
ID of the browser session to use, which is prefixed by `pbs_` e.g. `pbs_123456`
|
||||
|
||||
browser_profile_id : typing.Optional[str]
|
||||
ID of a browser profile to reuse for this run
|
||||
|
||||
browser_address : typing.Optional[str]
|
||||
The CDP address for the task.
|
||||
|
||||
extra_http_headers : typing.Optional[typing.Dict[str, typing.Optional[str]]]
|
||||
Additional HTTP headers to include in requests
|
||||
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
download_suffix : typing.Optional[str]
|
||||
Suffix or complete filename for the downloaded file
|
||||
|
||||
download_timeout : typing.Optional[float]
|
||||
Timeout in seconds for the download operation
|
||||
|
||||
max_steps_per_run : typing.Optional[int]
|
||||
Maximum number of steps to execute
|
||||
|
||||
parameter_keys : typing.Optional[typing.Sequence[str]]
|
||||
List of parameter keys to use in the workflow
|
||||
|
||||
request_options : typing.Optional[RequestOptions]
|
||||
Request-specific configuration.
|
||||
|
||||
Returns
|
||||
-------
|
||||
WorkflowRunResponse
|
||||
Successful Response
|
||||
|
||||
Examples
|
||||
--------
|
||||
import asyncio
|
||||
|
||||
from skyvern import AsyncSkyvern
|
||||
|
||||
client = AsyncSkyvern(
|
||||
api_key="YOUR_API_KEY",
|
||||
)
|
||||
|
||||
|
||||
async def main() -> None:
|
||||
await client.file_download(
|
||||
navigation_goal="navigation_goal",
|
||||
)
|
||||
|
||||
|
||||
asyncio.run(main())
|
||||
"""
|
||||
_response = await self._raw_client.file_download(
|
||||
navigation_goal=navigation_goal,
|
||||
url=url,
|
||||
webhook_url=webhook_url,
|
||||
proxy_location=proxy_location,
|
||||
totp_identifier=totp_identifier,
|
||||
totp_url=totp_url,
|
||||
browser_session_id=browser_session_id,
|
||||
browser_profile_id=browser_profile_id,
|
||||
browser_address=browser_address,
|
||||
extra_http_headers=extra_http_headers,
|
||||
max_screenshot_scrolling_times=max_screenshot_scrolling_times,
|
||||
download_suffix=download_suffix,
|
||||
download_timeout=download_timeout,
|
||||
max_steps_per_run=max_steps_per_run,
|
||||
parameter_keys=parameter_keys,
|
||||
request_options=request_options,
|
||||
)
|
||||
return _response.data
|
||||
|
||||
async def get_scripts(
|
||||
self,
|
||||
*,
|
||||
|
||||
@@ -1951,7 +1951,6 @@ class RawSkyvern:
|
||||
*,
|
||||
credential_type: SkyvernSchemasRunBlocksCredentialType,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
@@ -1961,6 +1960,7 @@ class RawSkyvern:
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
credential_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_collection_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_item_id: typing.Optional[str] = OMIT,
|
||||
@@ -1981,13 +1981,10 @@ class RawSkyvern:
|
||||
Where to get the credential from
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website url
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send login status updates
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
@@ -2013,6 +2010,9 @@ class RawSkyvern:
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
|
||||
credential_id : typing.Optional[str]
|
||||
ID of the Skyvern credential to use for login.
|
||||
|
||||
@@ -2052,9 +2052,7 @@ class RawSkyvern:
|
||||
"v1/run/tasks/login",
|
||||
method="POST",
|
||||
json={
|
||||
"credential_type": credential_type,
|
||||
"url": url,
|
||||
"prompt": prompt,
|
||||
"webhook_url": webhook_url,
|
||||
"proxy_location": proxy_location,
|
||||
"totp_identifier": totp_identifier,
|
||||
@@ -2064,6 +2062,8 @@ class RawSkyvern:
|
||||
"browser_address": browser_address,
|
||||
"extra_http_headers": extra_http_headers,
|
||||
"max_screenshot_scrolling_times": max_screenshot_scrolling_times,
|
||||
"credential_type": credential_type,
|
||||
"prompt": prompt,
|
||||
"credential_id": credential_id,
|
||||
"bitwarden_collection_id": bitwarden_collection_id,
|
||||
"bitwarden_item_id": bitwarden_item_id,
|
||||
@@ -2106,6 +2106,136 @@ class RawSkyvern:
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response.text)
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response_json)
|
||||
|
||||
def file_download(
|
||||
self,
|
||||
*,
|
||||
navigation_goal: str,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
totp_url: typing.Optional[str] = OMIT,
|
||||
browser_session_id: typing.Optional[str] = OMIT,
|
||||
browser_profile_id: typing.Optional[str] = OMIT,
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
download_suffix: typing.Optional[str] = OMIT,
|
||||
download_timeout: typing.Optional[float] = OMIT,
|
||||
max_steps_per_run: typing.Optional[int] = OMIT,
|
||||
parameter_keys: typing.Optional[typing.Sequence[str]] = OMIT,
|
||||
request_options: typing.Optional[RequestOptions] = None,
|
||||
) -> HttpResponse[WorkflowRunResponse]:
|
||||
"""
|
||||
Download a file from a website by navigating and clicking download buttons
|
||||
|
||||
Parameters
|
||||
----------
|
||||
navigation_goal : str
|
||||
Instructions for navigating to and downloading the file
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
|
||||
totp_identifier : typing.Optional[str]
|
||||
Identifier for TOTP (Time-based One-Time Password) if required
|
||||
|
||||
totp_url : typing.Optional[str]
|
||||
TOTP URL to fetch one-time passwords
|
||||
|
||||
browser_session_id : typing.Optional[str]
|
||||
ID of the browser session to use, which is prefixed by `pbs_` e.g. `pbs_123456`
|
||||
|
||||
browser_profile_id : typing.Optional[str]
|
||||
ID of a browser profile to reuse for this run
|
||||
|
||||
browser_address : typing.Optional[str]
|
||||
The CDP address for the task.
|
||||
|
||||
extra_http_headers : typing.Optional[typing.Dict[str, typing.Optional[str]]]
|
||||
Additional HTTP headers to include in requests
|
||||
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
download_suffix : typing.Optional[str]
|
||||
Suffix or complete filename for the downloaded file
|
||||
|
||||
download_timeout : typing.Optional[float]
|
||||
Timeout in seconds for the download operation
|
||||
|
||||
max_steps_per_run : typing.Optional[int]
|
||||
Maximum number of steps to execute
|
||||
|
||||
parameter_keys : typing.Optional[typing.Sequence[str]]
|
||||
List of parameter keys to use in the workflow
|
||||
|
||||
request_options : typing.Optional[RequestOptions]
|
||||
Request-specific configuration.
|
||||
|
||||
Returns
|
||||
-------
|
||||
HttpResponse[WorkflowRunResponse]
|
||||
Successful Response
|
||||
"""
|
||||
_response = self._client_wrapper.httpx_client.request(
|
||||
"v1/run/tasks/file_download",
|
||||
method="POST",
|
||||
json={
|
||||
"url": url,
|
||||
"webhook_url": webhook_url,
|
||||
"proxy_location": proxy_location,
|
||||
"totp_identifier": totp_identifier,
|
||||
"totp_url": totp_url,
|
||||
"browser_session_id": browser_session_id,
|
||||
"browser_profile_id": browser_profile_id,
|
||||
"browser_address": browser_address,
|
||||
"extra_http_headers": extra_http_headers,
|
||||
"max_screenshot_scrolling_times": max_screenshot_scrolling_times,
|
||||
"navigation_goal": navigation_goal,
|
||||
"download_suffix": download_suffix,
|
||||
"download_timeout": download_timeout,
|
||||
"max_steps_per_run": max_steps_per_run,
|
||||
"parameter_keys": parameter_keys,
|
||||
},
|
||||
headers={
|
||||
"content-type": "application/json",
|
||||
},
|
||||
request_options=request_options,
|
||||
omit=OMIT,
|
||||
)
|
||||
try:
|
||||
if 200 <= _response.status_code < 300:
|
||||
_data = typing.cast(
|
||||
WorkflowRunResponse,
|
||||
parse_obj_as(
|
||||
type_=WorkflowRunResponse, # type: ignore
|
||||
object_=_response.json(),
|
||||
),
|
||||
)
|
||||
return HttpResponse(response=_response, data=_data)
|
||||
if _response.status_code == 422:
|
||||
raise UnprocessableEntityError(
|
||||
headers=dict(_response.headers),
|
||||
body=typing.cast(
|
||||
typing.Optional[typing.Any],
|
||||
parse_obj_as(
|
||||
type_=typing.Optional[typing.Any], # type: ignore
|
||||
object_=_response.json(),
|
||||
),
|
||||
),
|
||||
)
|
||||
_response_json = _response.json()
|
||||
except JSONDecodeError:
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response.text)
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response_json)
|
||||
|
||||
def get_scripts(
|
||||
self,
|
||||
*,
|
||||
@@ -4342,7 +4472,6 @@ class AsyncRawSkyvern:
|
||||
*,
|
||||
credential_type: SkyvernSchemasRunBlocksCredentialType,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
@@ -4352,6 +4481,7 @@ class AsyncRawSkyvern:
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
prompt: typing.Optional[str] = OMIT,
|
||||
credential_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_collection_id: typing.Optional[str] = OMIT,
|
||||
bitwarden_item_id: typing.Optional[str] = OMIT,
|
||||
@@ -4372,13 +4502,10 @@ class AsyncRawSkyvern:
|
||||
Where to get the credential from
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website url
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send login status updates
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
@@ -4404,6 +4531,9 @@ class AsyncRawSkyvern:
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
prompt : typing.Optional[str]
|
||||
Login instructions. Skyvern has default prompt/instruction for login if this field is not provided.
|
||||
|
||||
credential_id : typing.Optional[str]
|
||||
ID of the Skyvern credential to use for login.
|
||||
|
||||
@@ -4443,9 +4573,7 @@ class AsyncRawSkyvern:
|
||||
"v1/run/tasks/login",
|
||||
method="POST",
|
||||
json={
|
||||
"credential_type": credential_type,
|
||||
"url": url,
|
||||
"prompt": prompt,
|
||||
"webhook_url": webhook_url,
|
||||
"proxy_location": proxy_location,
|
||||
"totp_identifier": totp_identifier,
|
||||
@@ -4455,6 +4583,8 @@ class AsyncRawSkyvern:
|
||||
"browser_address": browser_address,
|
||||
"extra_http_headers": extra_http_headers,
|
||||
"max_screenshot_scrolling_times": max_screenshot_scrolling_times,
|
||||
"credential_type": credential_type,
|
||||
"prompt": prompt,
|
||||
"credential_id": credential_id,
|
||||
"bitwarden_collection_id": bitwarden_collection_id,
|
||||
"bitwarden_item_id": bitwarden_item_id,
|
||||
@@ -4497,6 +4627,136 @@ class AsyncRawSkyvern:
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response.text)
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response_json)
|
||||
|
||||
async def file_download(
|
||||
self,
|
||||
*,
|
||||
navigation_goal: str,
|
||||
url: typing.Optional[str] = OMIT,
|
||||
webhook_url: typing.Optional[str] = OMIT,
|
||||
proxy_location: typing.Optional[ProxyLocation] = OMIT,
|
||||
totp_identifier: typing.Optional[str] = OMIT,
|
||||
totp_url: typing.Optional[str] = OMIT,
|
||||
browser_session_id: typing.Optional[str] = OMIT,
|
||||
browser_profile_id: typing.Optional[str] = OMIT,
|
||||
browser_address: typing.Optional[str] = OMIT,
|
||||
extra_http_headers: typing.Optional[typing.Dict[str, typing.Optional[str]]] = OMIT,
|
||||
max_screenshot_scrolling_times: typing.Optional[int] = OMIT,
|
||||
download_suffix: typing.Optional[str] = OMIT,
|
||||
download_timeout: typing.Optional[float] = OMIT,
|
||||
max_steps_per_run: typing.Optional[int] = OMIT,
|
||||
parameter_keys: typing.Optional[typing.Sequence[str]] = OMIT,
|
||||
request_options: typing.Optional[RequestOptions] = None,
|
||||
) -> AsyncHttpResponse[WorkflowRunResponse]:
|
||||
"""
|
||||
Download a file from a website by navigating and clicking download buttons
|
||||
|
||||
Parameters
|
||||
----------
|
||||
navigation_goal : str
|
||||
Instructions for navigating to and downloading the file
|
||||
|
||||
url : typing.Optional[str]
|
||||
Website URL
|
||||
|
||||
webhook_url : typing.Optional[str]
|
||||
Webhook URL to send status updates
|
||||
|
||||
proxy_location : typing.Optional[ProxyLocation]
|
||||
Proxy location to use
|
||||
|
||||
totp_identifier : typing.Optional[str]
|
||||
Identifier for TOTP (Time-based One-Time Password) if required
|
||||
|
||||
totp_url : typing.Optional[str]
|
||||
TOTP URL to fetch one-time passwords
|
||||
|
||||
browser_session_id : typing.Optional[str]
|
||||
ID of the browser session to use, which is prefixed by `pbs_` e.g. `pbs_123456`
|
||||
|
||||
browser_profile_id : typing.Optional[str]
|
||||
ID of a browser profile to reuse for this run
|
||||
|
||||
browser_address : typing.Optional[str]
|
||||
The CDP address for the task.
|
||||
|
||||
extra_http_headers : typing.Optional[typing.Dict[str, typing.Optional[str]]]
|
||||
Additional HTTP headers to include in requests
|
||||
|
||||
max_screenshot_scrolling_times : typing.Optional[int]
|
||||
Maximum number of times to scroll for screenshots
|
||||
|
||||
download_suffix : typing.Optional[str]
|
||||
Suffix or complete filename for the downloaded file
|
||||
|
||||
download_timeout : typing.Optional[float]
|
||||
Timeout in seconds for the download operation
|
||||
|
||||
max_steps_per_run : typing.Optional[int]
|
||||
Maximum number of steps to execute
|
||||
|
||||
parameter_keys : typing.Optional[typing.Sequence[str]]
|
||||
List of parameter keys to use in the workflow
|
||||
|
||||
request_options : typing.Optional[RequestOptions]
|
||||
Request-specific configuration.
|
||||
|
||||
Returns
|
||||
-------
|
||||
AsyncHttpResponse[WorkflowRunResponse]
|
||||
Successful Response
|
||||
"""
|
||||
_response = await self._client_wrapper.httpx_client.request(
|
||||
"v1/run/tasks/file_download",
|
||||
method="POST",
|
||||
json={
|
||||
"url": url,
|
||||
"webhook_url": webhook_url,
|
||||
"proxy_location": proxy_location,
|
||||
"totp_identifier": totp_identifier,
|
||||
"totp_url": totp_url,
|
||||
"browser_session_id": browser_session_id,
|
||||
"browser_profile_id": browser_profile_id,
|
||||
"browser_address": browser_address,
|
||||
"extra_http_headers": extra_http_headers,
|
||||
"max_screenshot_scrolling_times": max_screenshot_scrolling_times,
|
||||
"navigation_goal": navigation_goal,
|
||||
"download_suffix": download_suffix,
|
||||
"download_timeout": download_timeout,
|
||||
"max_steps_per_run": max_steps_per_run,
|
||||
"parameter_keys": parameter_keys,
|
||||
},
|
||||
headers={
|
||||
"content-type": "application/json",
|
||||
},
|
||||
request_options=request_options,
|
||||
omit=OMIT,
|
||||
)
|
||||
try:
|
||||
if 200 <= _response.status_code < 300:
|
||||
_data = typing.cast(
|
||||
WorkflowRunResponse,
|
||||
parse_obj_as(
|
||||
type_=WorkflowRunResponse, # type: ignore
|
||||
object_=_response.json(),
|
||||
),
|
||||
)
|
||||
return AsyncHttpResponse(response=_response, data=_data)
|
||||
if _response.status_code == 422:
|
||||
raise UnprocessableEntityError(
|
||||
headers=dict(_response.headers),
|
||||
body=typing.cast(
|
||||
typing.Optional[typing.Any],
|
||||
parse_obj_as(
|
||||
type_=typing.Optional[typing.Any], # type: ignore
|
||||
object_=_response.json(),
|
||||
),
|
||||
),
|
||||
)
|
||||
_response_json = _response.json()
|
||||
except JSONDecodeError:
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response.text)
|
||||
raise ApiError(status_code=_response.status_code, headers=dict(_response.headers), body=_response_json)
|
||||
|
||||
async def get_scripts(
|
||||
self,
|
||||
*,
|
||||
|
||||
@@ -43,7 +43,9 @@ if typing.TYPE_CHECKING:
|
||||
from .bitwarden_sensitive_information_parameter_yaml import BitwardenSensitiveInformationParameterYaml
|
||||
from .block_type import BlockType
|
||||
from .branch_condition import BranchCondition
|
||||
from .branch_criteria import BranchCriteria
|
||||
from .branch_condition_criteria import BranchConditionCriteria, BranchConditionCriteria_Jinja2Template
|
||||
from .branch_condition_yaml import BranchConditionYaml
|
||||
from .branch_criteria_yaml import BranchCriteriaYaml
|
||||
from .browser_profile import BrowserProfile
|
||||
from .browser_session_response import BrowserSessionResponse
|
||||
from .click_action import ClickAction
|
||||
@@ -66,6 +68,7 @@ if typing.TYPE_CHECKING:
|
||||
)
|
||||
from .code_block_yaml import CodeBlockYaml
|
||||
from .conditional_block import ConditionalBlock
|
||||
from .conditional_block_yaml import ConditionalBlockYaml
|
||||
from .context_parameter import ContextParameter
|
||||
from .context_parameter_source import (
|
||||
ContextParameterSource,
|
||||
@@ -186,6 +189,7 @@ if typing.TYPE_CHECKING:
|
||||
ForLoopBlockYamlLoopBlocksItem,
|
||||
ForLoopBlockYamlLoopBlocksItem_Action,
|
||||
ForLoopBlockYamlLoopBlocksItem_Code,
|
||||
ForLoopBlockYamlLoopBlocksItem_Conditional,
|
||||
ForLoopBlockYamlLoopBlocksItem_DownloadToS3,
|
||||
ForLoopBlockYamlLoopBlocksItem_Extraction,
|
||||
ForLoopBlockYamlLoopBlocksItem_FileDownload,
|
||||
@@ -253,6 +257,7 @@ if typing.TYPE_CHECKING:
|
||||
from .input_or_select_context import InputOrSelectContext
|
||||
from .input_text_action import InputTextAction
|
||||
from .input_text_action_data import InputTextActionData
|
||||
from .jinja_branch_criteria import JinjaBranchCriteria
|
||||
from .locate_element_action import LocateElementAction
|
||||
from .login_block import LoginBlock
|
||||
from .login_block_data_schema import LoginBlockDataSchema
|
||||
@@ -473,6 +478,7 @@ if typing.TYPE_CHECKING:
|
||||
WorkflowDefinitionYamlBlocksItem,
|
||||
WorkflowDefinitionYamlBlocksItem_Action,
|
||||
WorkflowDefinitionYamlBlocksItem_Code,
|
||||
WorkflowDefinitionYamlBlocksItem_Conditional,
|
||||
WorkflowDefinitionYamlBlocksItem_DownloadToS3,
|
||||
WorkflowDefinitionYamlBlocksItem_Extraction,
|
||||
WorkflowDefinitionYamlBlocksItem_FileDownload,
|
||||
@@ -560,7 +566,10 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"BitwardenSensitiveInformationParameterYaml": ".bitwarden_sensitive_information_parameter_yaml",
|
||||
"BlockType": ".block_type",
|
||||
"BranchCondition": ".branch_condition",
|
||||
"BranchCriteria": ".branch_criteria",
|
||||
"BranchConditionCriteria": ".branch_condition_criteria",
|
||||
"BranchConditionCriteria_Jinja2Template": ".branch_condition_criteria",
|
||||
"BranchConditionYaml": ".branch_condition_yaml",
|
||||
"BranchCriteriaYaml": ".branch_criteria_yaml",
|
||||
"BrowserProfile": ".browser_profile",
|
||||
"BrowserSessionResponse": ".browser_session_response",
|
||||
"ClickAction": ".click_action",
|
||||
@@ -581,6 +590,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"CodeBlockParametersItem_Workflow": ".code_block_parameters_item",
|
||||
"CodeBlockYaml": ".code_block_yaml",
|
||||
"ConditionalBlock": ".conditional_block",
|
||||
"ConditionalBlockYaml": ".conditional_block_yaml",
|
||||
"ContextParameter": ".context_parameter",
|
||||
"ContextParameterSource": ".context_parameter_source",
|
||||
"ContextParameterSource_AwsSecret": ".context_parameter_source",
|
||||
@@ -690,6 +700,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"ForLoopBlockYamlLoopBlocksItem": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Action": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Code": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Conditional": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_DownloadToS3": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Extraction": ".for_loop_block_yaml_loop_blocks_item",
|
||||
"ForLoopBlockYamlLoopBlocksItem_FileDownload": ".for_loop_block_yaml_loop_blocks_item",
|
||||
@@ -750,6 +761,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"InputOrSelectContext": ".input_or_select_context",
|
||||
"InputTextAction": ".input_text_action",
|
||||
"InputTextActionData": ".input_text_action_data",
|
||||
"JinjaBranchCriteria": ".jinja_branch_criteria",
|
||||
"LocateElementAction": ".locate_element_action",
|
||||
"LoginBlock": ".login_block",
|
||||
"LoginBlockDataSchema": ".login_block_data_schema",
|
||||
@@ -949,6 +961,7 @@ _dynamic_imports: typing.Dict[str, str] = {
|
||||
"WorkflowDefinitionYamlBlocksItem": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_Action": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_Code": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_Conditional": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_DownloadToS3": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_Extraction": ".workflow_definition_yaml_blocks_item",
|
||||
"WorkflowDefinitionYamlBlocksItem_FileDownload": ".workflow_definition_yaml_blocks_item",
|
||||
@@ -1057,7 +1070,10 @@ __all__ = [
|
||||
"BitwardenSensitiveInformationParameterYaml",
|
||||
"BlockType",
|
||||
"BranchCondition",
|
||||
"BranchCriteria",
|
||||
"BranchConditionCriteria",
|
||||
"BranchConditionCriteria_Jinja2Template",
|
||||
"BranchConditionYaml",
|
||||
"BranchCriteriaYaml",
|
||||
"BrowserProfile",
|
||||
"BrowserSessionResponse",
|
||||
"ClickAction",
|
||||
@@ -1078,6 +1094,7 @@ __all__ = [
|
||||
"CodeBlockParametersItem_Workflow",
|
||||
"CodeBlockYaml",
|
||||
"ConditionalBlock",
|
||||
"ConditionalBlockYaml",
|
||||
"ContextParameter",
|
||||
"ContextParameterSource",
|
||||
"ContextParameterSource_AwsSecret",
|
||||
@@ -1187,6 +1204,7 @@ __all__ = [
|
||||
"ForLoopBlockYamlLoopBlocksItem",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Action",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Code",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Conditional",
|
||||
"ForLoopBlockYamlLoopBlocksItem_DownloadToS3",
|
||||
"ForLoopBlockYamlLoopBlocksItem_Extraction",
|
||||
"ForLoopBlockYamlLoopBlocksItem_FileDownload",
|
||||
@@ -1247,6 +1265,7 @@ __all__ = [
|
||||
"InputOrSelectContext",
|
||||
"InputTextAction",
|
||||
"InputTextActionData",
|
||||
"JinjaBranchCriteria",
|
||||
"LocateElementAction",
|
||||
"LoginBlock",
|
||||
"LoginBlockDataSchema",
|
||||
@@ -1446,6 +1465,7 @@ __all__ = [
|
||||
"WorkflowDefinitionYamlBlocksItem",
|
||||
"WorkflowDefinitionYamlBlocksItem_Action",
|
||||
"WorkflowDefinitionYamlBlocksItem_Code",
|
||||
"WorkflowDefinitionYamlBlocksItem_Conditional",
|
||||
"WorkflowDefinitionYamlBlocksItem_DownloadToS3",
|
||||
"WorkflowDefinitionYamlBlocksItem_Extraction",
|
||||
"WorkflowDefinitionYamlBlocksItem_FileDownload",
|
||||
|
||||
@@ -4,7 +4,7 @@ import typing
|
||||
|
||||
import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
from .branch_criteria import BranchCriteria
|
||||
from .branch_condition_criteria import BranchConditionCriteria
|
||||
|
||||
|
||||
class BranchCondition(UniversalBaseModel):
|
||||
@@ -12,7 +12,7 @@ class BranchCondition(UniversalBaseModel):
|
||||
Represents a single conditional branch edge within a ConditionalBlock.
|
||||
"""
|
||||
|
||||
criteria: typing.Optional[BranchCriteria] = None
|
||||
criteria: typing.Optional[BranchConditionCriteria] = None
|
||||
next_block_label: typing.Optional[str] = None
|
||||
description: typing.Optional[str] = None
|
||||
is_default: typing.Optional[bool] = None
|
||||
|
||||
26
skyvern/client/types/branch_condition_criteria.py
Normal file
26
skyvern/client/types/branch_condition_criteria.py
Normal file
@@ -0,0 +1,26 @@
|
||||
# This file was auto-generated by Fern from our API Definition.
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
import typing
|
||||
|
||||
import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
|
||||
|
||||
class BranchConditionCriteria_Jinja2Template(UniversalBaseModel):
|
||||
criteria_type: typing.Literal["jinja2_template"] = "jinja2_template"
|
||||
expression: str
|
||||
description: typing.Optional[str] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
|
||||
|
||||
BranchConditionCriteria = BranchConditionCriteria_Jinja2Template
|
||||
23
skyvern/client/types/branch_condition_yaml.py
Normal file
23
skyvern/client/types/branch_condition_yaml.py
Normal file
@@ -0,0 +1,23 @@
|
||||
# This file was auto-generated by Fern from our API Definition.
|
||||
|
||||
import typing
|
||||
|
||||
import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
from .branch_criteria_yaml import BranchCriteriaYaml
|
||||
|
||||
|
||||
class BranchConditionYaml(UniversalBaseModel):
|
||||
criteria: typing.Optional[BranchCriteriaYaml] = None
|
||||
next_block_label: typing.Optional[str] = None
|
||||
description: typing.Optional[str] = None
|
||||
is_default: typing.Optional[bool] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
21
skyvern/client/types/branch_criteria_yaml.py
Normal file
21
skyvern/client/types/branch_criteria_yaml.py
Normal file
@@ -0,0 +1,21 @@
|
||||
# This file was auto-generated by Fern from our API Definition.
|
||||
|
||||
import typing
|
||||
|
||||
import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
|
||||
|
||||
class BranchCriteriaYaml(UniversalBaseModel):
|
||||
criteria_type: typing.Optional[typing.Literal["jinja2_template"]] = None
|
||||
expression: str
|
||||
description: typing.Optional[str] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
32
skyvern/client/types/conditional_block_yaml.py
Normal file
32
skyvern/client/types/conditional_block_yaml.py
Normal file
@@ -0,0 +1,32 @@
|
||||
# This file was auto-generated by Fern from our API Definition.
|
||||
|
||||
import typing
|
||||
|
||||
import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
from .branch_condition_yaml import BranchConditionYaml
|
||||
|
||||
|
||||
class ConditionalBlockYaml(UniversalBaseModel):
|
||||
label: str = pydantic.Field()
|
||||
"""
|
||||
Author-facing identifier; must be unique per workflow.
|
||||
"""
|
||||
|
||||
next_block_label: typing.Optional[str] = pydantic.Field(default=None)
|
||||
"""
|
||||
Optional pointer to the label of the next block. When omitted, it will default to sequential order. See [[s-4bnl]].
|
||||
"""
|
||||
|
||||
continue_on_failure: typing.Optional[bool] = None
|
||||
model: typing.Optional[typing.Dict[str, typing.Optional[typing.Any]]] = None
|
||||
branch_conditions: typing.Optional[typing.List[BranchConditionYaml]] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
@@ -8,6 +8,7 @@ import pydantic
|
||||
import typing_extensions
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel, update_forward_refs
|
||||
from ..core.serialization import FieldMetadata
|
||||
from .branch_condition_yaml import BranchConditionYaml
|
||||
from .extraction_block_yaml_data_schema import ExtractionBlockYamlDataSchema
|
||||
from .file_storage_type import FileStorageType
|
||||
from .file_type import FileType
|
||||
@@ -524,6 +525,24 @@ class ForLoopBlockYamlLoopBlocksItem_HttpRequest(UniversalBaseModel):
|
||||
extra = pydantic.Extra.allow
|
||||
|
||||
|
||||
class ForLoopBlockYamlLoopBlocksItem_Conditional(UniversalBaseModel):
|
||||
block_type: typing.Literal["conditional"] = "conditional"
|
||||
label: str
|
||||
next_block_label: typing.Optional[str] = None
|
||||
continue_on_failure: typing.Optional[bool] = None
|
||||
model: typing.Optional[typing.Dict[str, typing.Optional[typing.Any]]] = None
|
||||
branch_conditions: typing.Optional[typing.List[BranchConditionYaml]] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
|
||||
|
||||
ForLoopBlockYamlLoopBlocksItem = typing.Union[
|
||||
ForLoopBlockYamlLoopBlocksItem_Task,
|
||||
ForLoopBlockYamlLoopBlocksItem_ForLoop,
|
||||
@@ -546,5 +565,6 @@ ForLoopBlockYamlLoopBlocksItem = typing.Union[
|
||||
ForLoopBlockYamlLoopBlocksItem_PdfParser,
|
||||
ForLoopBlockYamlLoopBlocksItem_TaskV2,
|
||||
ForLoopBlockYamlLoopBlocksItem_HttpRequest,
|
||||
ForLoopBlockYamlLoopBlocksItem_Conditional,
|
||||
]
|
||||
update_forward_refs(ForLoopBlockYamlLoopBlocksItem_ForLoop)
|
||||
|
||||
@@ -6,12 +6,11 @@ import pydantic
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel
|
||||
|
||||
|
||||
class BranchCriteria(UniversalBaseModel):
|
||||
class JinjaBranchCriteria(UniversalBaseModel):
|
||||
"""
|
||||
Abstract interface describing how a branch condition should be evaluated.
|
||||
Jinja2-templated branch criteria (only supported criteria type for now).
|
||||
"""
|
||||
|
||||
criteria_type: str
|
||||
expression: str
|
||||
description: typing.Optional[str] = None
|
||||
|
||||
@@ -8,6 +8,7 @@ import pydantic
|
||||
import typing_extensions
|
||||
from ..core.pydantic_utilities import IS_PYDANTIC_V2, UniversalBaseModel, update_forward_refs
|
||||
from ..core.serialization import FieldMetadata
|
||||
from .branch_condition_yaml import BranchConditionYaml
|
||||
from .extraction_block_yaml_data_schema import ExtractionBlockYamlDataSchema
|
||||
from .file_storage_type import FileStorageType
|
||||
from .file_type import FileType
|
||||
@@ -63,6 +64,24 @@ class WorkflowDefinitionYamlBlocksItem_Code(UniversalBaseModel):
|
||||
extra = pydantic.Extra.allow
|
||||
|
||||
|
||||
class WorkflowDefinitionYamlBlocksItem_Conditional(UniversalBaseModel):
|
||||
block_type: typing.Literal["conditional"] = "conditional"
|
||||
label: str
|
||||
next_block_label: typing.Optional[str] = None
|
||||
continue_on_failure: typing.Optional[bool] = None
|
||||
model: typing.Optional[typing.Dict[str, typing.Optional[typing.Any]]] = None
|
||||
branch_conditions: typing.Optional[typing.List[BranchConditionYaml]] = None
|
||||
|
||||
if IS_PYDANTIC_V2:
|
||||
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow", frozen=True) # type: ignore # Pydantic v2
|
||||
else:
|
||||
|
||||
class Config:
|
||||
frozen = True
|
||||
smart_union = True
|
||||
extra = pydantic.Extra.allow
|
||||
|
||||
|
||||
class WorkflowDefinitionYamlBlocksItem_DownloadToS3(UniversalBaseModel):
|
||||
block_type: typing.Literal["download_to_s3"] = "download_to_s3"
|
||||
label: str
|
||||
@@ -528,6 +547,7 @@ class WorkflowDefinitionYamlBlocksItem_Wait(UniversalBaseModel):
|
||||
WorkflowDefinitionYamlBlocksItem = typing.Union[
|
||||
WorkflowDefinitionYamlBlocksItem_Action,
|
||||
WorkflowDefinitionYamlBlocksItem_Code,
|
||||
WorkflowDefinitionYamlBlocksItem_Conditional,
|
||||
WorkflowDefinitionYamlBlocksItem_DownloadToS3,
|
||||
WorkflowDefinitionYamlBlocksItem_Extraction,
|
||||
WorkflowDefinitionYamlBlocksItem_FileDownload,
|
||||
|
||||
Reference in New Issue
Block a user