A basic Terraform provider for Aviatrix. Read this tutorial as an alternative to the README, only if the instructions are unclear.
Requirements
- Install Terraform 0.10.x/0.11.x (0.12.x is incompatible)
- Install Go 1.11+ (This will be used to build the provider plugin.)
- Create a directory, go, follow this doc to edit ~/.bash_profile to setup the GOPATH environment variable)
Building The Provider
Clone repository to: $GOPATH/src/github.com/terraform-providers/terraform-provider-aviatrix
$ mkdir -p $GOPATH/src/github.com/terraform-providers
$ cd $GOPATH/src/github.com/terraform-providers
$ git clone https://github.com/AviatrixSystems/terraform-provider-aviatrix
To clone on windows
mkdir %GOPATH%\src\github.com\terraform-providers
cd %GOPATH%\src\github.com\terraform-providers
git clone https://github.com/AviatrixSystems/terraform-provider-aviatrix
Enter the provider directory and build the provider
$ cd $GOPATH/src/github.com/terraform-providers/terraform-provider-aviatrix
$ make fmt
$ make build
To build on Windows
cd %GOPATH%\src\github.com\terraform-providers\terraform-provider-aviatrix
go fmt
go install
Using Aviatrix Provider
Activate the provider by adding the following to ~/.terraformrc
on Linux/Unix.
providers {
"aviatrix" = "$GOPATH/bin/terraform-provider-aviatrix"
}
For Windows, the file should be at '%APPDATA%\terraform.rc'. Do not change $GOPATH to %GOPATH%.
In Windows, for terraform 0.11.8 and lower use the above text.
In Windows, for terraform 0.11.9 and higher use the following at '%APPDATA%\terraform.rc'
providers {
"aviatrix" = "$GOPATH/bin/terraform-provider-aviatrix.exe"
}
If the rc file is not present, it should be created
Examples
Check examples here. (Outdated)
Visit here for the complete documentation for all resources
Controller version
Due to some non-backward compatible changes in REST API not all controller versions are supported.
If you find a branch with the controller version please use that branch
Controller versions older than 3.3 are not supported
For example:
- UserConnect-3.3 for 3.3.x controller version
- UserConnect-3.4 for 3.4.x controller version
master branch supports latest controller version but please use the branch specific to your controller version. This is so that you do not go out of sync with the controller.(For instance, the master branch code may get updated to be only 4.2 compatible but your controller may still be running 4.1)
We also recommend you to update to the latest controller version to stay on top of fixes/features.