Skip to content

polytomic/terraform-provider-polytomic

Repository files navigation

Polytomic Terraform Provider

This repository contains the Polytomic Terraform provider. This provider may be used to manage on premises deployments.

Example Organization configuration with users

provider "polytomic" {
  deployment_url     = "polytomic.acmeinc.com"
  deployment_api_key = "secret-key"
}

resource "polytomic_organization" "acme" {
  name = "Acme, Inc."
}

resource "polytomic_user" "acme_admin" {
  organization = polytomic_organization.acme.id
  email        = "admin@acmeinc.com"
  role         = "admin"
}

Terraform Importer

See Polytomic Importer

Development

If you wish to work on the provider, you'll first need Go installed on your machine (see Requirements above).

Connections can be added by editing provider/gen/connections/connections.yaml and running go generate

To compile the provider, run go install. This will build the provider and put the provider binary in the $GOPATH/bin directory.

To generate or update documentation, run go generate.

In order to run the full suite of Acceptance tests, run make testacc.

Note: Acceptance tests create real resources, and often cost money to run.

make testacc

Requirements

Building The Provider

  1. Clone the repository
  2. Enter the repository directory
  3. Build the provider using the Go install command:
go install

Adding Dependencies

This provider uses Go modules. Please see the Go documentation for the most up to date information about using Go modules.

To add a new dependency github.com/author/dependency to your Terraform provider:

go get github.com/author/dependency
go mod tidy

Then commit the changes to go.mod and go.sum.

Testing a pre-release version

If you wish to test a pre-release version of the provider, you can use the a .tfrc file to specify the location of your local provider binary. If you installed the provider using go install, create a dev.tfrc file with the following contents, substituting the correct home directory path.

provider_installation {
  dev_overrides {
    "polytomic/polytomic" = "/Users/username/go/bin"
  }

  # all the other providers, install them as usual
  direct {}
}

To instruct Terraform to use those settings, set the TF_CLI_CONFIG environment variable.

$ TF_CLI_CONFIG_FILE=dev.tfrc terraform apply

Releasing

  1. Update CHANGELOG.md with release details and date and commit.

  2. Create an annotated version tag; a version tag consists of the letter v followed by MAJOR.MINOR.PATCH. For example:

    git tag -a v0.2.0
  3. Push the tag to Github.

    git push origin v0.2.0

Github Actions are configured to build release tags and create a new release. Once the release has been created, the Terraform registry will pick it up within a few minutes.