gbox_sdk package¶
Subpackages¶
- gbox_sdk.resources package
- gbox_sdk.types package
- Subpackages
- gbox_sdk.types.v1 package
- Subpackages
- Submodules
- gbox_sdk.types.v1.android_box module
- gbox_sdk.types.v1.box_create_android_params module
- gbox_sdk.types.v1.box_create_linux_params module
- gbox_sdk.types.v1.box_execute_commands_params module
- gbox_sdk.types.v1.box_execute_commands_response module
- gbox_sdk.types.v1.box_list_params module
- gbox_sdk.types.v1.box_list_response module
- gbox_sdk.types.v1.box_live_view_url_params module
- gbox_sdk.types.v1.box_live_view_url_response module
- gbox_sdk.types.v1.box_retrieve_response module
- gbox_sdk.types.v1.box_run_code_params module
- gbox_sdk.types.v1.box_run_code_response module
- gbox_sdk.types.v1.box_start_params module
- gbox_sdk.types.v1.box_start_response module
- gbox_sdk.types.v1.box_stop_params module
- gbox_sdk.types.v1.box_stop_response module
- gbox_sdk.types.v1.box_terminate_params module
- gbox_sdk.types.v1.box_web_terminal_url_params module
- gbox_sdk.types.v1.box_web_terminal_url_response module
- gbox_sdk.types.v1.create_box_config_param module
- gbox_sdk.types.v1.linux_box module
- Module contents
- gbox_sdk.types.v1 package
- Module contents
- Subpackages
- gbox_sdk.wrapper package
Module contents¶
- exception gbox_sdk.APIError(message, request, *, body)¶
Bases:
GboxClientError
- body: object | None¶
- message: str¶
- request: httpx.Request¶
- exception gbox_sdk.APIResponseValidationError(response, body, *, message=None)¶
Bases:
APIError
- response: httpx.Response¶
- status_code: int¶
- exception gbox_sdk.APIStatusError(message, *, response, body)¶
Bases:
APIError
Raised when an API response has a status code of 4xx or 5xx.
- response: httpx.Response¶
- status_code: int¶
- exception gbox_sdk.APITimeoutError(request)¶
Bases:
APIConnectionError
- class gbox_sdk.ActionOperator(client, box_id)¶
Bases:
object
Provides high-level action operations for a specific box using the GboxClient.
Methods correspond to various box actions such as click, drag, swipe, type, screenshot, etc.
- ai(body)¶
Perform an AI-powered action on the box.
- Return type:
Union
[AIActionScreenshotResult
,AIActionResult
]
- Args:
body: Either a string instruction or ActionAI parameters.
- Returns:
ActionAIResponse: The response from the AI action.
- click(body)¶
Perform a click action on the box.
- Return type:
- Args:
body (ActionClickParams): Parameters for the click action.
- Returns:
ActionClickResponse: The response from the click action.
- drag(body)¶
Perform a drag action on the box.
- Return type:
- Args:
body (ActionDragParams): Parameters for the drag action.
- Returns:
ActionDragResponse: The response from the drag action.
- move(body)¶
Move an element or pointer on the box.
- Return type:
- Args:
body (ActionMoveParams): Parameters for the move action.
- Returns:
ActionMoveResponse: The response from the move action.
- press_button(body)¶
Simulate a button press on the box.
- Return type:
- Args:
body (ActionPressButtonParams): Parameters for the button press action.
- Returns:
ActionPressButtonResponse: The response from the button press action.
- press_key(body)¶
Simulate a key press on the box.
- Return type:
- Args:
body (ActionPressKeyParams): Parameters for the key press action.
- Returns:
ActionPressKeyResponse: The response from the key press action.
- screen_rotation(body)¶
Rotate the screen of the box.
- Return type:
- Args:
body (ActionScreenRotationParams): Parameters for the screen rotation action.
- Returns:
ActionScreenRotationResponse: The response from the screen rotation action.
- screenshot(body=None)¶
Take a screenshot of the box.
- Return type:
- Args:
- body (Optional[ActionScreenshot]): Parameters for the screenshot action.
If not provided, defaults to base64 output format.
- Returns:
ActionScreenshotResponse: The response containing the screenshot data.
- Examples:
Take a screenshot and return base64 data: >>> response = action_operator.screenshot()
Take a screenshot and save to file: >>> response = action_operator.screenshot({“path”: “/path/to/screenshot.png”})
Take a screenshot with specific format: >>> response = action_operator.screenshot({“output_format”: “base64”})
- scroll(body)¶
Perform a scroll action on the box.
- Return type:
- Args:
body (ActionScrollParams): Parameters for the scroll action.
- Returns:
ActionScrollResponse: The response from the scroll action.
- swipe(body)¶
Perform a swipe action on the box.
- Return type:
- Args:
body (ActionSwipeParams): Parameters for the swipe action.
- Returns:
ActionSwipeResponse: The response from the swipe action.
- touch(body)¶
Simulate a touch action on the box.
- Return type:
- Args:
body (ActionTouchParams): Parameters for the touch action.
- Returns:
ActionTouchResponse: The response from the touch action.
- type(body)¶
Simulate typing text on the box.
- Return type:
- Args:
body (ActionTypeParams): Parameters for the type action.
- Returns:
ActionTypeResponse: The response from the type action.
- class gbox_sdk.ActionScreenshot¶
Bases:
ActionScreenshotParams
Extends ActionScreenshotParams to optionally include a file path for saving the screenshot.
- Attributes:
path (Optional[str]): The file path where the screenshot will be saved.
-
output_format:
Annotated
[Literal
['base64'
,'storageKey'
]]¶
-
path:
Optional
[str
]¶
- class gbox_sdk.AndroidAppOperator(client, box, data)¶
Bases:
object
Operator class for managing a specific Android app within a box.
Provides methods to open, restart, close, list activities, and backup the app.
- Attributes:
client (GboxClient): The API client used for communication. box (AndroidBox): The Android box data object. data (AndroidApp): The app data object.
- backup()¶
Backup the app.
- Return type:
BinaryAPIResponse
- Returns:
BinaryAPIResponse: The backup response containing binary data.
- close()¶
Close the app.
- Return type:
None
- list_activities()¶
List all activities of the app.
- Return type:
- Returns:
AndroidListActivitiesResponse: The response containing the list of activities.
- open(activity_name=None)¶
Open the app, optionally specifying an activity name.
- Return type:
None
- Args:
activity_name (str, optional): The activity name to open. Defaults to None.
- restart(activity_name=None)¶
Restart the app, optionally specifying an activity name.
- Return type:
None
- Args:
activity_name (str, optional): The activity name to restart. Defaults to None.
- class gbox_sdk.AndroidBoxOperator(client, data)¶
Bases:
BaseBox
Operator class for managing Android boxes, providing access to app and package management functionalities.
- Attributes:
app (AndroidAppManager): Manager for Android app operations. pkg (AndroidPkgManager): Manager for Android package operations.
- class gbox_sdk.AndroidPkgOperator(client, box, data)¶
Bases:
object
Operator class for managing a specific Android package within a box.
Provides methods to open, close, restart, list activities, and backup the package.
- Attributes:
client (GboxClient): The API client used for communication. box (AndroidBox): The Android box data object. data (AndroidGetResponse): The package data object.
- backup()¶
Backup the package.
- Return type:
BinaryAPIResponse
- Returns:
BinaryAPIResponse: The backup response containing binary data.
- close()¶
Close the package.
- Return type:
None
- list_activities()¶
List all activities of the package.
- Return type:
- Returns:
AndroidListActivitiesResponse: The response containing the list of activities.
- open(activity_name=None)¶
Open the package, optionally specifying an activity name.
- Return type:
None
- Args:
activity_name (str, optional): The activity name to open. Defaults to None.
- restart(activity_name=None)¶
Restart the package, optionally specifying an activity name.
- Return type:
None
- Args:
activity_name (str, optional): The activity name to restart. Defaults to None.
- gbox_sdk.AsyncClient¶
alias of
AsyncGboxClient
- class gbox_sdk.AsyncGboxClient(*, api_key=None, environment=NOT_GIVEN, base_url=NOT_GIVEN, timeout=NOT_GIVEN, max_retries=0, default_headers=None, default_query=None, http_client=None, _strict_response_validation=False)¶
Bases:
AsyncAPIClient
- api_key: str¶
- property auth_headers: dict[str, str]¶
- copy(*, api_key=None, environment=None, base_url=None, timeout=NOT_GIVEN, http_client=None, max_retries=NOT_GIVEN, default_headers=None, set_default_headers=None, default_query=None, set_default_query=None, _extra_kwargs={})¶
Create a new client instance re-using the same options given to the current client with optional overriding.
- Return type:
Self
- property qs: Querystring¶
- v1: v1.AsyncV1Resource¶
- with_options(*, api_key=None, environment=None, base_url=None, timeout=NOT_GIVEN, http_client=None, max_retries=NOT_GIVEN, default_headers=None, set_default_headers=None, default_query=None, set_default_query=None, _extra_kwargs={})¶
Create a new client instance re-using the same options given to the current client with optional overriding.
- Return type:
Self
- with_raw_response: AsyncGboxClientWithRawResponse¶
- with_streaming_response: AsyncGboxClientWithStreamedResponse¶
- class gbox_sdk.AsyncStream(*, cast_to, response, client)¶
Bases:
Generic
[_T
]Provides the core interface to iterate over an asynchronous stream response.
- async close()¶
Close the response and release the connection.
Automatically called if the response body is read to completion.
- Return type:
None
- response: httpx.Response¶
- exception gbox_sdk.AuthenticationError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[401] = 401¶
- exception gbox_sdk.BadRequestError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[400] = 400¶
- class gbox_sdk.BaseBox(client, data)¶
Bases:
object
Base class for box operations, providing common interfaces for box lifecycle and actions.
- Attributes:
client (GboxClient): The Gbox client instance used for API calls. data (Union[LinuxBox, AndroidBox]): The box data object. action (ActionOperator): Operator for box actions. fs (FileSystemOperator): Operator for file system actions. browser (BrowserOperator): Operator for browser actions.
- command(body)¶
Execute shell commands in the box.
- Return type:
- Args:
body (Union[BoxExecuteCommandsParams, str, List[str]]): The commands to execute or parameters object.
- Returns:
BoxExecuteCommandsResponse: The response containing the command execution result.
- live_view(body=None)¶
Get the live view URL for the box.
- Return type:
- Args:
body (BoxLiveViewURLParams): Parameters for live view URL.
- Returns:
BoxLiveViewURLResponse: The response containing the live view URL.
- run_code(body)¶
Run code in the box.
- Return type:
- Args:
body (Union[BoxRunCodeParams, str]): The code to run or parameters object.
- Returns:
BoxRunCodeResponse: The response containing the code execution result.
- start(body=None)¶
Start the box.
- Return type:
Self
- Args:
body (Optional[BoxStartParams]): Parameters for starting the box.
- Returns:
Self: The updated box instance for method chaining.
- stop(body=None)¶
Stop the box.
- Return type:
Self
- Args:
body (Optional[BoxStopParams]): Parameters for stopping the box.
- Returns:
Self: The updated box instance for method chaining.
- terminate(body=None)¶
Terminate the box.
- Return type:
Self
- Args:
body (Optional[BoxTerminateParams]): Parameters for terminating the box.
- Returns:
Self: The updated box instance for method chaining.
- web_terminal(body=None)¶
Get the web terminal URL for the box.
- Return type:
- Args:
body (BoxWebTerminalURLParams): Parameters for web terminal URL.
- Returns:
BoxWebTerminalURLResponse: The response containing the web terminal URL.
- class gbox_sdk.BaseModel(**data)¶
Bases:
BaseModel
- classmethod construct(_fields_set=None, **values)¶
- Return type:
TypeVar
(ModelT
, bound=BaseModel
)
- model_config: ClassVar[ConfigDict] = {'defer_build': True, 'extra': 'allow'}¶
Configuration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].
- classmethod model_construct(_fields_set=None, **values)¶
Creates a new instance of the Model class with validated data.
Creates a new model setting __dict__ and __pydantic_fields_set__ from trusted or pre-validated data. Default values are respected, but no other validation is performed.
- Return type:
TypeVar
(ModelT
, bound=BaseModel
)
- !!! note
model_construct() generally respects the model_config.extra setting on the provided model. That is, if model_config.extra == ‘allow’, then all extra passed values are added to the model instance’s __dict__ and __pydantic_extra__ fields. If model_config.extra == ‘ignore’ (the default), then all extra passed values are ignored. Because no validation is performed with a call to model_construct(), having model_config.extra == ‘forbid’ does not result in an error if extra values are passed, but they will be ignored.
- Args:
- _fields_set: A set of field names that were originally explicitly set during instantiation. If provided,
this is directly used for the [model_fields_set][pydantic.BaseModel.model_fields_set] attribute. Otherwise, the field names from the values argument will be used.
values: Trusted or pre-validated data dictionary.
- Returns:
A new instance of the Model class with validated data.
- to_dict(*, mode='python', use_api_names=True, exclude_unset=True, exclude_defaults=False, exclude_none=False, warnings=True)¶
Recursively generate a dictionary representation of the model, optionally specifying which fields to include or exclude.
By default, fields that were not set by the API will not be included, and keys will match the API response, not the property names from the model.
For example, if the API responds with “fooBar”: true but we’ve defined a foo_bar: bool property, the output will use the “fooBar” key (unless use_api_names=False is passed).
- Return type:
dict
[str
,object
]
- Args:
- mode:
If mode is ‘json’, the dictionary will only contain JSON serializable types. e.g. datetime will be turned into a string, “2024-3-22T18:11:19.117000Z”. If mode is ‘python’, the dictionary may contain any Python objects. e.g. datetime(2024, 3, 22)
use_api_names: Whether to use the key that the API responded with or the property name. Defaults to True. exclude_unset: Whether to exclude fields that have not been explicitly set. exclude_defaults: Whether to exclude fields that are set to their default value from the output. exclude_none: Whether to exclude fields that have a value of None from the output. warnings: Whether to log warnings when invalid fields are encountered. This is only supported in Pydantic v2.
- to_json(*, indent=2, use_api_names=True, exclude_unset=True, exclude_defaults=False, exclude_none=False, warnings=True)¶
Generates a JSON string representing this model as it would be received from or sent to the API (but with indentation).
By default, fields that were not set by the API will not be included, and keys will match the API response, not the property names from the model.
For example, if the API responds with “fooBar”: true but we’ve defined a foo_bar: bool property, the output will use the “fooBar” key (unless use_api_names=False is passed).
- Return type:
str
- Args:
indent: Indentation to use in the JSON output. If None is passed, the output will be compact. Defaults to 2 use_api_names: Whether to use the key that the API responded with or the property name. Defaults to True. exclude_unset: Whether to exclude fields that have not been explicitly set. exclude_defaults: Whether to exclude fields that have the default value. exclude_none: Whether to exclude fields that have a value of None. warnings: Whether to show any warnings that occurred during serialization. This is only supported in Pydantic v2.
- class gbox_sdk.BrowserOperator(client, box_id)¶
Bases:
object
Provides operations related to browser management for a specific box.
- Args:
client (GboxClient): The GboxClient instance used to interact with the API. box_id (str): The unique identifier of the box.
- cdp_url()¶
Get the Chrome DevTools Protocol (CDP) URL for the browser in the specified box.
- Return type:
str
- Returns:
str: The CDP URL for the browser.
- gbox_sdk.Client¶
alias of
GboxClient
- exception gbox_sdk.ConflictError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[409] = 409¶
- gbox_sdk.DefaultAioHttpClient¶
alias of
_DefaultAioHttpClient
- gbox_sdk.DefaultAsyncHttpxClient¶
alias of
_DefaultAsyncHttpxClient
- gbox_sdk.DefaultHttpxClient¶
alias of
_DefaultHttpxClient
- class gbox_sdk.DirectoryOperator(client, box_id, data)¶
Bases:
object
Operator for directory operations within a box.
Provides methods to list and rename a directory.
- Args:
client (GboxClient): The Gbox client instance. box_id (str): The ID of the box to operate on. data (DataDir): The directory data.
- list(body=None)¶
List files and directories in this directory, returning operator objects.
- Return type:
List
[Union
[FileOperator
,DirectoryOperator
]]
- Args:
body (Optional[FListParams]): Parameters for listing. If None, uses the directory’s path.
- Returns:
List[Union[FileOperator, DirectoryOperator]]: List of file or directory operator objects.
- list_info(body=None)¶
Get detailed information about files and directories in this directory.
- Return type:
- Args:
body (Optional[FListParams]): Parameters for listing. If None, uses the directory’s path.
- Returns:
FListResponse: The response containing file/directory information.
- class gbox_sdk.FileOperator(client, box_id, data)¶
Bases:
object
Operator for file operations within a box.
Provides methods to read, write, and rename a file.
- Args:
client (GboxClient): The Gbox client instance. box_id (str): The ID of the box to operate on. data (DataFile): The file data.
- read(body=None)¶
Read the content of this file.
- Return type:
- Args:
body (Optional[FReadParams]): Parameters for reading the file. If None, uses the file’s path.
- Returns:
FReadResponse: The response containing file content.
- rename(body)¶
Rename this file.
- Args:
body (FRenameParams): Parameters for renaming the file.
- Returns:
FRenameResponse: The response after renaming.
- write(body)¶
Write content to this file (text or binary).
- Return type:
- Args:
- body (Union[WriteFile, WriteFileByBinary]): Parameters for writing to the file.
Can be either WriteFile (for text content) or WriteFileByBinary (for binary content).
- Returns:
FWriteResponse: The response after writing.
- class gbox_sdk.FileSystemOperator(client, box_id)¶
Bases:
object
Operator for file system operations within a box.
Provides methods to list, read, write, remove, check existence, rename, and retrieve file or directory information in a box.
- Args:
client (GboxClient): The Gbox client instance. box_id (str): The ID of the box to operate on.
- data_to_operator(data)¶
Convert a Data object to the corresponding operator.
- Return type:
Union
[FileOperator
,DirectoryOperator
]
- Args:
data (Optional[Data]): The data object to convert.
- Returns:
Union[FileOperator, DirectoryOperator]: The corresponding operator object.
- Raises:
ValueError: If data is None.
- exists(body)¶
Check if a file or directory exists.
- Return type:
Union
[ExistsFileResult
,NotExistsFileResult
]
- Args:
body (FExistsParams): Parameters for checking existence.
- Returns:
FExistsResponse: The response indicating existence.
- get(body)¶
Get an operator for a file or directory by its information.
- Return type:
Union
[FileOperator
,DirectoryOperator
]
- Args:
body (FInfoParams): Parameters for retrieving file or directory info.
- Returns:
Union[FileOperator, DirectoryOperator]: The corresponding operator object.
- list(body)¶
List files and directories at a given path or with given parameters, returning operator objects.
- Return type:
List
[Union
[FileOperator
,DirectoryOperator
]]
- Args:
body (Union[FListParams, str]): Path as a string or FListParams object.
- Returns:
List[Union[FileOperator, DirectoryOperator]]: List of file or directory operator objects.
- list_info(body)¶
Get detailed information about files and directories at a given path or with given parameters.
- Return type:
- Args:
body (Union[FListParams, str]): Path as a string or FListParams object.
- Returns:
FListResponse: The response containing file/directory information.
- read(body)¶
Read the content of a file.
- Return type:
- Args:
body (FReadParams): Parameters for reading the file.
- Returns:
FReadResponse: The response containing file content.
- remove(body)¶
Remove a file or directory.
- Return type:
- Args:
body (FRemoveParams): Parameters for removing the file or directory.
- Returns:
None
- rename(body)¶
Rename a file or directory.
- Args:
body (FRenameParams): Parameters for renaming.
- Returns:
FRenameResponse: The response after renaming.
- write(body)¶
Write content to a file (text or binary).
- Return type:
- Args:
- body (Union[WriteFile, WriteFileByBinary]): Parameters for writing to the file.
Can be either WriteFile (for text content) or WriteFileByBinary (for binary content).
- Returns:
FileOperator: The file operator for the written file.
- class gbox_sdk.GboxClient(*, api_key=None, environment=NOT_GIVEN, base_url=NOT_GIVEN, timeout=NOT_GIVEN, max_retries=0, default_headers=None, default_query=None, http_client=None, _strict_response_validation=False)¶
Bases:
SyncAPIClient
- api_key: str¶
- property auth_headers: dict[str, str]¶
- copy(*, api_key=None, environment=None, base_url=None, timeout=NOT_GIVEN, http_client=None, max_retries=NOT_GIVEN, default_headers=None, set_default_headers=None, default_query=None, set_default_query=None, _extra_kwargs={})¶
Create a new client instance re-using the same options given to the current client with optional overriding.
- Return type:
Self
- property qs: Querystring¶
- v1: v1.V1Resource¶
- with_options(*, api_key=None, environment=None, base_url=None, timeout=NOT_GIVEN, http_client=None, max_retries=NOT_GIVEN, default_headers=None, set_default_headers=None, default_query=None, set_default_query=None, _extra_kwargs={})¶
Create a new client instance re-using the same options given to the current client with optional overriding.
- Return type:
Self
- with_raw_response: GboxClientWithRawResponse¶
- with_streaming_response: GboxClientWithStreamedResponse¶
- exception gbox_sdk.GboxClientError¶
Bases:
Exception
- class gbox_sdk.GboxSDK(*, api_key=None, base_url=None, timeout=NOT_GIVEN, max_retries=None, default_headers=None, default_query=None, http_client=None, _strict_response_validation=None)¶
Bases:
object
GboxSDK provides a high-level interface for managing and operating Gbox containers (boxes).
This SDK allows users to create, list, retrieve, and terminate both Android and Linux boxes, and provides operator objects for further box-specific operations. It wraps the lower-level GboxClient and exposes convenient methods for common workflows.
- Attributes:
client (GboxClient): The underlying client used for API communication.
- Examples:
Initialize the SDK: ```python from gbox_sdk.wrapper import GboxSDK
# Initialize the SDK sdk = GboxSDK(api_key=”your-api-key”) ```
Create boxes using the unified create method: ```python # Create an Android box android_box = sdk.create({“type”: “android”, “config”: {“labels”: {“env”: “test”}}})
# Create a Linux box linux_box = sdk.create({“type”: “linux”, “config”: {“envs”: {“PYTHON_VERSION”: “3.9”}}}) ```
List and manage boxes: ```python # List all boxes boxes = sdk.list()
# Get a specific box box = sdk.get(“box_id”)
- create(body)¶
Create a new box and return its operator.
This method provides a unified interface for creating both Android and Linux boxes. The box type is determined by the ‘type’ field in the body parameter.
- Return type:
Union
[AndroidBoxOperator
,LinuxBoxOperator
]
- Args:
- body (CreateParams): Parameters for creating the box. Must include a ‘type’ field
specifying either ‘android’ or ‘linux’.
- Returns:
BoxOperator: Operator for the created box (AndroidBoxOperator or LinuxBoxOperator).
- Raises:
ValueError: If an unsupported box type is provided.
- Examples:
Create an Android box:
`python android_box = sdk.create({"type": "android", "config": {"labels": {"env": "test"}}}) `
Create a Linux box:
`python linux_box = sdk.create({"type": "linux", "config": {"envs": {"PYTHON_VERSION": "3.9"}}}) `
- data_to_operator(data)¶
Convert box data to the corresponding operator object.
- Return type:
Union
[AndroidBoxOperator
,LinuxBoxOperator
]
- Args:
data (Union[AndroidBox, LinuxBox]): The box data to convert.
- Returns:
BoxOperator: The corresponding operator object.
- Raises:
ValueError: If the box type is invalid.
- get(box_id)¶
Retrieve a specific box and return its operator object.
- Return type:
Union
[AndroidBoxOperator
,LinuxBoxOperator
]
- Args:
box_id (str): The ID of the box to retrieve.
- Returns:
BoxOperator: Operator object for the specified box.
- Example:
`python box = sdk.get("975fed9f-bb28-4718-a2c5-e01f72864bd1") `
- get_client()¶
Get the underlying GboxClient instance.
- Return type:
- Returns:
GboxClient: The underlying client instance.
- get_info(box_id)¶
Retrieve detailed information for a specific box.
- Return type:
Union
[LinuxBox
,AndroidBox
]
- Args:
box_id (str): The ID of the box to retrieve.
- Returns:
BoxRetrieveResponse: Detailed information about the box.
- Example:
`python box_info = sdk.get_info("975fed9f-bb28-4718-a2c5-e01f72864bd1") `
- list(query=None)¶
List all boxes matching the query and return their operator objects.
- Return type:
- list_info(query=None)¶
List information of all boxes matching the query.
- Return type:
- terminate(box_id, body=None)¶
Terminate a specific box.
- Return type:
None
- Args:
box_id (str): The ID of the box to terminate. body (Optional[BoxTerminate]): Additional parameters for termination.
- Example:
`python sdk.terminate("box_id") `
- exception gbox_sdk.InternalServerError(message, *, response, body)¶
Bases:
APIStatusError
- class gbox_sdk.LinuxBoxOperator(client, data)¶
Bases:
BaseBox
Operator class for managing Linux boxes via the Gbox SDK. Provides an interface to interact with and control Linux-based boxes.
- class gbox_sdk.NoneType¶
Bases:
object
The type of the None singleton.
- exception gbox_sdk.NotFoundError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[404] = 404¶
- class gbox_sdk.NotGiven¶
Bases:
object
A sentinel singleton class used to distinguish omitted keyword arguments from those passed in with the value None (which may have different behavior).
For example:
```py def get(timeout: Union[int, NotGiven, None] = NotGiven()) -> Response: …
get(timeout=1) # 1s timeout get(timeout=None) # No timeout get() # Default timeout behavior, which may not be statically known at the method definition. ```
- class gbox_sdk.Omit¶
Bases:
object
In certain situations you need to be able to represent a case where a default value has to be explicitly removed and None is not an appropriate substitute, for example:
``py # as the default `Content-Type header is application/json that will be sent client.post(“/upload/files”, files={“file”: b”my raw file content”})
# you can’t explicitly override the header as it has to be dynamically generated # to look something like: ‘multipart/form-data; boundary=0d8382fcf5f8c3be01ca2e11002d2983’ client.post(…, headers={“Content-Type”: “multipart/form-data”})
# instead you can remove the default application/json header by passing Omit client.post(…, headers={“Content-Type”: Omit()}) ```
- exception gbox_sdk.PermissionDeniedError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[403] = 403¶
- exception gbox_sdk.RateLimitError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[429] = 429¶
- class gbox_sdk.RequestOptions¶
Bases:
TypedDict
-
extra_json:
Mapping
[str
,object
]¶
-
follow_redirects:
bool
¶
-
idempotency_key:
str
¶
-
max_retries:
int
¶
-
params:
Mapping
[str
,object
]¶
-
extra_json:
- class gbox_sdk.Stream(*, cast_to, response, client)¶
Bases:
Generic
[_T
]Provides the core interface to iterate over a synchronous stream response.
- close()¶
Close the response and release the connection.
Automatically called if the response body is read to completion.
- Return type:
None
- response: httpx.Response¶
- class gbox_sdk.Timeout(timeout=<httpx._config.UnsetType object>, *, connect=<httpx._config.UnsetType object>, read=<httpx._config.UnsetType object>, write=<httpx._config.UnsetType object>, pool=<httpx._config.UnsetType object>)¶
Bases:
object
Timeout configuration.
Usage:
Timeout(None) # No timeouts. Timeout(5.0) # 5s timeout on all operations. Timeout(None, connect=5.0) # 5s timeout on connect, no other timeouts. Timeout(5.0, connect=10.0) # 10s timeout on connect. 5s timeout elsewhere. Timeout(5.0, pool=None) # No timeout on acquiring connection from pool.
# 5s timeout elsewhere.
- as_dict()¶
- Return type:
dict
[str
,float
|None
]
- gbox_sdk.Transport¶
alias of
BaseTransport
- exception gbox_sdk.UnprocessableEntityError(message, *, response, body)¶
Bases:
APIStatusError
- status_code: Literal[422] = 422¶
- gbox_sdk.file_from_path(path)¶
- Return type:
Union
[IO
[bytes
],bytes
,PathLike
,Tuple
[Optional
[str
],Union
[IO
[bytes
],bytes
,PathLike
]],Tuple
[Optional
[str
],Union
[IO
[bytes
],bytes
,PathLike
],Optional
[str
]],Tuple
[Optional
[str
],Union
[IO
[bytes
],bytes
,PathLike
],Optional
[str
],Mapping
[str
,str
]]]