A small tool to parse URLs for S3 compatible storage services
Project description
Parses S3 credentials from the given string and returns it in comfortable format to pass to popular clients like boto3.
About
This is a small utility to parse locations of buckets of S3-compatible storage (and, of course, the original Amazon’s S3 itself) given in the URL form like s3://bucket/.
It could be useful in our epoch of the 12-factor applications when it’s a good practice to store credentials inside of environment variables.
Also, these days, there are some notable S3-compatible storage services:
And dozens of others.
With s3-parse-url, you can use any one of these services with no doubts about configuration endpoints. For example, you can connect to your Selectel storage with boto3 just using selectel://my-bucket DSN.
That’s an example, what it was all about:
from s3_parse_url import s3_parse_url
from s3_parse_url.ext.clients import get_boto3_client
dsn = "s3://AKIA***OO:XP***@my-bucket/?region=us-east-2"
# It's a completely ready boto3 client instance to work with Selectel
s3_client = get_boto3_client(dsn)
Of course, in the code above we worked with Selectel (have you ever heard about it?). You can work this way with any S3 compatible storage. If you prefer unknown storage, you can easily create a plugin to add support for your favorite service. Or, if you are a pervert, you can use a universal S3:// scheme, but in this case, you should manage endpoints by yourself:
from s3_parse_url.ext.clients import get_boto3_client
# Also should work
dsn = "s3://my-minio-user:my-minio-pass@minio.example.com:9000/?region=us-east-1"
# A ready client to work with a minio instance
s3_client = get_boto3_client(dsn)
Supported providers
Currently we have support for these storages
Amazon S3
Selectel
Yandex
Mail.ru
MinIO
But you can easily add your own one.
License
This project is licensed under the terms of the 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
Built Distribution
Hashes for s3_parse_url-0.2.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a8f0bdbab41186f89213fc52310457558b338db2f25a7d3e947c438f0b99e4a0 |
|
MD5 | 14686850998083956b82e10d060b66f8 |
|
BLAKE2b-256 | 2ddac043531f07e9179692f7a07d987d2367378cedaf255cfcf25ec5f51df616 |