terraform-provider-spinnaker
Manage Spinnaker applications and pipelines with Terraform.
Note - this project is experimental and not supported by Armory for production use.
We are not actively developing terraform-provider-spinnaker
. If anyone is interested in taking over maintenance of this project, please reach out to [email protected]
. If you'd like to learn more about what features Armory supports, checkout our Platform Compatibility Matrix.
Demo
Example
provider "spinnaker" {
server = "http://spinnaker-gate.myorg.io"
}
resource "spinnaker_application" "my_app" {
application = "terraformtest"
email = "[email protected]"
}
resource "spinnaker_pipeline" "terraform_example" {
application = "${spinnaker_application.my_app.application}"
name = "Example Pipeline"
pipeline = "${file("pipelines/example.json")}"
}
Installation
Build from Source
Requires Go to be installed on the system.
$ env GO111MODULE=on go get github.com/armory-io/terraform-provider-spinnaker
$ cd $GOPATH/src/github.com/armory-io/terraform-provider-spinnaker
$ env GO111MODULE=on go build
Installing 3rd Party Plugins
See Terraform documentation for installing 3rd party plugins.
Provider
Example Usage
provider "spinnaker" {
server = "http://spinnaker-gate.myorg.io"
config = "/path/to/config.yml"
ignore_cert_errors = true
default_headers = "Api-Key=abc123"
}
Argument Reference
server
- The Gate API Urlconfig
- (Optional) - Path to Gate config file. See the Spin CLI for an example config.ignore_cert_errors
- (Optional) - Set this totrue
to ignore certificate errors from Gate. Defaults tofalse
.default_headers
- (Optional) - Pass through a comma separated set of key value pairs to set default headers for the gate client when sending requests to your gate endpoint e.g. "header1=value1,header2=value2". Defaults to "".
Resources
spinnaker_application
Example Usage
resource "spinnaker_application" "my_app" {
application = "terraformtest"
email = "[email protected]"
}
Argument Reference
application
- Application nameemail
- Owner email
spinnaker_pipeline
Example Usage
resource "spinnaker_pipeline" "terraform_example" {
application = "${spinnaker_application.my_app.application}"
name = "Example Pipeline"
pipeline = file("pipelines/example.json")
}
Argument Reference
application
- Application namename
- Pipeline namepipeline
- Pipeline JSON in string format, examplefile(pipelines/example.json)
spinnaker_pipeline_template
Example Usage
data "template_file" "dcd_template" {
template = "${file("template.yml")}"
}
resource "spinnaker_pipeline_template" "terraform_example" {
template = "${data.template_file.dcd_template.rendered}"
}
Argument Reference
template
- A yaml formated DCD Spec pipeline template
spinnaker_pipeline_template_config
Example Usage
data "template_file" "dcd_template_config" {
template = "${file("config.yml")}"
}
resource "spinnaker_pipeline_template_config" "terraform_example" {
pipeline_config = "${data.template_file.dcd_template_config.rendered}"
}
Argument Reference
pipeline_config
- A yaml formated DCD Spec pipeline configuration