Implements a terraform provider for Cloudera Data Platform(CDP) resources. Terraform is the de facto tool for Infrastructure as code. This repo
implements a provider for CDP that provides CDP resources (credentials, environments, datalakes, datahubs, etc). Example terraform code can be
found under examples directory.
Target terraform version is 1.1+.
Provider Documentation
Find detailed documentation for the provider in the docs folder.
Provider documentation is maintained according to terraform guidance.
Installation
The easiest way to install the CDP provider from source code is by
make install
which copies the binary to $GOPATH/bin
. After that you need to run:
make install-terraformrc
which installs a .terraformrc
file under your home directory to point to the locally
installed version of the provider binary.
If you have downloaded a binary release, you can execute these steps to install:
mkdir -p ~/.terraform.d/plugins/registry.terraform.io/cloudera/cdp/$VERSION/$ARCH
cp terraform-provider-cdp ~/.terraform.d/plugins/registry.terraform.io/cloudera/cdp/$VERSION/$ARCH/terraform-provider-cdp_v$VERSION
where VERSION should be replaced with something like 0.0.3
and ARCH should be replaced with something like darwin_amd64
or linux_amd64
Filing Bugs
Create a Github Issue, or (for Cloudera-only) file a JIRA using the CDPCP project using the cdp terraform provider component.
Generate logs by setting the TF_LOG environment variable to any value and capturing the output, for example by running TF_LOG=true terraform apply plan.txt > tf.log 2>&1
. Please attach the output file to the filed bug. Please also attach the crash.log file from any terraform crash. See the terraform docs for more debugging information.
Development
Find documentation about writing terraform providers is here: https://www.terraform.io/docs/extend/writing-custom-providers.html.
Contributing
All code and documentation contributions are welcome. Please fork the repository and send a pull request for your code
change. If you want to review patches you can add yourself in the Code Owners file. You can also
use that file to ping people about the code reviews.
Pull requests are expected to include appropriate updates to the change log as detailed here.
Compiling
make
cd examples/credential
make terraform-apply
cdp-sdk-go
Since CDP does not have an official golang SDK, this repo contains a subdirectory named "cdp-sdk-go" that implements a pure
golang SDK using the swagger definitions from the public API. go-swagger is used to generate the client code. This SDK is
independent of any terraform related logic, and ideally should be hosted elsewhere as a stand alone library.
Compiling cdp-sdk-go
cd cdp-sdk-go
make
Running swagger code gen
cd cdp-sdk-go
make swagger-gen
Generating Documentation
We follow the guidelines from https://developer.hashicorp.com/terraform/registry/providers/docs. Mainly we use the tool
tfplugindocs to automatically generate the documentation from the
schemas from the provider code plus the examples under the examples
directory.
Please read the docs at https://developer.hashicorp.com/terraform/registry/providers/docs and
https://github.com/hashicorp/terraform-plugin-docs to understand how the templating and examples
are used to render the final content. But in short, for every resource and data-source, we put example code under
examples/resources/<resource-name>/resource.tf
and the template docs at templates/resources/<resource-name>.md.tmpl
(similar for data-sources).
Then you can generate the docs by running:
make docs
which will override the files under /docs
. We check in the generated docs for every change that changes resources or
data-sources.
You can use this tool: https://registry.terraform.io/tools/doc-preview to copy-paste the markdown files to see how they
render in the terraform registry public docs.
Releases
We aim to follow official guidance
on versioning our provider. See the change log for the release history.
We use the goreleaser tool to build and publish official releases. Please follow the
Quick Start Guide to familiarize yourself with the tool.
We publish new releases following the Terraform Publishing Guide
to the Terraform Registry.
One time setup
- If you have not done so, create a personal github token here: https://github.com/settings/tokens
export GITHUB_TOKEN=<PLACE_THE_TOKEN>
- https://developer.hashicorp.com/terraform/registry/providers/publishing#preparing-and-adding-a-signing-key
- https://docs.github.com/en/authentication/managing-commit-signature-verification/generating-a-new-gpg-key
Publishing new releases
- Make sure that the build is fine, and unit tests and Terraform acceptance tests are running fine.
- Make sure that the NOTICE file is up to date and re-export and re-commit the NOTICE using the tool.
- Review the change log and update it as necessary. Ideally the content is
up-to-date as it has been maintained along the way. Note the data of the
release and create a new, empty unreleased entry at the top.
- Set the GPG fingerprint to use to sign the release
export GPG_FINGERPRINT=<YOUR_CODE_SIGNING_GPG_KEY_ID>
. Use (gpg --list-secret-keys --keyid-format=long
to find out).
- Cache the password for your GPG private key with
echo "foo" | gpg --armor --detach-sign --default-key $GPG_FINGERPRINT
(GoReleaser does not support signing binaries with a GPG key that requires a passphrase. Some systems may cache your GPG passphrase for a few minutes).
- Tag the commit with an appropriate semantic version, e.g.
git tag v0.0.1
.
- We use Semantic Versioning to mark the releases and
v
prefix is mandatory for terraform providers
- A release-candidate can be pushed by adding
-rc1
suffix like v0.0.1-rc1
.
- You can find the next version to use by looking at the existing releases / tags.
- Push the tag:
git push origin v0.0.1
.
- Run
goreleaser
: make release
- If goreleaser runs successfully, it will automatically:
- Cross-compile against all platforms and create binaries under
dist/
- Create zip archives for all binaries.
- Checksums all of the binaries using sha256 and saves the checksums under
dist/terraform-provider-cdp_<VERSION>_SHA256SUMS
.
- Signs the checksums file with the gpg keys of the user.
- Creates other metadata files for the build and release.
- Creates a release as a draft in Github (we are intentionally doing this. Once we get the other mechanics working we can do non-draft releases).
- Uploads artifacts and release notes to the Github release.
- Until otherwise noted, select the pre-release checkbox to indicate that we
are not yet production ready.
- The release that is pushed by goreleaser is a draft release. Go to the release page in Github, and double check the release notes, artifacts and the version. If everything is fine, click on "Edit" and then "Publish Release" button.
- Once the release is done, send a PR to update the
CHANGELOG.md
with the new release section, and update the release date.
Above staps only publish the artifacts to github. We need to futher publish the artifacts to Terraform Registry. The steps will be documented here.