Add a resource #
This page describes how to add a new resource to the google
or google-beta
Terraform provider using MMv1 and/or handwritten code.
For more information about types of resources and the generation process overall, see How Magic Modules works.
Before you begin #
- Complete the steps in Set up your development environment to set up your environment and your Google Cloud project.
- Ensure that your
magic-modules
,terraform-provider-google
, andterraform-provider-google-beta
repositories are up to date.cd ~/magic-modules git checkout main && git clean -f . && git checkout -- . && git pull cd $GOPATH/src/github.com/hashicorp/terraform-provider-google git checkout main && git clean -f . && git checkout -- . && git pull cd $GOPATH/src/github.com/hashicorp/terraform-provider-google-beta git checkout main && git clean -f . && git checkout -- . && git pull
Add a resource #
Using an editor of your choice, in the appropriate product folder, create a file called
RESOURCE_NAME.yaml
. ReplaceRESOURCE_NAME
with the name of the API resource you are adding support for. For example, a configuration file for NatAddress would be calledNatAddress.yaml
.Copy the following template into the new file:
# Copyright 2024 Google Inc. # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. --- # API resource name name: 'ResourceName' # Resource description for the provider documentation. description: | RESOURCE_DESCRIPTION references: guides: # Link to quickstart in the API's Guides section. For example: # 'Create and connect to a database': 'https://cloud.google.com/alloydb/docs/quickstart/create-and-connect' 'QUICKSTART_TITLE': 'QUICKSTART_URL' # Link to the REST API reference for the resource. For example, # https://cloud.google.com/alloydb/docs/reference/rest/v1/projects.locations.backups api: 'API_REFERENCE_URL' # Marks the resource as beta-only. Ensure a beta version block is present in # provider.yaml. # min_version: beta # URL for the resource's standard List method. https://google.aip.dev/132 # Terraform field names enclosed in double curly braces are replaced with # the field values from the resource at runtime. base_url: 'projects/{{project}}/locations/{{location}}/resourcenames' # URL for the resource's standard Get method. https://google.aip.dev/131 # Terraform field names enclosed in double curly braces are replaced with # the field values from the resource at runtime. self_link: 'projects/{{project}}/locations/{{location}}/resourcenames/{{name}}' # If true, the resource and all its fields are considered immutable - that is, # only creatable, not updatable. Individual fields can override this if they # have a custom update method in the API. immutable: true # URL for the resource's standard Create method, including query parameters. # https://google.aip.dev/133 # Terraform field names enclosed in double curly braces are replaced with # the field values from the resource at runtime. create_url: 'projects/{{project}}/locations/{{location}}/resourcenames?resourceId={{name}}' # Overrides the URL for the resource's standard Update method. (If unset, the # self_link URL is used by default.) https://google.aip.dev/134 # Terraform field names enclosed in double curly braces are replaced with # the field values from the resource at runtime. # update_url: 'projects/{{project}}/locations/{{location}}/resourcenames/{{name}}' # The HTTP verb used to update a resource. Allowed values: :POST, :PUT, :PATCH. Default: :PUT. update_verb: 'PATCH' # If true, the resource sets an `updateMask` query parameter listing modified # fields when updating the resource. If false, it does not. update_mask: true # If true, code for handling long-running operations is generated along with # the resource. If false, that code is not generated. autogen_async: true # Sets parameters for handling operations returned by the API. async: # Overrides which API calls return operations. Default: ['create', # 'update', 'delete'] # actions: ['create', 'update', 'delete'] operation: base_url: '{{op_id}}' parameters: - name: 'location' type: String required: true immutable: true url_param_only: true description: | LOCATION_DESCRIPTION - name: 'name' type: String required: true immutable: true url_param_only: true description: | NAME_DESCRIPTION properties: # Fields go here
Modify the template as needed to match the API resource’s documented behavior.
Delete all remaining comments in the resource configuration (including attribute descriptions) that were copied from the above template.
Note: The template includes the most commonly-used fields. For a comprehensive reference, see MMv1 resource reference ↗.
Warning: Handwritten resources are more difficult to develop and maintain. New handwritten resources will only be accepted if implementing the resource in MMv1 would require entirely overriding two or more CRUD methods.
- Add the resource in MMv1.
- Generate the beta provider
- From the beta provider, copy the files generated for the resource to the following locations:
- Resource: Copy to the appropriate service folder inside
magic-modules/mmv1/third_party/terraform/services
- Documentation:
magic-modules/mmv1/third_party/terraform/website/docs/r
- Tests: Copy to the appropriate service folder inside
magic-modules/mmv1/third_party/terraform/services
, and remove_generated
from the filename - Sweepers: Put to the appropriate service folder inside
magic-modules/mmv1/third_party/terraform/services
, and add_sweeper
suffix to the filename - Metadata: Copy
*_meta.yaml
to the appropriate service folder insidemagic-modules/mmv1/third_party/terraform/services
, and remove_generated
from the filename
- Resource: Copy to the appropriate service folder inside
- Modify the Go code as needed.
- Replace all occurrences of
github.com/hashicorp/terraform-provider-google-beta/google-beta
withgithub.com/hashicorp/terraform-provider-google/google
- Remove the
Example
suffix from all test function names. - Remove the comments at the top of the file.
- If beta-only fields are being tested, do the following:
- Change the file suffix to
.go.tmpl
- Wrap each beta-only test in a separate version guard:
{{- if ne $.TargetVersionName "ga" -}}...{{- else }}...{{- end }}
- Change the file suffix to
- Replace all occurrences of
- Register the resource
handwrittenResources
inmagic-modules/mmv1/third_party/terraform/provider/provider_mmv1_resources.go.tmpl
- Add a version guard for any beta-only resources.
- Optional: Complete other handwritten tasks that require the MMv1 configuration file.
- Delete the MMv1 configuration file.