CleverCloud Storage Framework
|
|
||
|---|---|---|
| .docker | ||
| .forgejo/workflows | ||
| src/clevercloud_storage_framework | ||
| tests | ||
| .coveragerc | ||
| .cz-config.js | ||
| .cz.json | ||
| .editorconfig | ||
| .gitignore | ||
| ATTRIBUTIONS.md | ||
| CHANGELOG.md | ||
| CODE_OF_CONDUCT.md | ||
| conftest.py | ||
| CONTRIBUTING.md | ||
| CONTRIBUTORS.md | ||
| Dockerfile.dev | ||
| LICENSE | ||
| MANIFEST.in | ||
| NOTICE | ||
| README.md | ||
| requirements-dev.txt | ||
| requirements.txt | ||
| setup.cfg | ||
| setup.py | ||
| tox.ini | ||
CleverCloud Storage Framework
A unified framework for interacting with various AWS storage services including S3, EFS, and Glacier. This library provides a consistent interface for common storage operations across different storage providers.
Features
- Unified API for multiple storage providers (S3, EFS, Glacier, Local)
- Streaming support for large files
- Automatic provider detection based on path format
- Chunked reading and writing for efficient memory usage
- Comprehensive error handling
- Support for SAS tokens (for S3)
Installation
pip install clevercloud-storage-framework
Quick Start
from clevercloud_storage_framework.factory import StorageClientFactory
from clevercloud_storage_framework.client import StorageClient
# Create a client for S3
s3_client = StorageClientFactory.create_client("s3", region_name="us-west-2")
# List files in an S3 bucket
files = s3_client.list_files("s3://my-bucket/my-prefix/")
# Read a file from S3
content = s3_client.read_file("s3://my-bucket/my-file.txt")
# Write a file to S3
s3_client.write_file("s3://my-bucket/new-file.txt", "Hello, World!")
# Copy a file between providers
s3_client.copy("s3://my-bucket/source.txt", "efs://my-filesystem/destination.txt")
Working with Different Storage Providers
S3
# Create an S3 client
s3_client = StorageClientFactory.create_client("s3",
region_name="us-west-2",
aws_access_key_id="YOUR_ACCESS_KEY",
aws_secret_access_key="YOUR_SECRET_KEY")
# Generate a presigned URL
from clevercloud_storage_framework.providers.s3_provider import S3StorageProvider
s3_provider = s3_client._provider
presigned_url = s3_provider.generate_presigned_url("s3://my-bucket/my-file.txt", expiration=3600)
EFS
# Create an EFS client
efs_client = StorageClientFactory.create_client("efs",
region_name="us-west-2",
mount_point="/mnt/efs")
# Create a directory
efs_client.create_directory("efs://fs-12345/my-directory")
# List files recursively
files = efs_client.list_files("efs://fs-12345/", recursive=True)
Glacier
# Create a Glacier client
glacier_client = StorageClientFactory.create_client("glacier", region_name="us-west-2")
# Initiate an archive retrieval
from clevercloud_storage_framework.providers.glacier_provider import GlacierStorageProvider
glacier_provider = glacier_client._provider
job_id = glacier_provider.initiate_archive_retrieval("my-vault", "archive-id")
# Check job status
status = glacier_provider.check_job_status("my-vault", job_id)
# Get job output when complete
if status == "Succeeded":
content = b"".join(list(glacier_provider.get_job_output("my-vault", job_id)))
Local Storage
# Create a local storage client
local_client = StorageClientFactory.create_client("local")
# Work with local files
local_client.write_file("/path/to/local/file.txt", "Hello, World!")
content = local_client.read_file("/path/to/local/file.txt")
Error Handling
from clevercloud_storage_framework.exceptions import StorageError, ResourceNotFoundError
try:
content = client.read_file("s3://non-existent-bucket/file.txt")
except ResourceNotFoundError as e:
print(f"Resource not found: {e.resource}")
except StorageError as e:
print(f"Storage error: {e.message}")
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.