Skip to main content

Send a response object to a custom resource by way of an Amazon S3 presigned URL

Project description

Streamline AWS CloudFormation Custom Resource Management with Python's cfnresponse2

Simplify the management of custom resources in AWS CloudFormation, especially within AWS Lambda environments, using the cfnresponse2 Python package.

Installation

You can effortlessly install the cfnresponse2 package via pip:

pip install cfnresponse2

Alternatively, you have the option to download it directly or upload it to Amazon S3:

import urllib3, sys, os

sys.path.append("/tmp")
raw_url = "https://raw.githubusercontent.com/ggiallo28/cfnresponse/master/cfnresponse/__init__.py"
with open("/tmp/cfnresponse.py", "wb") as f, urllib3.PoolManager() as http:
    f.write(http.request("GET", raw_url).data)

from cfnresponse import register_handler, lambda_handler


@register_handler("create", "update", "delete")
def myfun(event, context):
    return {}

Practical Use Cases

cfnresponse2 is designed with AWS Lambda functions in mind, serving as custom resource handlers in CloudFormation stacks. It simplifies CloudFormation operations such as creating, updating, and deleting custom resources. This empowers you to execute custom logic during stack operations.

For comprehensive examples showcasing effective usage of the cfnresponse2 package, explore the samples directory within the repository. These samples cover various scenarios of custom resource management within CloudFormation.

from cfnresponse import register_handler, lambda_handler

@register_handler("create")
def custom_create(event, context):
    # Your custom logic for handling the 'create' action
    response_data = {"message": "Resource creation successful"}
    return response_data

@register_handler("update")
def custom_update(event, context):
    # Your custom logic for handling the 'update' action
    response_data = {"message": "Resource update successful"}
    return response_data

@register_handler("delete")
def custom_delete(event, context):
    # Your custom logic for handling the 'delete' action
    response_data = {"message": "Resource deletion successful"}
    return response_data

Repository Structure

The project repository is organized as follows:

  • cfnresponse: Houses the __init__.py file, serving as the core of the cfnresponse2 module.
  • LICENSE: Contains licensing information associated with the package.
  • README.md: The document you are currently reading, offering essential instructions for usage.
  • samples: Contains sample Lambda functions that provide practical demonstrations of cfnresponse2 usage. The actual code resides in the repository, not within this README.
  • setup.py: A configuration file for setting up the package.
  • tests: Contains test cases tailored to evaluate the functionality of the cfnresponse2 package.

Important Note

cfnresponse2 maintains compatibility with Amazon Web Services (AWS) cfnresponse module, readily available within Python AWS Lambda environments. You can seamlessly update your code with this package, ensuring a smooth transition without disruptions.

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

cfnresponse2-1.0.7.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

cfnresponse2-1.0.7-py2.py3-none-any.whl (8.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file cfnresponse2-1.0.7.tar.gz.

File metadata

  • Download URL: cfnresponse2-1.0.7.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.17

File hashes

Hashes for cfnresponse2-1.0.7.tar.gz
Algorithm Hash digest
SHA256 8b83bf241fe307eb9445e6460fa97532d90b3620df708d9ecd0d28160fd4e7df
MD5 67cf6cc9f2bb9d723da7be4363d7e080
BLAKE2b-256 d80817cc185b9d5afbe06dce5eb9b80adefb0795041459623ad8ab2e8eaf3a75

See more details on using hashes here.

File details

Details for the file cfnresponse2-1.0.7-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for cfnresponse2-1.0.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9ae69e51c71a62d450d84f88f335c50e047fecfd25c9c61f6e72eb36a1f9653c
MD5 27c7fce86435b5386f1c8285cc61a11b
BLAKE2b-256 9c4a877a6c43aa6a04d47a42e3bfd5a561ff6de46d23e80d6e6199eac27ea9a1

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