Skip to main content

Wrapper for connection to S3

Project description

ConnectKit S3 [en|ru]


ConnectKit S3 is a wrapper for boto3 and aioboto3 to simplify working with S3 storages.

Includes pydantic settings, template code.

Installation


To install the sync version:

pip install ConnectKit-S3

To install the async version:

pip install ConnectKit-S3[async]

Usage


These variables from settings are used for connection by default. All variables are optional.

The first four are responsible for setting up the default connection, you need to specify everything except the region to enable it.

Bucket is used by default unless another one is programmatically selected.

Variables are extracted from the environment:

AWS_HOST=str               # Address of S3 server
AWS_ACCESS_KEY_ID=str      # Access key
AWS_SECRET_ACCESS_KEY=str  # Secret key
AWS_REGION=str             # Region, optional
AWS_BUCKET=str             # Default bucket

These variables can be overridden:

from s3.settings import settings

settings.AWS_BUCKET = "some_bucket"

!! Attention !! After creating a default connection, changing the settings variables for it is ignored.

The s3 and async_s3 functions are used to open the connection.

Uploading and downloading files requires:

  • Synchronous mode requires a synchronous file descriptor open in binary mode.
  • Asynchronous mode requires the aiofiles binary file descriptor
from s3 import s3
from s3.asyncio import async_s3

# Synchronous
client = s3()
if client.has_file("s3_filename"):
    pass

# Asynchronous
client = async_s3

async with client() as conn:
    if conn.has_file("s3_filename"):
        pass

License


ConnectKit S3 is 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

connectkit_s3-2.0.1.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

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

connectkit_s3-2.0.1-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file connectkit_s3-2.0.1.tar.gz.

File metadata

  • Download URL: connectkit_s3-2.0.1.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.21.0 CPython/3.10.11 Windows/10

File hashes

Hashes for connectkit_s3-2.0.1.tar.gz
Algorithm Hash digest
SHA256 26435476a6d18064b6ede10c9a4c4e28bf2b28ace47b7bb6dee1574f254cf015
MD5 d54e00548d6c3be04a1acaa70f6b07b6
BLAKE2b-256 6d8d6a9a92564e3864961b1b9ccd0ee6bcd20746e9aaec2aab635b4350625222

See more details on using hashes here.

File details

Details for the file connectkit_s3-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: connectkit_s3-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.21.0 CPython/3.10.11 Windows/10

File hashes

Hashes for connectkit_s3-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c2bc666ca3330f000167f087a6e4561b94275175fee6c331193501f1e41cce6e
MD5 716ce8f5eeb7dc2a67f5b8f2aa7bbdb2
BLAKE2b-256 dd013d2513847247766a389da9a69eb022f032aa7310d620bcc2a64d75c9c7ab

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