Skip to content
/ s3proxy Public

S3proxy provides a simple REST-interface to files and keys stored on the AWS S3 service.

License

Notifications You must be signed in to change notification settings

nkrumm/s3proxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

S3proxy - serve S3 files simply

S3proxy is a simple flask-based REST web application which can expose files (keys) stored in the AWS Simple Storage Service (S3) via a simple REST api.

What does this do?

S3proxy takes a set of AWS credentials and an S3 bucket name and provides GET and HEAD endpoints on the files within the bucket. It uses the boto library for internal access to S3. For example, if your bucket has the following file:

s3://mybucket/examples/path/to/myfile.txt

then running S3proxy on a localhost server (port 5000) would enable you read (GET) this file at:

http://localhost:5000/files/examples/path/to/myfile.txt

Support exists in S3proxy for the byte-range header in a GET request. This means that the API can provide arbitrary parts of S3 files if requested/supported by the application making the GET request.

Why do this?

S3proxy simplifies access to private S3 objects. While S3 already provides a complete REST API, this API requires signed authentication headers or parameters that are not always obtainable within existing applications (see below), or overly complex for simple development/debugging tasks.

In fact, however, S3proxy was specifically designed to provide a compatability layer for viewing DNA sequencing data in(.bam files) using IGV. While IGV already includes an interface for reading bam files from an HTTP endpoint, it does not support creating signed requests as required by the AWS S3 API (IGV does support HTTP Basic Authentication, a feature that I would like to include in S3proxy in the near future). Though it is in principal possible to provide a signed AWS-compatible URL to IGV, IGV will still not be able to create its own signed URLs necessary for accessing .bai index files, usually located in the same directory as the .bam file. Using S3proxy you can expose the S3 objects via a simplified HTTP API which IGV can understand and access directly.

This project is in many ways similar to S3Auth, a hosted service which provides a much more complete API to a private S3 bucket. I wrote S3proxy as a faster, simpler solution-- and because S3Auth requires a domain name and access to the CNAME record in order to function. If you want a more complete API (read: more than just GET/HEAD at the moment) should check them out!

Features

  • Serves S3 file objects via standard GET request, optionally providing only a part of a file using the byte-range header.
  • Easy to configure via a the config.yaml file-- S3 keys and bucket name is all you need!
  • Limited support for simple url-rewriting where necessary.
  • Uses the werkzeug SimpleCache module to cache S3 object identifiers (but not data) in order to reduce latency and lookup times.

Usage

Requirements

To run S3proxy, you will need:

  • Flask
  • boto
  • PyYAML
  • An Amazon AWS account and keys with appropriate S3 access

Installation/Configuration

At the moment, there is no installation. Simply put your AWS keys and bucket name into the config.yaml file:

AWS_ACCESS_KEY_ID: ''
AWS_SECRET_ACCESS_KEY: ''
bucket_name: ''

You may also optionally specify a number of "rewrite" rules. These are simple pairs of a regular expression and a replacement string which can be used to internally redirect (Note, the API does not actually currently send a REST 3XX redirect header) file paths. The example in the config.yaml file reads:

rewrite_rules:
    bai_rule:
        from: ".bam.bai$"
        to: ".bai"

... which will match all url/filenames ending with ".bam.bai" and rewrite this to ".bai".

If you do not wish to use any rewrite_rules, simply leave this commented out.

Running S3cmd:

Once you have filled out the config.yaml file, you can test out S3proxy simply by running on the command line:

python app.py

Note: Running using the built-in flask server is not recommended for anything other than debugging. Refer to these deployment options for instructions on how to set up a flask applicaiton in a WSGI framework.

Options

If you wish to see more debug-level output (headers, etc.), use the --debug option. You may also specify a yaml configuration file to load using the --config parameter.

Important considerations and caveats

S3proxy should not be used in production-level or open/exposed servers! There is currently no security provided by S3proxy (though I may add basic HTTP authentication later). Once given the AWS credentials, S3proxy will serve any path available to it. And, although I restrict requests to GET and HEAD only, I cannot currently guarantee that a determined person would not be able to execute a PUT/UPDATE/DELETE request using this service. Finally, I highly recommend you create a separate IAM role in AWS with limited access and permisisons to S3 only for use with S3proxy.

Future development

  • Implement HTTP Basic Authentication to provide some level of security.
  • Implement other error codes and basic REST responses.
  • Add ability to log to a file and specify a --log-level (use the Python logging module)

About

S3proxy provides a simple REST-interface to files and keys stored on the AWS S3 service.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages