Skip to main content

Typescript language support for the CloudFormation CLI

Project description

AWS CloudFormation Resource Provider Typescript Plugin

We're excited to share our progress with adding new languages to the CloudFormation CLI!

AWS CloudFormation Resource Provider TypeScript Plugin

GitHub Workflow Status Codecov GitHub release Node.js version

The CloudFormation CLI (cfn) allows you to author your own resource providers that can be used by CloudFormation.

This plugin library helps to provide TypeScript runtime bindings for the execution of your providers by CloudFormation.

Usage

If you are using this package to build resource providers for CloudFormation, install the CloudFormation CLI TypeScript Plugin - this will automatically install the CloudFormation CLI! A Python virtual environment is recommended.

Prerequisites

  • Python version 3.6 or above
  • SAM CLI
  • Your choice of TypeScript IDE

Installation

pip install cloudformation-cli-typescript-plugin

Refer to the CloudFormation CLI User Guide for the CloudFormation CLI for usage instructions.

Howto

Example run:

$ cfn init
Initializing new project
What's the name of your resource type?
(Organization::Service::Resource)
>> Foo::Bar::Baz
Select a language for code generation:
[1] java
[2] typescript
(enter an integer):
>> 2
Use docker for platform-independent packaging (Y/n)?
This is highly recommended unless you are experienced
with cross-platform Typescript packaging.
>> y
Initialized a new project in <>
$ cfn submit --dry-run
$ sam local invoke --event sam-tests/create.json TestEntrypoint

Development

For changes to the plugin, a Python virtual environment is recommended. Check out and install the plugin in editable mode:

python3 -m venv env
source env/bin/activate
pip3 install -e /path/to/cloudformation-cli-typescript-plugin

You may also want to check out the CloudFormation CLI if you wish to make edits to that. In this case, installing them in one operation works well:

pip3 install \
  -e /path/to/cloudformation-cli \
  -e /path/to/cloudformation-cli-typescript-plugin

That ensures neither is accidentally installed from PyPI.

Linting and running unit tests is done via pre-commit, and so is performed automatically on commit after being installed (pre-commit install). The continuous integration also runs these checks. Manual options are available so you don't have to commit:

# run all hooks on all files, mirrors what the CI runs
pre-commit run --all-files
# run unit tests only. can also be used for other hooks, e.g. black, flake8, pylint-local
pre-commit run pytest-local

License

This library is licensed under the Apache 2.0 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

Built Distribution

File details

Details for the file cloudformation-cli-typescript-plugin-1.0.0.tar.gz.

File metadata

  • Download URL: cloudformation-cli-typescript-plugin-1.0.0.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.7.7

File hashes

Hashes for cloudformation-cli-typescript-plugin-1.0.0.tar.gz
Algorithm Hash digest
SHA256 776555543058064473b7140181b5910a4afdbe076151bfec825c045dd1d723f3
MD5 df24ab5bcfc2fae405ea7127697aa09e
BLAKE2b-256 a4d829dc3bba6be1e85ed9cdc934bdd737184e95a607d29cead689486b7beb58

See more details on using hashes here.

File details

Details for the file cloudformation_cli_typescript_plugin-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for cloudformation_cli_typescript_plugin-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2239a156f96f815ef0c3fa2d15f1938332f1661da1ecd853a0a192229a124c21
MD5 c3f32ea663ec512252a46fcb48a42042
BLAKE2b-256 05b8878e0060d0207784380404a0e59984b847c69b71cc78d59fdb25e99d17a3

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