Skip to main content

Configure Travis-CI artifact uploading to S3

Project description

s3same (“sesame”, like “open sesame”) creates unique-per-repo AWS credentials for Travis CI artifact uploading to S3 and encrypts those credentials with the repo’s public key.

Installation

Running the command

sudo pip install s3same

will install the latest stable release of s3same as a command in /usr/local/bin.

Usage

$ s3same --help
Usage: s3same [OPTIONS] REPO

Options:
  --pro               Use Travis CI Pro
  --github TEXT       GitHub token
  --owner TEXT        GitHub owner
  --s3-bucket TEXT    S3 bucket for artifacts
  --aws-region TEXT   AWS region
  --aws-key TEXT      AWS key
  --aws-secret TEXT   AWS secret
  --aws-profile TEXT  AWS profile
  --nuke              Nuke the entire s3same setup on IAM
  --help              Show this message and exit.

Let’s assume you’ve got your AWS credentials in `~/.aws/credentials <http://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html#cli-config-files>`__. Go to your GitHub settings and create a personal access token for s3same (the token must have the repo permission). Create ~/.s3same with:

GITHUB_TOKEN=put your token here
S3_BUCKET=the bucket to which artifacts will be uploaded
AWS_PROFILE=some profile
AWS_REGION=your AWS region

If your AWS credentials are in the default profile, you can omit the AWS_PROFILE line.

With all the credentials in place, running

$ s3same some-repo-name --owner some-user --pro

will create an AWS IAM user unique to the repo (s3same_travis__some-user__some-repo-name), add that user to the s3same_travis AWS IAM group (creating the group if it doesn’t exist) to give it the necessary permissions (defined by the s3same_travis policy, which will be created if it doesn’t exist), generate an AWS key and secret for that user, use the public key for the given repo on Travis CI to encrypt the key and secret, and print out the YAML snippet to use for artifact uploading credentials.

Configuration

Several configuration parameters can be specified by the environment, in the ~/.s3same file, or on the command line. The name/syntax for environment variables and within the ~/.s3same file are the same. Anything in the ~/.s3same file overrides the corresponding environment variable and anything passed as a command-line parameter overrides the environment variables and the ~/.s3same file. Setting an AWS key/secret pair overrides specifying an AWS configuration profile.

Parameter

Variable Name

Command-Line

GitHub Token

GITHUB_TOKEN

--github

GitHub Owner

GITHUB_OWNER

--owner

S3 Bucket

S3_BUCKET

--s3-bucket

AWS Region

AWS_REGION

--aws-region

AWS Key

AWS_ACCESS_KEY_ID

--aws-key

AWS Secret

AWS_SECRET_ACCESS_KEY

--aws-secret

AWS Profile

AWS_PROFILE

--aws-profile

Project details


Release history Release notifications | RSS feed

This version

0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

s3same-0.1.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

s3same-0.1-py2.py3-none-any.whl (8.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file s3same-0.1.tar.gz.

File metadata

  • Download URL: s3same-0.1.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for s3same-0.1.tar.gz
Algorithm Hash digest
SHA256 4c9f3c726c3ed03de711b9ca35e691b80560102cd525b192996bb817cfa05931
MD5 51f743900ff1879273dd4ddd8d6a47e0
BLAKE2b-256 890dd16597dc756cf50d6d782eb9c967f0cb51a8bb8fee6a67abab0e99a7e90d

See more details on using hashes here.

File details

Details for the file s3same-0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for s3same-0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b5187d189292e189051d1c4fb5868968274b6a6c5d380c861ef52a8a45961463
MD5 38923969df0390e430a9ec28d7a81f93
BLAKE2b-256 7ea2a7ed5bd1222ab9223d881e655e874609a1a01de9ba0de483f2b5dbb223b1

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