Follow these steps if you have a Pulumi 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 Plugin Framework.
-
Ensure you have access to the
github.com/hashicorp/terraform-plugin-framework/provider.Provider
from the upstream provider. If the provider is shimmed (or needs to be), you can follow step (1) from "How to Upgrade a Bridged Provider to Plugin Framework". -
Find the tfgen binary
main
that callstfgen.Main
fromgithub.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfgen
and update it to calltfgen.MainWithMuxer
fromgithub.com/pulumi/pulumi-terraform-bridge/v3/pf/tfgen
.Note that the extra version parameter is removed from
tfgen.Main
, so this code:import "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfgen" ... tfgen.Main("cloudflare", version.Version, tls.Provider())
Becomes:
import "github.com/pulumi/pulumi-terraform-bridge/v3/pf/tfgen" ... tfgen.MainWithMuxer("cloudflare", cloudflare.Provider())
-
Find the provider binary
main
that calls"github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfbridge".Main
and update it to"github.com/pulumi/pulumi-terraform-bridge/v3/pf/tfbridge".MainWithMuxer
.Note the signature changes: version parameter is removed, and
Context
is now required, so this code:import "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfbridge" ... tfbridge.Main("cloudflare", version.Version, cloudflare.Provider(), pulumiSchema)
Becomes:
import "github.com/pulumi/pulumi-terraform-bridge/v3/pf/tfbridge" ... tfbridge.MainWithMuxer(context.Background(), "cloudflare", cloudflare.Provider(), pulumiSchema)
-
Update code declaring
ProviderInfo
(typically inprovider/resources.go
), changing the embedded"github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfbridge".ProviderInfo.P
to the result of calling"github.com/pulumi/pulumi-terraform-bridge/v3/pf/tfbridge".MuxShimWithPF
.This function combines the original SDK based provider with the new PF based provider, so this code:
import ( "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfbridge" shimv2 "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfshim/sdk-v2" "github.com/${PROVIDER_ORG}/terraform-provider-${PROVIDER_NAME}" ) ... func Provider() tfbridge.ProviderInfo { p := shimv2.NewProvider(${PROVIDER_NAME}.SDKProvider()) prov := tfbridge.ProviderInfo{ P: p, ... } ... return prov }
You should replace
github.com/${PROVIDER_ORG}/terraform-provider-${PROVIDER_NAME}.SDKProvider()
with whatever function is necessary to produce the*github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema.Provider
used by the upstream provider.Becomes:
import ( "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfbridge" pfbridge "github.com/pulumi/pulumi-terraform-bridge/v3/pf/tfbridge" shimv2 "github.com/pulumi/pulumi-terraform-bridge/v3/pkg/tfshim/sdk-v2" "github.com/${PROVIDER_ORG}/terraform-provider-${PROVIDER_NAME}" ) ... func Provider() tfbridge.ProviderInfo { p := pfbridge.MuxShimWithPF(context.Background(), shimv2.NewProvider(${PROVIDER_NAME}.SDKProvider()), ${PROVIDER_NAME}.PFProvider(), ) prov := tfbridge.ProviderInfo{ P: p, ... } ... return prov }
You should replace
github.com/${PROVIDER_ORG}/terraform-provider-${PROVIDER_NAME}.PFProvider()
with whatever function is necessary to produce thegithub.com/hashicorp/terraform-plugin-framework/provider.Provider
used by the upstream provider. -
Ensure that
tfbridge.ProviderInfo.MetadataInfo
is set.For details on setting this up, see here.
-
From this point the update proceeds as a typical upstream provider update. Build and run the tfgen binary to compute the Pulumi Package Schema. It will now also compute a new metadata file
bridge-metadata.json
, build the provider binary, re-generate language-specific SDKs and run tests.make tfgen make provider make build_sdks