Requirements
- Terraform >=0.13.x
- Go 1.16.x (to build the provider plugin)
Building The Provider
$ git clone git@github.com:disc/terraform-provider-pritunl
$ make build
Example usage
Take a look at the examples in the documentation of the registry
or use the following example:
# Set the required provider and versions
terraform {
required_providers {
pritunl = {
source = "disc/pritunl"
version = "0.0.4"
}
}
}
# Configure the pritunl provider
provider "pritunl" {
url = "https://vpn.server.com"
token = "api-token"
secret = "api-secret"
insecure = false
}
# Create a pritunl organization resource
resource "pritunl_organization" "developers" {
name = "Developers"
}
# Create a pritunl user resource
resource "pritunl_user" "steve" {
name = "steve"
organization_id = pritunl_organization.developers.id
email = "steve@developers.com"
groups = [
"developers",
]
}
# Create a pritunl server resource
resource "pritunl_server" "example" {
name = "example"
port = 15500
protocol = "udp"
network = "192.168.1.0/24"
groups = [
"admins",
"developers",
]
# Attach the organization to the server
organization_ids = [
pritunl_organization.developers.id,
]
# Describe all the routes manually
# Default route 0.0.0.0/0 will be deleted on the server creation
route {
network = "10.0.0.0/24"
comment = "Private network #1"
nat = true
}
route {
network = "10.2.0.0/24"
comment = "Private network #2"
nat = false
}
# Or create dynamic routes from variables
dynamic "route" {
for_each = var.common_routes
content {
network = route.value["network"]
comment = route.value["comment"]
nat = route.value["nat"]
}
}
}
Importing exist resources
Describe exist resource in the terraform file first and then import them:
# Describe a pritunl organization resource
resource "pritunl_organization" "developers" {
name = "Developers"
}
Import an organization:
terraform import pritunl_organization.developers ${ORGANIZATION_ID}
terraform import pritunl_organization.developers 610e42d2a0ed366f41dfe6e8
The organization ID (as well as other resource IDs) can be found in the Pritunl API responses or in the HTML document response.
# Describe a pritunl user resource
resource "pritunl_user" "steve" {
name = "steve"
organization_id = pritunl_organization.developers.id
email = "steve@developers.com"
}
Import a user:
terraform import pritunl_user.steve ${ORGANIZATION_ID}-${USER_ID}
terraform import pritunl_user.steve 610e42d2a0ed366f41dfe6e8-610e42d6a0ed366f41dfe72b
# Describe a pritunl server resource
resource "pritunl_server" "example" {
name = "example"
port = 15500
protocol = "udp"
network = "192.168.1.0/24"
groups = [
"developers",
]
# Attach the organization to the server
organization_ids = [
pritunl_organization.developers.id,
]
# Describe all the routes manually
# Default route 0.0.0.0/0 will be deleted on the server creation
route {
network = "10.0.0.0/24"
comment = "Private network #1"
nat = true
}
}
Import a server:
terraform import pritunl_server.example ${SERVER_ID}
terraform import pritunl_server.example 60cd0bfa7723cf3c911468a8
License
The Terraform Pritunl Provider is available to everyone under the terms of the Mozilla Public License Version 2.0. Take a look the LICENSE file.