Skip to content

folio-sec/terraform-provider-zoom

Repository files navigation

Terraform Provider Zoom

  • A resource and a data source (internal/provider/),
  • Examples (examples/) and generated documentation (docs/),
  • Miscellaneous meta files.

Documentation

Full, comprehensive documentation is available on the Terraform Registory. API documentation is also available for non-Terraform or service specific information.

Requirements

Building The Provider

  1. Clone the repository
  2. Enter the repository directory
  3. Build the provider using the make command:
make updatespec # to update the spec using the latest version of the Zoom API
make generate # to generate the provider code from openapi spec and the documentation
make build # to build the provider

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.

Using the provider

terraform {
  required_providers {
    zoom = {
      source  = "folio-sec/zoom"
      version = "~> 0.0.0"
    }
  }
}

provider "zoom" {
  account_id    = var.zoom_account_id
  client_id     = var.zoom_client_id
  client_secret = var.zoom_client_secret
}

Developing the Provider

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

To compile the provider, run make build. This will build the provider and put the provider binary in the dist/bin directory.

To generate or update documentation, run make 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.

Debugging the Provider

Setup your zoom application from https://marketplace.zoom.us/user/build then get the secrets beforehand.

Case 1. Local install

You can debug developing provider using following steps:

  1. make local_install
  2. Edit ~/.terraformrc using the output comment
  3. cd examples/resources/zoom_phone_autoreceiptionist
  4. TF_LOG_PROVIDER=debug terraform apply

Case 2. Using Visual Studio Code

You can debug developing provider using following steps:

  1. Launch your Visual Studio Code app
  2. Select Debug Terraform Provier configuration and start a debugging session from "Run and Debug" view
  3. Copy a TF_REATTACH_PROVIDERS={...} output from "Debug Console" tab
  4. cd examples/resources/zoom_phone_autoreceiptionist
  5. TF_REATTACH_PROVIDERS={...} TF_LOG_PROVIDER=debug terraform apply

Release

We use release management by tagpr. When merging tagpr PR, next version would be released by github-actions.

Contribution

See also CONTRIBUTING.md.

DCO Sign-Off Methods

The sign-off is a simple line at the end of the explanation for the patch, which certifies that you wrote it or otherwise have the right to pass it on as an open-source patch.

The DCO requires a sign-off message in the following format appear on each commit in the pull request:

Signed-off-by: Sample Developer sample@example.com

The text can either be manually added to your commit body, or you can add either -s or --signoff to your usual git commit commands.

Auto sign-off

The following method is examples only and are not mandatory.

touch .git/hooks/prepare-commit-msg
chmod +x .git/hooks/prepare-commit-msg

Edit the prepare-commit-msg file like:

#!/bin/sh

name=$(git config user.name)
email=$(git config user.email)

if [ -z "${name}" ]; then
  echo "empty git config user.name"
  exit 1
fi

if [ -z "${email}" ]; then
  echo "empty git config user.email"
  exit 1
fi

git interpret-trailers --if-exists doNothing --trailer \
    "Signed-off-by: ${name} <${email}>" \
    --in-place "$1"