Skip to main content

A python library to sign AWS requests using AWS Signature V4.

Project description

aws-request-signer

A python library to sign AWS requests using AWS Signature V4.

This small python library serves only purpose: Helping you sign HTTP requests for use with AWS (and compatible) services. The library is unopinionated and should work with just about anything that makes HTTP requests (requests, aiohttp).

It supports generating authorization headers for HTTP requests, pre-signing URLs so you can easily use them elsewhere and signing S3 POST policies for use in HTML forms.

This library has no requirements, but comes with an authentication helper for the requests package.

Installation

aws-request-signer is available from pypi:

pip install aws-request-signer

Usage example

Here's an example of how to use the library to sign a request to upload a file to a minio S3 bucket running on your local machine:

import hashlib

import requests
from aws_request_signer import AwsRequestSigner

AWS_REGION = ""
AWS_ACCESS_KEY_ID = "minio"
AWS_SECRET_ACCESS_KEY = "minio123"

URL = "http://127.0.0.1:9000/demo/hello_world.txt"

# Demo content for our target file.
content = b"Hello, World!\n"
content_hash = hashlib.sha256(content).hexdigest()

# Create a request signer instance.
request_signer = AwsRequestSigner(
    AWS_REGION, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, "s3"
)

# The headers we'll provide and want to sign.
headers = {"Content-Type": "text/plain", "Content-Length": str(len(content))}

# Add the authentication headers.
headers.update(
    request_signer.sign_with_headers("PUT", URL, headers, content_hash)
)

# Make the request.
r = requests.put(URL, headers=headers, data=content)
r.raise_for_status()

For more examples and usage, please refer to demo.py.

Development setup

For development purposes, you can clone the repository and use poetry to install and maintain the dependencies. There is no test suite. It comes with a set of pre-commit hooks that can format (isort, black) and check your code (mypy, flake8) automatically.

git clone git@github.com:iksteen/aws-request-signer.git
cd aws-request-signer
poetry install -E demo
poetry run pre-commit install

Release History

  • 1.2.0
    • Add support for passing a security token to AwsRequestSigner and AwsAuth helper for request. Thanks @ajpl.
  • 1.1.1
    • Use quote instead of the default quote_plus so query arguments that contain spaces work (thanks @eraser-77).
  • 1.1.0
    • Minimum supported python version is now 3.6.1.
    • Assume empty content when signing a HEAD or DELETE request just as we do when signing a GET request. Thanks @alvassin!
    • Fix bug where sign_with_headers did not include valueless query arguments in the signing process (f.e. ?acl).
  • 1.0.0
    • Initial Release.

Meta

Ingmar Steen – @iksteen

Distributed under the MIT license. See LICENSE for more information.

https://github.com/iksteen/

Contributing

  1. Fork it (https://github.com/iksteen/aws-request-signer/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

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

aws_request_signer-1.2.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

aws_request_signer-1.2.0-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file aws_request_signer-1.2.0.tar.gz.

File metadata

  • Download URL: aws_request_signer-1.2.0.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.9 Linux/6.1.7-arch1-1

File hashes

Hashes for aws_request_signer-1.2.0.tar.gz
Algorithm Hash digest
SHA256 0d5a2b0ced30cfde0585db9ac7b56c419e41e529c17ec1d0a0ba16e26e827be5
MD5 773864936bfaae5a8f764e2ea3e295c6
BLAKE2b-256 63ab2ca5870971f1e3601e27d22c0290a75dd90bcce066a67884d9034b7cf765

See more details on using hashes here.

File details

Details for the file aws_request_signer-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for aws_request_signer-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eb5bca05d5055a608078be5f47bb6a333f1e5c383ed7603a75289e04203a10a6
MD5 82ca126bf89211e5915564b82df0ed69
BLAKE2b-256 3416fc50db007b6cc69c53e3f3bbdd97dfde03aa8c0bb2b2f6c6c924ccd85eaf

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