terraform-provider-persistent

command module
v0.2.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 20, 2023 License: MPL-2.0 Imports: 5 Imported by: 0

README

Persistent Counter provider for Terraform

This provider allows to assign unique, increasing integers to string keys maintaining the same value per key while the key stays assigned.

Example

terraform {
  required_providers {
    persistent = {
      source  = "rosmo/persistent"
      version = ">=0.1.11"
    }
  }
}

variable input {
  type = set(string)
}

resource "persistent_counter" "with-reuse" {
  initial_value = 1
  keys          = var.input
  reuse         = true
}

resource "persistent_counter" "without-reuse" {
  initial_value = 1
  keys          = var.input
  reuse         = false
}

output counters {
  value = {
    "with-reuse" = persistent_counter.with-reuse.values,
    "without-reuse" = persistent_counter.without-reuse.values,
  }
}

Run the example providing an initial value as input results in the following output:

$ terraform apply -auto-approve -var 'input=["c","b","a"]'

counters = {
  "with-reuse" = tomap({
    "a" = 1
    "b" = 2
    "c" = 3
  })
  "without-reuse" = tomap({
    "a" = 1
    "b" = 2
    "c" = 3
  })
}

If values were just added, both, the version with and without reuse enabled behave the same. Also note, that keys are always sorted ascending, before counter values are assigned to them.

The difference the two versions in this example can be made clear when exchanging an element (i.e. removing a value and adding a new one at the same time):

$ terraform apply -auto-approve -var 'input=["c","a","d"]'

counters = {
  "with-reuse" = tomap({
    "a" = 1
    "c" = 3
    "d" = 2
  })
  "without-reuse" = tomap({
    "a" = 1
    "c" = 3
    "d" = 4
  })
}

When reuse is set to true, the counter will re-assign values that are no longer in use, while a value of false will always emit unique, ascending values.

Usage

The provider is available from Terraform registry: registry.terraform.io/providers/rosmo/persistent/latest.

Requirements

  • Terraform >= 1.0
  • Go >= 1.21 (building from source only)

Building The Provider

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

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL