Python SDK for Kamimind Storage Service
Project description
Kamimind Storage SDK for Python
Official Python SDK for Kamimind Storage Service.
Installation
Install from PyPI:
# Using uv (recommended)
uv add kamimind-storage
# Using pip
pip install kamimind-storage
Quick Start
from kamimind_storage import StorageClient
# Initialize client
client = StorageClient(
base_url="https://api.kamimind.ai",
access_token="your-jwt-token",
)
# Upload a file
session = client.upload_file("path/to/file.pdf", is_public=True)
print(f"Uploaded: {session.session_id}")
# Get download URL
download = client.get_download_url(session.session_id)
print(f"Download URL: {download.download_url}")
# Make file public
public_info = client.make_public(session.session_id)
print(f"Public URL: {public_info.public_url}")
Async Support
from kamimind_storage import AsyncStorageClient
async def main():
async with AsyncStorageClient(
base_url="https://api.kamimind.ai",
access_token="your-jwt-token",
) as client:
session = await client.upload_file("path/to/file.pdf")
print(f"Uploaded: {session.session_id}")
Features
File Upload
# Upload from file path
session = client.upload_file("path/to/file.pdf")
# Upload from bytes
session = client.upload_bytes(b"Hello, World!", filename="hello.txt")
# Upload with progress callback
def on_progress(progress):
print(f"Uploaded: {progress.percentage:.1f}%")
session = client.upload_file("large_file.zip", on_progress=on_progress)
# Upload with metadata
session = client.upload_file(
"document.pdf",
metadata={"category": "reports", "year": 2024},
is_public=True,
)
File Download
# Get download URL
download_info = client.get_download_url(session_id)
print(download_info.download_url)
# Download to file
path = client.download_file(session_id, "downloads/file.pdf")
# Download as bytes
content = client.download_bytes(session_id)
Public Sharing
# Make file public
public_info = client.make_public(session_id)
print(f"Public URL: {public_info.public_url}")
# Toggle public access
client.toggle_public_access(session_id, is_public=False)
# Get public URL by shortcut
public_url = client.get_public_url("abc12345")
Session Management
# Get upload status
status = client.get_upload_status(session_id)
print(f"Status: {status.status}")
# Abort upload
client.abort_upload(session_id)
Configuration
client = StorageClient(
base_url="https://api.kamimind.ai",
access_token="your-jwt-token",
timeout=60.0, # Request timeout in seconds
max_retries=3, # Max retry attempts
multipart_threshold=100 * 1024 * 1024, # 100MB threshold for multipart
part_size=5 * 1024 * 1024, # 5MB part size
)
Error Handling
from kamimind_storage.exceptions import (
StorageError,
AuthenticationError,
NotFoundError,
UploadError,
QuotaExceededError,
)
try:
session = client.upload_file("file.pdf")
except AuthenticationError:
print("Invalid or expired token")
except QuotaExceededError:
print("Storage quota exceeded")
except UploadError as e:
print(f"Upload failed: {e.message}")
except StorageError as e:
print(f"Storage error: {e.message}")
Development
# Install uv if not already installed
curl -LsSf https://astral.sh/uv/install.sh | sh
# Create virtual environment and install dependencies
uv sync
# Run tests
uv run pytest
# Run with coverage
uv run pytest --cov=kamimind_storage
# Lint
uv run ruff check .
# Format
uv run ruff format .
# Type check
uv run mypy src
License
MIT License
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
kamimind_storage-0.1.6.tar.gz
(13.7 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
File details
Details for the file kamimind_storage-0.1.6.tar.gz.
File metadata
- Download URL: kamimind_storage-0.1.6.tar.gz
- Upload date:
- Size: 13.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec7d127636f8157a87ad83459ce6e286f59b45a7cbcdb1f3650492f2c069d38b
|
|
| MD5 |
f3d01504c18495c4bfa7995d7ef38a9e
|
|
| BLAKE2b-256 |
1f9c58bab4c69ccf7273ddfb1e6cc7a18a6242a2e6f33ff3d48a2c7bd067a903
|
File details
Details for the file kamimind_storage-0.1.6-py3-none-any.whl.
File metadata
- Download URL: kamimind_storage-0.1.6-py3-none-any.whl
- Upload date:
- Size: 19.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3467fd54bd293fe4bd0fbb1518beeaca61829400975d19abf866583407f6858f
|
|
| MD5 |
c271c4533560a429f36b7015cb41f41c
|
|
| BLAKE2b-256 |
3fffb9c53f0b0871f8fffeea9e64daab5dea93d2b6a68f8991d1c9f0330c245e
|