Skip to main content

apiminio is a Python package that provides a ready-to-use REST API for interacting with MinIO S3 storage, built with FastAPI and the MinIO Python client. It enables seamless file uploads, downloads, and bucket management via HTTP interface ideal for integrating MinIO S3 into your applications with minimal setup.

Project description

apiminio

docs.apimin.io Release PyPI Version Build status codecov Commit activity License

apiminio banner

apiminio is a Python package that provides a ready-to-use REST API for interacting with MinIO S3 storage, built with FastAPI and the MinIO Python client. It enables seamless file uploads, downloads, and bucket management via HTTP interface ideal for integrating MinIO S3 into your applications with minimal setup.

📄 Table of Contents

📚 Project

  1. At 1st basic implementation of apiminio, handling buckets and files will be focused.
  2. Security will be at the 2nd development stage using authenticated sessions by credentials as well as tokens.
  3. Certificate handling and TLS will be the 3rd level.

🚦 Prerequisites

🚀 Install

Recommended

uv add apiminio

or use pip

pip install apiminio

💥 Usage 🌰🐿️

Create your python file, e.g., apiminio_server.py, configure your S3 server like:

from apiminio import Apiminio, MinioConfig
from pydantic import SecretStr

app = Apiminio(
    config=MinioConfig(
        endpoint="localhost:9000",
        access_key="minioadmin",
        secret_key=SecretStr("minioadmin"),
        secure=False
    )
)

if __name__ == "__main__":
    # Serve FastAPI using Uvicorn
    import uvicorn

    uvicorn.run("minimal:app", host="0.0.0.0", port=8000, reload=True)

Either just run python apiminio_server.py or use fastapi run apiminio_server.py.

You can use flags and parmeters inherited from FastAPI to deploy your apiminio server via Uvicorn 🦄🐍

🥐 Recommended Dev Setup Kubernetes

This repository has a skaffold.yaml configuration with a working minio as well as the apiminio service to bootstrap the development 😎🙌

🛞 Commands

To clone this repository, run:

git clone https://github.com/raederan/apiminio.git

To instantly provide minio with apiminio, e.g., run:

skaffold dev --no-prune=false --cache-artifacts=false --default-repo localhost:32000/apiminio --port-forward

📜 License

This project is licensed under the terms of the Apache License 2.0.

The banner file is based on an original png generated using Microsoft Copilot and subsequently modified further as svg by the initial author of this repository.

🦥 Authors

Andreas Räder

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

apiminio-0.2.3.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

apiminio-0.2.3-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file apiminio-0.2.3.tar.gz.

File metadata

  • Download URL: apiminio-0.2.3.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.14

File hashes

Hashes for apiminio-0.2.3.tar.gz
Algorithm Hash digest
SHA256 1cd148f3371a56f8f0122de5d33f8ce6d411ab8657295226c59cb1b5894d6ee3
MD5 b1a9041b636da6f2346557db99a7bf0b
BLAKE2b-256 b2bf580b9c9fe7e64d6175542419ba63eb2fd9624c3e1a9c26e7466e332a6fc3

See more details on using hashes here.

File details

Details for the file apiminio-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: apiminio-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.14

File hashes

Hashes for apiminio-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d52ba21bdcd4dddd9a1cebb2f5256415dfa55f4f5e68cfdd3ec98e9914d985dc
MD5 753eb103cd3d69304aa4d53223734243
BLAKE2b-256 5a7042f2833f4c607b292a6361b9849bf9b47817860faa6600e4168d94325656

See more details on using hashes here.

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