pulumi-terraform-bridge

module
v3.100.0 Latest Latest
Warning

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

Go to latest
Published: Jan 9, 2025 License: Apache-2.0

README

Build Status Go Report Card GoDoc

Pulumi Terraform Bridge

This bridge adapts any Terraform Provider built using the Terraform Plugin SDK for use with Pulumi. The Terraform community provides resource providers that perform create, read, update, and delete (CRUD) operations for a broad array of infrastructure providers and types. In principle, any of them can be programmed using Pulumi with this bridge.

If you want to wrap a new Terraform provider as a Pulumi provider, check out pulumi/pulumi-tf-provider-boilerplate.

Developing a New Provider

The recommended way to start developing a new TF provider is with pulumi-tf-provider-boilerplate.

If you want details on how provider development works, please see our docs.

Upgrading an Existing Bridged Provider

To upgrade a provider that used to use the Terraform Plugin SDK to a version that uses the Terraform Plugin Framework, see here.

To upgrade a provider that was bridged from a Terraform provider built against Terraform Plugin SDK and you want to upgrade it to a version that has migrated some but not all resources/datasources to the Terraform Plugin Framework, see here.

Overview

Most users of Pulumi don't need to know how this bridge works. Many will find it interesting, and, if you'd like to bring up a new provider that is available in Terraform but not yet Pulumi, we would love to hear from you.

How It Works

There are two major things involved in this bridge: design-time and runtime.

At design-time, we code-generate packages by dynamic inspection of a Terraform Provider's schema. This only works for providers that are built using static schemas. It is possible to write Terraform Providers without this, which means the ability to create packages would not exist, but in practice all interesting providers use it.

Second, the bridge connects the Pulumi engine to a given Terraform Provider using Pulumi's RPC interfaces. This behavior also leverages the Terraform provider schema, for operations like performing validation and diffs.

Development

This section only matters if you want to build this bridge from scratch, or use it in your own project.

See also the Pulumi Terraform Bridge developer docs.

Prerequisites

Before doing any development, there are a few prerequisites to install:

Building and Testing

There is a Makefile in the root that builds and tests everything.

To build, ensure $GOPATH is set, and clone into a standard Go workspace:

$ git clone git@github.com:pulumi/pulumi-terraform-bridge $GOPATH/src/github.com/pulumi/pulumi-terraform-bridge
$ cd $GOPATH/src/github.com/pulumi/pulumi-terraform-bridge

You can run make to build and run tests:

$ make

This repo on its own isn't particularly interesting, until it is used to create a new Pulumi provider.

Releasing

See playbook.

Design Time Options

tfgen, the command that generates Pulumi schema/code for a bridged provider supports the following environment variables:

  • PULUMI_SKIP_MISSING_MAPPING_ERROR: If truthy, tfgen will not fail if a data source or resource in the TF provider is not mapped to the Pulumi provider. Instead, a warning is printed. Default is false.
  • PULUMI_SKIP_EXTRA_MAPPING_ERROR: If truthy, tfgen will not fail if a mapped data source or resource does not exist in the TF provider. Instead, warning is printed. Default is false.
  • PULUMI_MISSING_DOCS_ERROR: If truthy, tfgen will fail if docs cannot be found for a data source or resource. Default is false.
  • PULUMI_CONVERT: If truthy, tfgen will shell out to pulumi convert for converting example code from TF HCL to Pulumi PCL
  • PULUMI_CONVERT_ONLY: If set to a resource or data source ID such as "aws_acm_certificate" will convert docs only for that single resource; useful to speed up debugging docs issues
  • COVERAGE_OUTPUT_DIR: If set to a folder path, will generate a report on TF to Pulumi example code translation, including detailed errors and overall coverage statistics
  • PULUMI_CONVERT_AUTOFILL_DIR: Configure example auto-fill

Directories

Path Synopsis
internal/fixup
package fixup applies fixes to a info.Provider to ensure that it can generate a valid schema and that the schema can generate valid SDKs in all all languages.
package fixup applies fixes to a info.Provider to ensure that it can generate a valid schema and that the schema can generate valid SDKs in all all languages.
internal/shim/protov5
protov5 providers a translation layer between tfplugin5.ProviderClient and tfprotov5.ProviderServer.
protov5 providers a translation layer between tfplugin5.ProviderClient and tfprotov5.ProviderServer.
internal/shim/protov6
protov6 providers a translation layer between [otshim.ProviderClient] and tfprotov6.ProviderServer.
protov6 providers a translation layer between [otshim.ProviderClient] and tfprotov6.ProviderServer.
parameterize
parameterize encapsulates parsing parameterize args as well as marshaling and unmarshaling parameterize values.
parameterize encapsulates parsing parameterize args as well as marshaling and unmarshaling parameterize values.
internal
pkg
convert
Converts between Pulumi and Terraform value representations.
Converts between Pulumi and Terraform value representations.
internal/tests/cross-tests
Adapters for converting morally equivalent typed representations of TF values for integrating with all the libraries cross-testing is using.
Adapters for converting morally equivalent typed representations of TF values for integrating with all the libraries cross-testing is using.
internal/tests/cross-tests/impl
Package crosstestsimpl (cross-tests implementation) contains code meant to be shared across cross-test implementations (SDKv2, PF) but not used by people writing tests themselves.
Package crosstestsimpl (cross-tests implementation) contains code meant to be shared across cross-test implementations (SDKv2, PF) but not used by people writing tests themselves.
internal/tests/cross-tests/impl/hclwrite
hclwrite is a shared interface for writing HCL files for cross-tests.
hclwrite is a shared interface for writing HCL files for cross-tests.
pf
pf/internal/plugin
The code in this package implements Context-preserving provider server and is forked from pulumi/pulumi.
The code in this package implements Context-preserving provider server and is forked from pulumi/pulumi.
pf/proto
proto enables building a shim.Provider around a tfprotov6.ProviderServer.
proto enables building a shim.Provider around a tfprotov6.ProviderServer.
pf/tests/internal/testprovider/cmd/pulumi-resource-muxedrandom
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-resource-random
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-resource-testbridge
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-resource-tls
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-tfgen-muxedrandom
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-tfgen-random
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/cmd/pulumi-tfgen-testbridge
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
Implements a Pulumi provider for testing the functionality of bridging Terraform Plugin Framework based providers.
pf/tests/internal/testprovider/sdkv2randomprovider
Implements a TF Provider against SDKv2 for testing the muxer.
Implements a TF Provider against SDKv2 for testing the muxer.
pf/tfbridge
Package tfbridge implements adapters for constructing [Pulumi Resource Providers] from Terraform providers built with the [Terraform Plugin Framework].
Package tfbridge implements adapters for constructing [Pulumi Resource Providers] from Terraform providers built with the [Terraform Plugin Framework].
pf/tfgen
Package tfgen implements build-time introspection and generating a [Pulumi Package Schema].
Package tfgen implements build-time introspection and generating a [Pulumi Package Schema].
tests/tfcheck
Helpers to execute OS commands.
Helpers to execute OS commands.
tf2pulumi/internal/addrs
Package addrs contains types that represent "addresses", which are references to specific objects within a Terraform configuration or state.
Package addrs contains types that represent "addresses", which are references to specific objects within a Terraform configuration or state.
tf2pulumi/internal/config
The config package is responsible for loading and validating the configuration.
The config package is responsible for loading and validating the configuration.
tfbridge/info
info contains the types that bridged provider authors use to describe the mapping between Pulumi and Terraform providers.
info contains the types that bridged provider authors use to describe the mapping between Pulumi and Terraform providers.
tfbridge/internal/test/schemaconvert
This is a test utility for converting sdkv2 schemas to sdkv1 to allow testing both without having to specify the schema twice.
This is a test utility for converting sdkv2 schemas to sdkv1 to allow testing both without having to specify the schema twice.
tfbridge/x
Experimental extensions to the tfbridge module.
Experimental extensions to the tfbridge module.
tfgen
Facilities to help caching the example generation.
Facilities to help caching the example generation.
tfgen/internal/autofill
Package autofill implements filling undeclared references in examples.
Package autofill implements filling undeclared references in examples.
tfgen/parse/section
package section provides an extension to goldmark: a section.
package section provides an extension to goldmark: a section.
tfshim
Package tfshim implements an abstraction layer for TF bridge backends.
Package tfshim implements an abstraction layer for TF bridge backends.
tfshim/tfplugin5
tfplugin5 is an old attempt at consuming SDKv1 and SDKv2 providers at the gRPC level, instead of linking in at the SDKv{1,2} level.
tfplugin5 is an old attempt at consuming SDKv1 and SDKv2 providers at the gRPC level, instead of linking in at the SDKv{1,2} level.
vendored/opentofu/plugin/convert
Code copied from github.com/opentofu/opentofu by go generate; DO NOT EDIT.
Code copied from github.com/opentofu/opentofu by go generate; DO NOT EDIT.
vendored/opentofu/plugin6/convert
Code copied from github.com/opentofu/opentofu by go generate; DO NOT EDIT.
Code copied from github.com/opentofu/opentofu by go generate; DO NOT EDIT.
x/testing
Deprecated: This package has been moved to [https://github.com/pulumi/providertest/tree/main/replay]
Deprecated: This package has been moved to [https://github.com/pulumi/providertest/tree/main/replay]
A package that exposes an unstable interface across go module boundaries.
A package that exposes an unstable interface across go module boundaries.
scripts/exconverter
This script assists the rollout of the new example converter across bridged providers by computing the difference in example generation metrics.
This script assists the rollout of the new example converter across bridged providers by computing the difference in example generation metrics.

Jump to

Keyboard shortcuts

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