An sbt plugin to deploy a CloudFormation stack generated by the project. Create a main class in the project that accepts a file path as its first argument, and write the stack's CloudFormation template to the given file.
Add the following to project/plugins.sbt
addSbtPlugin("com.dwolla.sbt" % "sbt-cloudformation-stack" % "{version-number}")Then, enable the plugin by adding something like the following to build.sbt:
val app = (project in file(".")).enablePlugins(CloudFormationStack)Filename of the generated JSON CloudFormation template.
Name of the stack. Defaults the normalized name of the project.
List of key-value pairs that will be provided to the stack as parameters. These can accept task or setting values; e.g., S3 bucket and keys from the S3 Publisher plugin.
stackParameters ++= List(
  "S3Bucket" → s3Bucket.value,
  "S3Key" → s3Key.value
)If supplied, CloudFormation will create a change set to allow stack creates or update to be evaluated before being completed.
Runs the main class of the project, passing templateJson as the first argument.
Creates or updates a CloudFormation stack using the generated JSON template.
Allows certain deploy parameters to be set on the command line, with some input validation. The parameters that will be overridden are as follows:
- 
awsAccountIdmust be a 12-digit AWS Account ID
- 
awsRoleNamemust match the patternrole/{name}, and the value will be set to{name}
- 
stackRoleArnwill be set to a full ARN ifawsAccountIdandawsRoleNameare set, or toNoneif either are missing
- 
deployEnvironmentmust be one of the values indeployEnvironmentOptions, and will add a stack parameter named usingdeployEnvironmentParameterName.The default deployEnvironmentParameterNameisEnvironment, so settingdeployEnvironmenttoAdminwould add a stack parameter namedEnvironmentwith the valueAdmin.
Note that all these will be set if the command is invoked. Missing values will be set to None. The parameters can be passed in any order.
For example,
sbt "withDeployParameters 123456789012 role/myRole Admin" deploywill add a stack parameter Environment → Admin and create or update the stack using the AWS role arn:aws:iam::123456789012:role/myRole.