Skip to main content

Pluggable file upload + storage (local or S3 via extras) module for simple_module apps

Project description

simple_module_file_storage

Pluggable file-upload + storage module for simple_module apps. Defaults to local-disk storage for development; install the [s3] extra to switch to any S3-compatible backend via aioboto3.

Install

# local-disk storage (dev default)
pip install simple_module_file_storage

# S3-compatible storage (production)
pip install "simple_module_file_storage[s3]"

What it provides

  • POST /api/files upload endpoint with multipart + metadata.
  • GET /api/files/{id} signed-URL or stream download.
  • Pluggable backend via SM_FILE_STORAGE_BACKEND (local | s3).
  • S3 config via SM_FILE_STORAGE_S3_BUCKET, SM_FILE_STORAGE_S3_ENDPOINT (for R2/MinIO/etc.), SM_FILE_STORAGE_S3_REGION.

Usage

From another module:

from file_storage.service import FileStorageService   # type: ignore[import-not-found]

async def attach_receipt(
    svc: FileStorageService = Depends(FileStorageService),
    upload: UploadFile = File(...),
):
    record = await svc.save(upload, folder="receipts/")
    return {"file_id": record.id, "url": record.url}

Env config (example, S3):

SM_FILE_STORAGE_BACKEND=s3
SM_FILE_STORAGE_S3_BUCKET=my-app-uploads
SM_FILE_STORAGE_S3_REGION=us-east-1
AWS_ACCESS_KEY_ID=...
AWS_SECRET_ACCESS_KEY=...

Depends on

  • simple_module_core, simple_module_db, simple_module_hosting
  • aiofiles
  • Optional: aioboto3 (install the [s3] extra)

License

MIT — see 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

simple_module_file_storage-0.0.1.tar.gz (23.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

simple_module_file_storage-0.0.1-py3-none-any.whl (27.8 kB view details)

Uploaded Python 3

File details

Details for the file simple_module_file_storage-0.0.1.tar.gz.

File metadata

File hashes

Hashes for simple_module_file_storage-0.0.1.tar.gz
Algorithm Hash digest
SHA256 687b81d0c1d9e0b124e27d94a5eff17a725fc3d04c755cf256dce03a91aea866
MD5 036d2f95c16dd93d3e4739c23746d4f1
BLAKE2b-256 4d1069fe5e5e5fe0fbb8225a15186de230eaa6f73f6770c9997f90c82d1257f2

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_file_storage-0.0.1.tar.gz:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file simple_module_file_storage-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_module_file_storage-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 11c995a835487a5c904f7590949d2ca07c8303db42a1adf9a61fe6a1c7bcec22
MD5 d84b559263f7a264ab89b3260c76efbe
BLAKE2b-256 630b849061c4c9482e1b78f130d9d82f3f2d779b04c2c6050795e6096ae4ef20

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_file_storage-0.0.1-py3-none-any.whl:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page