mmv1/products/spanner/InstanceConfig.yaml (112 lines of code) (raw):
# 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.
---
name: 'InstanceConfig'
description: |
A possible configuration for a Cloud Spanner instance. Configurations
define the geographic placement of nodes and their replication.
references:
guides:
'Official Documentation': 'https://cloud.google.com/spanner/'
api: 'https://cloud.google.com/spanner/docs/reference/rest/v1/projects.instanceConfigs'
docs:
id_format: '{{project}}/{{name}}'
base_url: 'projects/{{project}}/instanceConfigs'
update_verb: 'PATCH'
update_mask: true
import_format:
- 'projects/{{project}}/instanceConfigs/{{name}}'
- '{{project}}/{{name}}'
- '{{name}}'
timeouts:
insert_minutes: 20
update_minutes: 20
delete_minutes: 20
autogen_async: true
async:
actions: ['create', 'update']
type: 'OpAsync'
operation:
base_url: '{{op_id}}'
result:
resource_inside_response: true
custom_code:
constants: 'templates/terraform/constants/spanner_instance_config.go.tmpl'
encoder: 'templates/terraform/encoders/spanner_instance_config.go.tmpl'
update_encoder: 'templates/terraform/update_encoder/spanner_instance_config_update.go.tmpl'
decoder: 'templates/terraform/decoders/spanner_instance_config.go.tmpl'
exclude_tgc: true
# Sweeper skipped as this resource has customized deletion.
exclude_sweeper: true
examples:
- name: 'spanner_instance_config_basic'
primary_resource_id: 'example'
vars:
instance_config_name: '"custom-nam11-config"'
test_vars_overrides:
'instance_config_name': '"custom-tf-test-nam11-config"'
parameters:
properties:
- name: 'name'
type: String
description: |
A unique identifier for the instance configuration. Values are of the
form projects/<project>/instanceConfigs/[a-z][-a-z0-9]*
immutable: true
default_from_api: true
- name: 'displayName'
type: String
description: |
The name of this instance configuration as it appears in UIs.
required: true
- name: 'baseConfig'
type: String
description: |
Base configuration name, e.g. nam3, based on which this configuration is created.
Only set for user managed configurations.
baseConfig must refer to a configuration of type GOOGLE_MANAGED in the same project as this configuration.
immutable: true
default_from_api: true
custom_flatten: 'templates/terraform/custom_flatten/name_from_self_link.tmpl'
custom_expand: 'templates/terraform/custom_expand/spanner_instance_config.go.tmpl'
- name: 'configType'
type: String
description: |
Output only. Whether this instance config is a Google or User Managed Configuration.
output: true
- name: 'replicas'
type: Array
description: |
The geographic placement of nodes in this instance configuration and their replication properties.
is_set: true
required: true
immutable: true
set_hash_func: replicasHash
item_type:
type: NestedObject
properties:
- name: 'location'
type: String
description: |
The location of the serving resources, e.g. "us-central1".
immutable: true
- name: 'type'
type: Enum
description: |
Indicates the type of replica. See the [replica types
documentation](https://cloud.google.com/spanner/docs/replication#replica_types)
for more details.
immutable: true
enum_values:
- 'READ_WRITE'
- 'READ_ONLY'
- 'WITNESS'
- name: 'defaultLeaderLocation'
type: Boolean
description: |-
If true, this location is designated as the default leader location where
leader replicas are placed.
immutable: true
default_value: false
- name: 'labels'
type: KeyValueLabels
description: |
An object containing a list of "key": value pairs.
Example: { "name": "wrench", "mass": "1.3kg", "count": "3" }.