Utility package to help managing configuration files stored in S3-like services.
There are binaries for Linux and Mac:
sudo curl -L "https://github.com/sbneto/s3conf/releases/download/0.10.2/s3conf-$(uname -s)-$(uname -m)" -o /usr/local/bin/s3conf
sudo chmod 755 /usr/local/bin/s3conf
For Alpine linux, use
sudo curl -L "https://github.com/sbneto/s3conf/releases/download/0.10.2/s3conf-$(uname -s)-$(uname -m)-alpine" -o /usr/local/bin/s3conf
sudo chmod 755 /usr/local/bin/s3conf
If it is not available for your platform, you can use pip to install with one or both extras (aws and gcp):
pip install s3conf[aws,gcp]
Run this command in the project root:
s3conf init dev s3://my-dev-bucket/dev-env/myfile.env
This will create the file s3conf.ini
if it does not exist and add the following lines to it:
[dev]
S3CONF = s3://my-dev-bucket/dev-env/myfile.env
If you have a aws-cli
working, s3conf
will user your default credentials. This can be done with:
aws configure
Similarly, s3conf
looks for default gcp credentials.
gcloud auth application-default login
If you do not have a configured aws-cli, the client will search for these authentication variables in order to access the remote storage:
S3CONF_ACCESS_KEY_ID=***access_key***
S3CONF_SECRET_ACCESS_KEY=***secret_access_key***
S3CONF_S3_ENDPOINT_URL=***endpoint_url***
These variables map to their AWS_
counterpart used for regular Boto3 configuration.
The client also searchs for the regular AWS_
variables, but their S3CONF_*
version take precedence.
They are particularly useful when using non-aws blob storage services that are compatible with S3,
such as DigitalOcean Spaces, without messing your AWS credentials.
Run this command in any folder of the project:
s3conf env dev -e
If it is a new bucket/file, use the -c
flag to create it:
s3conf env dev -ec
This will download the environment file from the S3-like storage to a temporary file, open your
default file editor for manual editing (much like as crontab -e
works) and upload the file back
to the remote storage service if any edits were made.
Running s3conf env dev
in any folder of the project reads and output to stdout the contents
of the environment file, while logs are sent to stderr:
$ s3conf env dev
info: Loading configs from s3://my-dev-bucket/dev-env/myfile.env
ENV_VAR_1=some_data_1
ENV_VAR_2=some_data_2
ENV_VAR_3=some_data_3
To apply this environment to your current shell you can do the following:
$ export $(s3conf env dev)
info: Loading configs from s3://my-dev-bucket/dev-env/myfile.env
If you have some file or folder that you want to save in the environment, you can add a mapping:
s3conf add dev ./some-credentials-file-or-folder
s3conf push dev
Use the -m
flag to download the file mappings to your current project folder:
export $(s3conf env dev -m)
The most straight forward way to use this client with docker is to create an entrypoint.sh
in your image
that sets the environment variables and map all needed files:
#!/usr/bin/env bash
set -e
export $(s3conf env dev -m)
exec "$@"
And use it when running your container (assuming your entrypoint is in /app/entrypoint.sh
and is executable)
docker run --entrypoint `/app/entrypoint.sh` my_image my_command