A CloudFormation Public Extension is typically a CloudFormation resource type developed by a third-party publisher, like Redis. Such an extension can allow AWS customers to integrate Redis-specific resources, which are only available over the Redis API, in their CloudFormation templates.
The AWS CloudFormation registry serves as a centralized hub to discover, manage, and provision these extensions.
There are currently three Redis resource types that can be provisioned via CloudFormation. The resource types act as a wrapper around our API [1]. How resource types relate to the API can be seen in the diagram below.
- Redis Cloud API keys are required to use CloudFormation Public Extensions. Please have your API Keys ready
- Find the CreateSecrets.yml in the root of this project.
- Run this CloudFormation template and replace the placeholders for secrets manually once the creation is done.
- The secret will be set up following this format:
SecretName: cfn/profile/{ProfileName}
SecretValue: {"PublicKey": "YourPublicKey", "PrivateKey": "YourPrivateKey"}
- If you desire a different naming convention for your secrets, feel free to either change the CloudFormation Template or create the secret in any other way. Please keep in mind to change the secrets name in the type-configuration in step 4.
- Activate the extension from the Extension Registry. This can we done in the CloudFormation UI but also programatically.
- In the command below
- Change the region parameter to the AWS region you required
- Change the key value information if you used a different secret name from Step 1
- Run the command in CloudShell or similar.
aws cloudformation set-type-configuration \
--region eu-west-1 \
--type-name "Redis::CloudFormation::ProSubscription" \
--type RESOURCE \
--configuration-alias default \
--configuration '{"RedisAccess": {"xapikey": "{{resolve:secretsmanager:"Secret Name":SecretString:"Secret Key for x_api_key"}}", "xapisecretkey": "{{resolve:secretsmanager:"Secret Name":SecretString:"Secret Key for x_api_secret_key"}}"}}'
If you like to contribute to this project it is heavily recommended to read the AWS documentation for 'Extension Development for CloudFormation' [2] first.
It is possible to freely test any feature by registering this extension to your own AWS account as a private extension.
If you like to publish your change via Redis then please create a PR to this Repository. Please note: In order for your code to be in the public AWS registry it needs to pass a specific set of tests [3]. Please especially focus on frequently running contract tests [4].
[...]
[1] https://api.redislabs.com/v1/swagger-ui/index.html#/ [2] https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-develop.html [3]https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html [4] https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-test.html