Skip to main content

Hatch plugin for deploying to AWS with SAM

Project description

hatch-aws-publisher

PyPI - Version PyPI - Python Version Hatch project code style - black types - mypy imports - isort

AWS publisher plugin for Hatch 🥚🐍. Hatch is modern, extensible Python project manager.


Table of Contents

How to enable

Plugin must be installed in the same environment as Hatch itself.

python -m venv .venv
.venv/bin/pip install hatch-aws-publisher

How to use it

The publisher plugin name is called aws.

  1. Build you app with SAM. You can use my Hatch plugin hatch-aws.

  2. Put your SAM config to pyproject.toml (stack name is by default name of your project):

    [project]
    name = "my-app"
    
    [tool.hatch.publish.aws.sam]
    region = "us-west-1"
    confirm_changeset = false
    fail_on_empty_changeset = false
    force_upload = true
    capabilities = "CAPABILITY_IAM"
    s3_bucket = "my-bucket"
    parameter_overrides = ["stage=dev"]
    
    [tool.hatch.publish.aws.sam.tags]
    job = "batman"
    name = "bruce"
    
  3. Publish (deploy) your app.

    hatch publish -p aws
    

Options

section tool.hatch.publish.aws

This section allows to modify behavior of the plugin. Available options:

[tool.hatch.publish.aws]
stack_name_append_env = true
stack_name_prefix = "super-"
stack_name_suffix = "-man"

All above options can be overwritten using a CLI parameter

.venv/hatch/bin/hatch publish -p aws -o stack_name_prefix="bat-"
  • stack_name_prefix: adds a prefix to a stack name -> bat-my-app
  • stack_name_suffix: adds a suffix to a stack name -> bat-my-app-man
  • stack_name_append_env: adds a selected environment to a stack name -> bat-my-app-man-dev

section tool.hatch.publish.aws.sam

Default values for SAM. You can use any key:value pair available in SAM config.

Only difference is format of tags (they use separate section):

[tool.hatch.publish.aws.sam.tags]
job = "batman"
name = "bruce"

section tool.hatch.publish.aws.sam.env.<env-name>

You can define specific deployment environments. They inherit values from tool.hatch.publish.aws.sam.

Environment settings in pyproject.toml:

[tool.hatch.publish.aws.sam]
region = "us-west-1"
confirm_changeset = false
fail_on_empty_changeset = false
force_upload = true
capabilities = "CAPABILITY_IAM"

[tool.hatch.publish.aws.sam.env.dev]
region = "us-west-2"
s3_bucket = "dev-bucket"
parameter_overrides = ["stage=dev"]

[tool.hatch.publish.aws.sam.env.prd]
s3_bucket = "prd-bucket"
parameter_overrides = ["stage=prd"]
fail_on_empty_changeset = true

You need to specify an environment using a CLI parameter:

hatch publish -p aws -o env=dev

License

Plugin hatch-aws-publisher is distributed under the terms of the MIT license.

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

hatch_aws_publisher-0.1.0.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

hatch_aws_publisher-0.1.0-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

Details for the file hatch_aws_publisher-0.1.0.tar.gz.

File metadata

  • Download URL: hatch_aws_publisher-0.1.0.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.23.3

File hashes

Hashes for hatch_aws_publisher-0.1.0.tar.gz
Algorithm Hash digest
SHA256 95c8f07c923de5e5995cc567c0641088fe5f0539b68965d9a003abd0d5e46a7b
MD5 a2f8d992a6640c0d1bbc9edab4545ff2
BLAKE2b-256 242158a2b35955986f29827c1c1d50a919b649ea6f0652e94cb5c883fd7b4a94

See more details on using hashes here.

File details

Details for the file hatch_aws_publisher-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for hatch_aws_publisher-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 773abe4546249be3bfd5d8d702a86b2aad652bfba52b1bfac8c7f743295dcab6
MD5 44c89e16042a210e578d19367f8755c5
BLAKE2b-256 e3d9ed7a893de008d5647554be33a8614a780b6a1044c95e5bbf9cbefe3bba01

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