Official Python SDK for XASE AI - Secure Data Marketplace
Project description
XASE Sheets SDK - Python
Official Python SDK for XASE Sheets - Secure Data Marketplace Platform.
Installation
pip install xase-sheets
Quick Start
from xase import XaseClient
# Initialize client
client = XaseClient(api_key='your-api-key')
# List datasets
result = client.list_datasets()
print(f"Found {result['total']} datasets")
# Create a lease
lease = client.create_lease(
dataset_id='dataset-id',
duration=3600, # 1 hour
purpose='AI model training'
)
print(f"Access token: {lease.accessToken}")
Features
- ✅ Full type hints support
- ✅ Synchronous and asynchronous API
- ✅ Automatic retries and error handling
- ✅ Context manager support
- ✅ Comprehensive error messages
- ✅ Python 3.8+ support
API Reference
Client Initialization
from xase import XaseClient
client = XaseClient(
api_key='your-api-key', # Required
base_url='https://api.xase.ai', # Optional
timeout=30, # Optional (seconds)
)
Datasets
List Datasets
result = client.list_datasets(
page=1,
limit=20,
data_type='AUDIO' # Optional filter
)
for dataset in result['datasets']:
print(f"{dataset['name']}: {dataset['size']} bytes")
Get Dataset
dataset = client.get_dataset('dataset-id')
print(f"Dataset: {dataset.name}")
print(f"Type: {dataset.dataType}")
print(f"Size: {dataset.size} bytes")
Create Dataset
dataset = client.create_dataset(
name='My Dataset',
data_type='AUDIO',
description='Audio dataset for speech recognition',
tags=['speech', 'english']
)
Update Dataset
updated = client.update_dataset(
'dataset-id',
description='Updated description',
tags=['speech', 'english', 'updated']
)
Delete Dataset
client.delete_dataset('dataset-id')
Leases
Create Lease
lease = client.create_lease(
dataset_id='dataset-id',
duration=3600, # seconds
purpose='Model training'
)
print(f"Lease ID: {lease.id}")
print(f"Access token: {lease.accessToken}")
print(f"Expires: {lease.endTime}")
Get Lease
lease = client.get_lease('lease-id')
print(f"Status: {lease.status}")
List Leases
result = client.list_leases(
page=1,
limit=20,
status='ACTIVE'
)
for lease in result['leases']:
print(f"Lease {lease['id']}: {lease['status']}")
Revoke Lease
client.revoke_lease('lease-id')
Renew Lease
renewed = client.renew_lease('lease-id', duration=3600)
print(f"New expiry: {renewed.endTime}")
Policies
Create Policy
policy = client.create_policy(
name='Strict Access Policy',
dataset_id='dataset-id',
rules={
'maxDuration': 7200,
'watermarkRequired': True,
'allowedPurposes': ['research', 'training']
}
)
Get Policy
policy = client.get_policy('policy-id')
print(f"Policy: {policy.name}")
print(f"Active: {policy.active}")
List Policies
result = client.list_policies(
dataset_id='dataset-id',
active=True
)
Update Policy
updated = client.update_policy(
'policy-id',
active=False
)
Delete Policy
client.delete_policy('policy-id')
Usage Tracking
Record Usage
client.record_usage(
lease_id='lease-id',
bytes_transferred=1024000,
records_accessed=100
)
Get Usage
usage = client.get_usage(
start_date='2024-01-01',
end_date='2024-01-31'
)
for record in usage:
print(f"Lease {record.leaseId}: {record.bytesTransferred} bytes")
Marketplace
List Offers
result = client.list_offers(
page=1,
limit=20,
data_type='AUDIO'
)
Get Offer
offer = client.get_offer('offer-id')
print(f"Price: {offer.price} {offer.currency}")
Request Access
request = client.request_access(
offer_id='offer-id',
purpose='Research project on speech recognition'
)
print(f"Request ID: {request.id}")
print(f"Status: {request.status}")
Search Marketplace
results = client.search_marketplace(
'speech recognition',
data_type='AUDIO',
min_size=1000000
)
Webhooks
Create Webhook
webhook = client.create_webhook(
url='https://your-domain.com/webhook',
events=['lease.created', 'lease.expired'],
secret='your-webhook-secret'
)
List Webhooks
webhooks = client.list_webhooks()
for webhook in webhooks:
print(f"Webhook {webhook.id}: {webhook.url}")
Delete Webhook
client.delete_webhook('webhook-id')
Health Check
health = client.health()
print(f"API Status: {health['status']}")
Error Handling
from xase import XaseClient
from xase.exceptions import XaseAPIError, XaseAuthError, XaseNotFoundError
client = XaseClient(api_key='your-api-key')
try:
dataset = client.get_dataset('invalid-id')
except XaseNotFoundError:
print("Dataset not found")
except XaseAuthError:
print("Invalid API key")
except XaseAPIError as e:
print(f"API error: {e}")
print(f"Status code: {e.status_code}")
print(f"Response: {e.response}")
Context Manager
from xase import XaseClient
with XaseClient(api_key='your-api-key') as client:
datasets = client.list_datasets()
print(f"Found {datasets['total']} datasets")
# Session automatically closed
Type Hints
from xase import XaseClient, Dataset, Lease, Policy
from typing import List
client = XaseClient(api_key='key')
# Full type hints
dataset: Dataset = client.get_dataset('id')
lease: Lease = client.create_lease(dataset_id='id')
Examples
Complete Workflow
from xase import XaseClient
def main():
client = XaseClient(api_key='your-api-key')
# 1. Create a dataset
dataset = client.create_dataset(
name='Speech Dataset',
data_type='AUDIO',
description='English speech samples'
)
print(f"Created dataset: {dataset.id}")
# 2. Create access policy
policy = client.create_policy(
name='Research Access',
dataset_id=dataset.id,
rules={
'maxDuration': 7200,
'watermarkRequired': True,
'allowedPurposes': ['research']
}
)
print(f"Created policy: {policy.id}")
# 3. Create lease
lease = client.create_lease(
dataset_id=dataset.id,
duration=3600,
purpose='Speech recognition research'
)
print(f"Access token: {lease.accessToken}")
# 4. Record usage
client.record_usage(
lease_id=lease.id,
bytes_transferred=5000000,
records_accessed=500
)
# 5. Get usage stats
usage = client.get_usage()
total_bytes = sum(u.bytesTransferred for u in usage)
print(f"Total bytes transferred: {total_bytes}")
if __name__ == '__main__':
main()
Batch Operations
from xase import XaseClient
client = XaseClient(api_key='your-api-key')
# Create multiple datasets
datasets = []
for i in range(5):
dataset = client.create_dataset(
name=f'Dataset {i+1}',
data_type='AUDIO',
description=f'Dataset number {i+1}'
)
datasets.append(dataset)
print(f"Created: {dataset.name}")
# Create leases for all datasets
leases = []
for dataset in datasets:
lease = client.create_lease(
dataset_id=dataset.id,
duration=3600
)
leases.append(lease)
print(f"Lease created for {dataset.name}")
Error Recovery
from xase import XaseClient
from xase.exceptions import XaseAPIError
import time
client = XaseClient(api_key='your-api-key')
def create_lease_with_retry(dataset_id, max_retries=3):
for attempt in range(max_retries):
try:
return client.create_lease(dataset_id=dataset_id)
except XaseAPIError as e:
if e.status_code == 429: # Rate limit
wait_time = 2 ** attempt # Exponential backoff
print(f"Rate limited, waiting {wait_time}s...")
time.sleep(wait_time)
else:
raise
raise Exception("Max retries exceeded")
lease = create_lease_with_retry('dataset-id')
Environment Variables
# .env
XASE_API_KEY=your-api-key
XASE_BASE_URL=https://api.xase.ai
import os
from xase import XaseClient
client = XaseClient(
api_key=os.getenv('XASE_API_KEY'),
base_url=os.getenv('XASE_BASE_URL', 'https://api.xase.ai')
)
Development
Install Development Dependencies
pip install -e ".[dev]"
Run Tests
pytest
pytest --cov=xase tests/
Code Formatting
black src/
isort src/
flake8 src/
mypy src/
License
MIT
Support
- Documentation: https://docs.xase.ai
- Email: support@xase.ai
- GitHub: https://github.com/xaseai/xase-sheets
Contributing
Contributions are welcome! Please read our contributing guidelines.
Changelog
See CHANGELOG.md for version history.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
xase_ai-2.1.0.tar.gz
(17.9 kB
view details)
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
xase_ai-2.1.0-py3-none-any.whl
(11.9 kB
view details)
File details
Details for the file xase_ai-2.1.0.tar.gz.
File metadata
- Download URL: xase_ai-2.1.0.tar.gz
- Upload date:
- Size: 17.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0a1dfc3d382ce49236292e524dcf509c852c3818ec19d7a60f73f0273b77ad24
|
|
| MD5 |
b0880ea4b4333959e0b393d13301fb7a
|
|
| BLAKE2b-256 |
33c57eae6c1116f319824154a61253ad9c05171c174a6bd65411c31721b39303
|
File details
Details for the file xase_ai-2.1.0-py3-none-any.whl.
File metadata
- Download URL: xase_ai-2.1.0-py3-none-any.whl
- Upload date:
- Size: 11.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
425caf6e5425fbdcc7aafbbf05edec742926b52fc6364420edbc95585802b254
|
|
| MD5 |
e0048f3d7ae336bd3b288a7b5e3984a4
|
|
| BLAKE2b-256 |
4ca865dd1d4c321f08877b0c514935a1e834157923e4625de694065d40f3aafd
|