Skip to main content

Upload directories to AWS S3

Project description

s3push

Codacy Badge Build Status PyPI version License: MIT

Upload whole directories or distinct files to AWS S3 using s3push in command line. Extensive support for different credential sources.

Project goal

This tool facilitates painless upload of directories to AWS S3. The initial goal was to provide developers with a simple tool that allows them to upload whole directories to S3 with a minimal effort. Initial project vision also contained an option to create and configure a fresh S3-hosted website from scratch.

However, the tool has been written after a very quick research and, as a result, suffered from the "Not invented here" syndrome. After a bit more careful research it was discovered that not only the other directory uploading tools exist, but also that there are far more superior instruments that also allow configuration of buckets and CloudFront CDN (i.e., s3cmd). See the rough feature set comparison in the docs.

As a project's post-mortem, it can be concluded that a proper research must be performed prior to the start of development. For example, before developing a new library or a tool it may be very useful to make a simple feature set comparison.

The project will, however, continue to exist as a demonstration of continuous delivery setup for a python package development. The environment for the project is designed to support fully automated releases and testing.

Installation

Recommended installation method is via Pipenv:

pipenv install s3push

Installing via Pip instead of Pipenv:

pip install s3push

Usage

Publish a directory with default credentials

s3push ~/my-website/ example.com

Publish a file using default credentials

s3push ~/my-website/index.html example.com

Publish with provided key pair

s3push ~/my-website/ example.com -k XXXXXXXXXXXXXXXXXXXX -s xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

Publish with saved profile by providing its name

s3push ~/my-website/ example.com -p my-deployment-profile

Note: see all possible options for specifying credentials below.

Priority of credentials providers

  1. Passing credentials as optional arguments: -k AWS_ACCESS_KEY_ID, -s AAWS_SECRET_ACCESS_KEY.
  2. Passing profile name of pre-configured credentials as optional argument: -p PROFILE_NAME.
  3. Environment variables, as listed in the boto3 guide.
  4. Default credentials in the shared credential file (~/.aws/credentials).
  5. Default credentials in the AWS config file (~/.aws/config).
  6. Boto2 config file (/etc/boto.cfg and ~/.boto).

Continuous Delivery

Branch Travis-CI Status CircleCI Status
master Build Status CircleCI
dev Build Status CircleCI

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

s3push-2019.10.14.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

s3push-2019.10.14-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

Details for the file s3push-2019.10.14.tar.gz.

File metadata

  • Download URL: s3push-2019.10.14.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.7

File hashes

Hashes for s3push-2019.10.14.tar.gz
Algorithm Hash digest
SHA256 58306407c081f07dae1d6c4010cec60d3e50c1b1acc242755b66a5ee0db6c2d9
MD5 728fdbc7eca157e9da71151ee9abc6e6
BLAKE2b-256 83a951d740705407524e5ec4d18e32d2dc1c02ece9d837a1177351a0bf570ff0

See more details on using hashes here.

File details

Details for the file s3push-2019.10.14-py3-none-any.whl.

File metadata

  • Download URL: s3push-2019.10.14-py3-none-any.whl
  • Upload date:
  • Size: 6.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.7

File hashes

Hashes for s3push-2019.10.14-py3-none-any.whl
Algorithm Hash digest
SHA256 6dbed5196fc53d2d4251863d537e0ef7abf1ad9739d56ff0a85a323a44cbda5e
MD5 e28f9805829fafe94ddf0af6fa1b4c61
BLAKE2b-256 9dfc200d7c9d4fceaceb212240743a52dee7daeea7f740e9199f7121095a80f9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page