AWS's Serverless Application Model (SAM) is the official AWS provided way to define serverless applications. sammie's purpose is to get you set up and deployed in seconds using SAM.
- Generate a minimal yet flexible SAM template for you to get started.
- Simplify SAM's complex packaging & deploy steps & flags into a simple
deploy
command. - Provide a best practice for deploying multiple environments.
AWS CLI - sammie uses this for all AWS operations under the hood.
npm i sammie -g
sammie init my-app
sammie deploy
This will generate a serverless application, deploy it to a development environment, and direct you to your app served over https!
sammie init <name>
Options:
-y, --yaml
: Generate yaml for SAM template. Defaults to json, because javascript.
sammie deploy
Options:
-t, --template
: Path to a SAM template. Defaults to sam.(json|yaml)
in the current directory.
-e, --environment
: An environment name to deploy. Defaults to "development".
-p, --parameters
: A list of parameters to override in your template.
-s, --stack-name
: Option to override the auto-generated environment stack name.
--s3-bucket
: S3 bucket where code is uploaded. Defaults to Parameters.bucketName in template which is generated for you.
--s3-prefix
: S3 path prefix added to the packaged code file. Defaults to stackName/year.
It's a best practice to create completely separate stacks for each of your application's environments, rather than a single stack with multiple lambda qualifiers, API Gateway stages, and permissions. This makes your application more portable and reduces the blast radius of taking down your live application during the development cycle.
To support this, sammie will deploy separate stacks for you based on the environment option:
E.g. your stack name is "my-app":
sammie deploy
will deploy stack "my-app-development" (development is the default)
sammie deploy --environment production
will deploy stack "my-app-production"
To help add environment specific variables & properties, you can create separate SAM templates named with the environment suffix.
E.g. sam-production.json
containing the following, will get merged with your base template sam.json
upon sammie deploy --environment production
{
"Resources": {
"TestFunction": {
"Properties": {
"MemorySize": 1280,
"Environment": {
"Variables": {
"ENV_VAR1": "var1-prod",
"ENV_VAR2": "var2-prod"
}
}
}
}
}
}