Official Python SDK for the RideScan Safety Layer API
Project description
RideScan Python SDK
The official Python client for the RideScan Safety Layer API. This SDK allows developers to programmatically manage robots, missions, and file uploads, and retrieve risk scores directly from their Python applications.
Installation
pip install ridescanapi
Getting Started
1. Obtain your API Key
To use this SDK, you must have a valid API Key.
- Go to the RideScan Developer Console.
- Create an account or Log in.
- Navigate to the API Keys section in your dashboard.
- Click Generate New Key.
- Copy the key (it starts with
rsk_...).
2. Initialize the Client
You can use the client as a context manager (recommended) to automatically handle session closing, or as a standard object.
Using Context Manager (Recommended):
from ridescanapi import RideScanClient
API_KEY = "rsk_your_api_key_here"
with RideScanClient(api_key=API_KEY) as client:
# Your code here
robots = client.get_robots()
print(robots)
Using Standard Initialization:
client = RideScanClient(api_key=API_KEY)
try:
robots = client.get_robots()
finally:
client.session.close() # Always close the session manually
API Reference
Robot Resources
create_robot(name, robot_type)
Registers a new robot in the system.
-
Arguments:
-
name(str): A friendly name for the robot (e.g., "Warehouse-Spot-01"). -
robot_type(str or int): The type identifier (e.g.,"SPOT","UR6"). -
Sample Usage:
response = client.create_robot(
name="Warehouse-Spot-01",
robot_type="SPOT"
)
print(response)
- Returns:
dict
{
"robot_id": "123e4567-e89b-12d3-a456-426614174000",
"robot_name": "Warehouse-Spot-01",
"message": "Robot created"
}
get_robots(robot_id=None, name=None, robot_type=None)
Search for robots matching specific criteria. If no arguments are provided, returns all robots.
-
Arguments:
-
robot_id(str, optional): Search by specific UUID. -
name(str, optional): Filter by name. -
robot_type(str, optional): Filter by type. -
Sample Usage:
# Get all robots
all_robots = client.get_robots()
# Filter by type
spot_robots = client.get_robots(robot_type="SPOT")
# Get specific robot by ID
specific_robot = client.get_robots(robot_id="123e4567-e89b-12d3-a456-426614174000")
- Returns:
List[dict]
edit_robot(robot_id, new_name=None, new_type=None)
Updates a robot's details.
-
Arguments:
-
robot_id(str): The UUID of the robot to update. -
new_name(str, optional): New name. -
new_type(str or int, optional): New type. -
Sample Usage:
updated_robot = client.edit_robot(
robot_id="123e4567-e89b-12d3-a456-426614174000",
new_name="Warehouse-Spot-02-Renamed"
)
- Returns:
dict(Updated robot object).
delete_robot(robot_id)
Permanently deletes a robot and all associated missions and files.
- Arguments:
robot_id(str). - Sample Usage:
client.delete_robot(robot_id="123e4567-e89b-12d3-a456-426614174000")
- Returns:
dict({"message": "Robot deleted"}).
Mission Resources
create_mission(robot_id, mission_name)
Creates a new mission scope under a specific robot.
-
Arguments:
-
robot_id(str): The UUID of the parent robot. -
mission_name(str): Descriptive name (e.g., "Calibration-Run-Jan"). -
Sample Usage:
mission = client.create_mission(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_name="Site-Inspection-Alpha"
)
print(f"New Mission ID: {mission['mission_id']}")
- Returns:
dictcontainingmission_id.
get_missions(robot_id=None, mission_id=None, mission_name=None, ...)
Search for missions.
-
Arguments:
-
robot_id(str, optional): Filter by robot. -
mission_id(str, optional): Filter by mission UUID. -
mission_name(str, optional): Filter by name. -
start_time/end_time(str, optional): Filter by date range (ISO format). -
Sample Usage:
# Get all missions for a specific robot
robot_missions = client.get_missions(
robot_id="123e4567-e89b-12d3-a456-426614174000"
)
# Search by mission name
specific_mission = client.get_missions(
mission_name="Calibration-Run-Jan"
)
- Returns:
List[dict].
edit_mission(robot_id, mission_id, new_name)
Renames an existing mission.
- Arguments:
robot_id,mission_id,new_name. - Sample Usage:
client.edit_mission(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000",
new_name="Site-Inspection-Beta"
)
- Returns:
dict(Updated mission object).
delete_mission(robot_id, mission_id)
Permanently deletes a mission.
- Arguments:
robot_id,mission_id. - Sample Usage:
client.delete_mission(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000"
)
- Returns:
dict.
File Resources
upload_files(robot_id, mission_id, file_paths, file_type='calib_file')
Bulk uploads files (.bag, .csv, .zip) to the server. This handles large file streaming automatically.
-
Arguments:
-
robot_id(str): Robot UUID. -
mission_id(str): Mission UUID. -
file_paths(List[str]): List of absolute local paths to the files. -
file_type(str): -
'calib_file'(Default) - Use for model training/calibration. -
'process_file'- Use for inference/risk analysis. -
Sample Usage:
# Upload calibration data
result = client.upload_files(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000",
file_paths=["/path/to/data/run1.bag", "/path/to/data/run2.csv"],
file_type="calib_file"
)
print(f"Uploaded: {result['uploaded_files']}")
- Returns:
dict
{
"success": true,
"uploaded_files": ["uuid_day1.bag", "uuid_day2.bag"],
"failed_files": []
}
list_files(robot_id, mission_id)
Lists all files uploaded for a specific mission.
- Arguments:
robot_id,mission_id. - Sample Usage:
files = client.list_files(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000"
)
for file in files:
print(f"File: {file['original_filename']} (ID: {file['unique_filename']})")
- Returns:
List[dict]containingunique_filename,original_filename,file_size, etc.
delete_file(robot_id, mission_id, unique_filename)
Deletes a specific file from storage and database.
-
Arguments:
-
robot_id(str): Robot UUID. -
mission_id(str): Mission UUID. -
unique_filename(str): The unique ID returned bylist_files(e.g.,abc123_data.csv). -
Sample Usage:
client.delete_file(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000",
unique_filename="550e8400-e29b-41d4-a716-446655440000_data.bag"
)
- Returns:
dict.
Model & Inference Resources
calibrate_model(robot_id, mission_id, epochs=100, robot_type="SPOT", retrain=False, ...)
Triggers an asynchronous Kubernetes job to train a model using uploaded calibration files.
-
Arguments:
-
robot_id(str): Robot UUID. -
mission_id(str): Mission UUID. -
epochs(int): Training duration (Default: 100). -
robot_type(str or int): Robot type identifier (Default:"SPOT"). -
retrain(bool): Force re-training if a model already exists (Default:False). -
file_names(List[str], optional): specific subset of unique filenames to use. IfNone, uses all uploaded calibration files. -
Sample Usage:
training_response = client.calibrate_model(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000",
epochs=200,
robot_type="SPOT",
retrain=True
)
print(f"Task Queued: {training_response['message']}")
- Returns:
dictindicating the task was queued.
{
"message": "Training task queued",
"details": {"task_id": "..."}
}
run_inference(robot_id, mission_id, file_names=None, device='cpu')
Runs risk analysis on uploaded inference files using the trained model.
-
Arguments:
-
robot_id(str): Robot UUID. -
mission_id(str): Mission UUID. -
device(str): Compute device ('cpu'or'cuda'). -
file_names(List[str], optional): specific subset of unique filenames to analyze. IfNone, uses all available files. -
Sample Usage:
# Run inference on GPU
inference_results = client.run_inference(
robot_id="123e4567-e89b-12d3-a456-426614174000",
mission_id="987fcdeb-51a2-12d3-a456-426614174000",
device="cuda"
)
- Returns:
dict(Inference results).
get_model_status(mission_id)
Checks the status of calibration or inference tasks.
- Arguments:
mission_id. - Sample Usage:
status = client.get_model_status(mission_id="987fcdeb-51a2-12d3-a456-426614174000")
print(f"Training Status: {status.get('calibration_status')}")
- Returns:
dict
{
"calibration_status": "Training_Completed",
"inference_status": "processing_completed",
"epochs": 100,
"upload_time": "..."
}
Error Handling
The SDK raises specific exceptions from ridescanapi.exceptions to help you handle errors gracefully.
| Exception Class | HTTP Code | Description |
|---|---|---|
AuthenticationError |
401 | Invalid API Key. Check your dashboard. |
ValidationError |
400 | Missing arguments, invalid file types, or malformed requests. |
ResourceNotFoundError |
404 | Robot, Mission, or File ID does not exist. |
ConflictError |
409 | Resource already exists (e.g., creating a robot with a duplicate ID). |
ServerError |
500+ | Internal backend issue. |
RideScanError |
- | Generic base exception for other errors. |
Example Usage:
from ridescanapi.exceptions import ResourceNotFoundError, ValidationError
try:
client.delete_robot("invalid-id")
except ResourceNotFoundError:
print("Robot not found!")
except ValidationError as e:
print(f"Invalid input: {e}")
Enums & Values
robot_type
Used in create_robot and calibrate_model.
"SPOT"(Boston Dynamics Spot)"UR6"
file_type
Used in upload_files.
"calib_file": Files used to train/calibrate the model."process_file": Files used for inference/risk assessment.
device
Used in run_inference.
"cpu"(Default)"cuda"(GPU - Requires backend support)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ridescanapi-1.3.1.tar.gz.
File metadata
- Download URL: ridescanapi-1.3.1.tar.gz
- Upload date:
- Size: 13.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
308412c6b9d7745dc29bd4f495c372218f3dc3121412eb719ea70e08aa0f8d42
|
|
| MD5 |
abf4feacfc68d6d6699b66173210f6f7
|
|
| BLAKE2b-256 |
3ffd868b7f7116b1e8a5b50eff64211568aaaa5f8c56cbf41f3d756b36bb8e61
|
File details
Details for the file ridescanapi-1.3.1-py3-none-any.whl.
File metadata
- Download URL: ridescanapi-1.3.1-py3-none-any.whl
- Upload date:
- Size: 9.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
59f5e04f9524bef3fdf617281b52bf1949396da476e9c33c3d8c21904949dc63
|
|
| MD5 |
6969e64d7c1ed0859a5b8533e14dd3c7
|
|
| BLAKE2b-256 |
9c9cdbd3e27a9e9f2df327b50647d12eb7364204cf4535d40224802fd0584c0d
|