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.0.tar.gz (4.9 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.0-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: connectkit_s3-2.0.0.tar.gz
  • Upload date:
  • Size: 4.9 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.0.tar.gz
Algorithm Hash digest
SHA256 416f1b79b57cc306f89fd6fffcd67693ab98d88d18360c197d9c80b7ca860d1e
MD5 981a941884c46181d2991f4e6a913381
BLAKE2b-256 6cd5cce3f4de3c9247976635889f1446258d81ee9055313aca29a5f3fa719316

See more details on using hashes here.

File details

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

File metadata

  • Download URL: connectkit_s3-2.0.0-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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ed9532f5bd9ad7dab9c2f886b8c3fea76f56e542c44f136b54cdb4ed21d1e597
MD5 2afbdeec691ecae9a8233a1b9cde70e8
BLAKE2b-256 d063d86a462f6c998c03b3d0c2a8a96bff3baa440d4cc50a22485d02ea1b83b4

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