mmv1/products/metastore/Service.yaml (514 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: 'Service' description: | A managed metastore service that serves metadata queries. references: guides: 'Official Documentation': 'https://cloud.google.com/dataproc-metastore/docs/overview' api: 'https://cloud.google.com/dataproc-metastore/docs/reference/rest/v1/projects.locations.services' docs: base_url: 'projects/{{project}}/locations/{{location}}/services' self_link: 'projects/{{project}}/locations/{{location}}/services/{{service_id}}' create_url: 'projects/{{project}}/locations/{{location}}/services?serviceId={{service_id}}' update_verb: 'PATCH' update_mask: true import_format: - 'projects/{{project}}/locations/{{location}}/services/{{service_id}}' timeouts: insert_minutes: 75 update_minutes: 75 delete_minutes: 75 autogen_async: true async: actions: ['create', 'delete', 'update'] type: 'OpAsync' operation: base_url: '{{op_id}}' timeouts: insert_minutes: 75 update_minutes: 75 delete_minutes: 75 result: resource_inside_response: false iam_policy: method_name_separator: ':' parent_resource_attribute: 'service_id' example_config_body: 'templates/terraform/iam/iam_attributes.go.tmpl' import_format: - 'projects/{{project}}/locations/{{location}}/services/{{service_id}}' - '{{service_id}}' custom_code: examples: - name: 'dataproc_metastore_service_basic' primary_resource_id: 'default' primary_resource_name: 'fmt.Sprintf("tf-test-metastore-srv%s", context["random_suffix"])' vars: metastore_service_name: 'metastore-srv' - name: 'dataproc_metastore_service_deletion_protection' primary_resource_id: 'default' primary_resource_name: 'fmt.Sprintf("tf-test-metastore-srv%s", context["random_suffix"])' vars: metastore_service_name: 'metastore-srv' deletion_protection: 'true' test_vars_overrides: 'deletion_protection': 'false' oics_vars_overrides: 'deletion_protection': 'false' - name: 'dataproc_metastore_service_cmek_test' primary_resource_id: 'default' vars: metastore_service_name: 'example-service' 'kms_key_name': 'acctest.BootstrapKMSKeyWithPurposeInLocationAndName(t, "ENCRYPT_DECRYPT", "us-central1", "tf-bootstrap-metastore-service-key1").CryptoKey.Name' exclude_docs: true skip_vcr: true - name: 'dataproc_metastore_service_cmek_example' primary_resource_id: 'default' vars: metastore_service_name: 'example-service' key_name: 'example-key' keyring_name: 'example-keyring' exclude_test: true - name: 'dataproc_metastore_service_endpoint' primary_resource_id: 'endpoint' vars: metastore_service_name: 'metastore-endpoint' exclude_docs: true - name: 'dataproc_metastore_service_aux' primary_resource_id: 'aux' vars: metastore_service_name: 'metastore-aux' exclude_docs: true - name: 'dataproc_metastore_service_metadata' primary_resource_id: 'metadata' vars: metastore_service_name: 'metastore-metadata' exclude_docs: true - name: 'dataproc_metastore_service_private_service_connect' primary_resource_id: 'default' vars: metastore_service_name: 'metastore-srv' network_name: 'my-network' subnet_name: 'my-subnetwork' exclude_test: true - name: 'dataproc_metastore_service_private_service_connect_custom_routes' primary_resource_id: 'default' min_version: 'beta' vars: metastore_service_name: 'metastore-srv' network_name: 'my-network' subnet_name: 'my-subnetwork' exclude_test: true - name: 'dataproc_metastore_service_telemetry' primary_resource_id: 'telemetry' vars: metastore_service_name: 'ms-telemetry' exclude_docs: true - name: 'dataproc_metastore_service_dpms2' primary_resource_id: 'dpms2' vars: metastore_service_name: 'ms-dpms2' - name: 'dataproc_metastore_service_dpms2_scaling_factor' primary_resource_id: 'dpms2_scaling_factor' vars: metastore_service_name: 'ms-dpms2sf' - name: 'dataproc_metastore_service_dpms2_scaling_factor_lt1' primary_resource_id: 'dpms2_scaling_factor_lt1' vars: metastore_service_name: 'ms-dpms2sflt1' exclude_docs: true - name: 'dataproc_metastore_service_scheduled_backup' primary_resource_id: 'backup' vars: metastore_service_name: 'backup' - name: 'dataproc_metastore_service_autoscaling_max_scaling_factor' primary_resource_id: 'test_resource' vars: metastore_service_name: 'test-service' - name: 'dataproc_metastore_service_autoscaling_min_and_max_scaling_factor' primary_resource_id: 'test_resource' vars: metastore_service_name: 'test-service' - name: 'dataproc_metastore_service_autoscaling_min_scaling_factor' primary_resource_id: 'test_resource' vars: metastore_service_name: 'test-service' - name: 'dataproc_metastore_service_autoscaling_no_limit_config' primary_resource_id: 'test_resource' vars: metastore_service_name: 'test-service' parameters: - name: 'serviceId' type: String description: | The ID of the metastore service. The id must contain only letters (a-z, A-Z), numbers (0-9), underscores (_), and hyphens (-). Cannot begin or end with underscore or hyphen. Must consist of between 3 and 63 characters. url_param_only: true required: true immutable: true - name: 'location' type: String description: | The location where the metastore service should reside. The default value is `global`. url_param_only: true immutable: true default_value: "global" properties: - name: 'name' type: String description: | The relative resource name of the metastore service. output: true - name: 'createTime' type: Time description: | Output only. The time when the metastore service was created. output: true - name: 'updateTime' type: Time description: | Output only. The time when the metastore service was last updated. output: true - name: 'labels' type: KeyValueLabels description: 'User-defined labels for the metastore service.' # This is an x-product resource reference. - name: 'network' type: String description: | The relative resource name of the VPC network on which the instance can be accessed. It is specified in the following form: "projects/{projectNumber}/global/networks/{network_id}". immutable: true default_from_api: true - name: 'endpointUri' type: String description: | The URI of the endpoint used to access the metastore service. output: true - name: 'port' type: Integer description: | The TCP port at which the metastore service is reached. Default: 9083. default_from_api: true - name: 'state' type: String description: | The current state of the metastore service. output: true - name: 'stateMessage' type: String description: | Additional information about the current state of the metastore service, if available. output: true - name: 'artifactGcsUri' type: String description: | A Cloud Storage URI (starting with gs://) that specifies where artifacts related to the metastore service are stored. output: true - name: 'tier' type: Enum description: | The tier of the service. default_from_api: true conflicts: - scalingConfig enum_values: - 'DEVELOPER' - 'ENTERPRISE' - name: 'scalingConfig' type: NestedObject description: | Represents the scaling configuration of a metastore service. properties: - name: 'instanceSize' type: Enum description: | Metastore instance sizes. required: false conflicts: - tier exactly_one_of: - 'scaling_config.0.instance_size' - 'scaling_config.0.scaling_factor' - 'scaling_config.0.autoscaling_config' enum_values: - 'EXTRA_SMALL' - 'SMALL' - 'MEDIUM' - 'LARGE' - 'EXTRA_LARGE' - name: 'scalingFactor' type: Double description: | Scaling factor, in increments of 0.1 for values less than 1.0, and increments of 1.0 for values greater than 1.0. required: false - name: 'autoscalingConfig' type: NestedObject description: | Represents the autoscaling configuration of a metastore service. required: false properties: - name: 'autoscalingEnabled' type: Boolean description: | Defines whether autoscaling is enabled. The default value is false. - name: 'autoscalingFactor' type: Double description: | Output only. The scaling factor of a service with autoscaling enabled. output: true - name: 'limitConfig' type: NestedObject description: | Represents the limit configuration of a metastore service. default_from_api: true properties: - name: 'minScalingFactor' type: Double description: | The minimum scaling factor that the service will autoscale to. The default value is 0.1. default_from_api: true - name: 'maxScalingFactor' type: Double description: | The maximum scaling factor that the service will autoscale to. The default value is 6.0. default_from_api: true - name: 'scheduledBackup' type: NestedObject description: | The configuration of scheduled backup for the metastore service. properties: - name: 'enabled' type: Boolean description: | Defines whether the scheduled backup is enabled. The default value is false. default_from_api: true - name: 'cronSchedule' type: String description: | The scheduled interval in Cron format, see https://en.wikipedia.org/wiki/Cron The default is empty: scheduled backup is not enabled. Must be specified to enable scheduled backups. - name: 'timeZone' type: String description: | Specifies the time zone to be used when interpreting cronSchedule. Must be a time zone name from the time zone database (https://en.wikipedia.org/wiki/List_of_tz_database_time_zones), e.g. America/Los_Angeles or Africa/Abidjan. If left unspecified, the default is UTC. default_from_api: true - name: 'backupLocation' type: String description: | A Cloud Storage URI of a folder, in the format gs://<bucket_name>/<path_inside_bucket>. A sub-folder <backup_folder> containing backup files will be stored below it. required: true - name: 'deletionProtection' type: Boolean description: | Indicates if the dataproc metastore should be protected against accidental deletions. - name: 'maintenanceWindow' type: NestedObject description: | The one hour maintenance window of the metastore service. This specifies when the service can be restarted for maintenance purposes in UTC time. Maintenance window is not needed for services with the `SPANNER` database type. properties: - name: 'hourOfDay' type: Integer description: | The hour of day (0-23) when the window starts. required: true - name: 'dayOfWeek' type: Enum description: | The day of week, when the window starts. required: true enum_values: - 'MONDAY' - 'TUESDAY' - 'WEDNESDAY' - 'THURSDAY' - 'FRIDAY' - 'SATURDAY' - 'SUNDAY' - name: 'encryptionConfig' type: NestedObject description: | Information used to configure the Dataproc Metastore service to encrypt customer data at rest. properties: - name: 'kmsKey' type: String description: | The fully qualified customer provided Cloud KMS key name to use for customer data encryption. Use the following format: `projects/([^/]+)/locations/([^/]+)/keyRings/([^/]+)/cryptoKeys/([^/]+)` required: true immutable: true - name: 'hiveMetastoreConfig' type: NestedObject description: | Configuration information specific to running Hive metastore software as the metastore service. properties: - name: 'endpointProtocol' type: Enum description: | The protocol to use for the metastore service endpoint. If unspecified, defaults to `THRIFT`. immutable: true default_value: "THRIFT" enum_values: - 'THRIFT' - 'GRPC' - name: 'version' type: String description: | The Hive metastore schema version. required: true immutable: true - name: 'configOverrides' type: KeyValuePairs description: | A mapping of Hive metastore configuration key-value pairs to apply to the Hive metastore (configured in hive-site.xml). The mappings override system defaults (some keys cannot be overridden) default_from_api: true diff_suppress_func: 'dataprocMetastoreServiceOverrideSuppress' - name: 'kerberosConfig' type: NestedObject description: | Information used to configure the Hive metastore service as a service principal in a Kerberos realm. properties: - name: 'keytab' type: NestedObject description: | A Kerberos keytab file that can be used to authenticate a service principal with a Kerberos Key Distribution Center (KDC). required: true properties: - name: 'cloudSecret' type: String description: | The relative resource name of a Secret Manager secret version, in the following form: "projects/{projectNumber}/secrets/{secret_id}/versions/{version_id}". required: true - name: 'principal' type: String description: | A Kerberos principal that exists in the both the keytab the KDC to authenticate as. A typical principal is of the form "primary/instance@REALM", but there is no exact format. required: true - name: 'krb5ConfigGcsUri' type: String description: | A Cloud Storage URI that specifies the path to a krb5.conf file. It is of the form gs://{bucket_name}/path/to/krb5.conf, although the file does not need to be named krb5.conf explicitly. required: true - name: 'auxiliaryVersions' type: Map description: | A mapping of Hive metastore version to the auxiliary version configuration. When specified, a secondary Hive metastore service is created along with the primary service. All auxiliary versions must be less than the service's primary version. The key is the auxiliary service name and it must match the regular expression a-z?. This means that the first character must be a lowercase letter, and all the following characters must be hyphens, lowercase letters, or digits, except the last character, which cannot be a hyphen. key_name: 'key' key_description: | The auxiliary service name value_type: name: auxiliaryVersions type: NestedObject properties: - name: 'version' type: String description: | The Hive metastore version of the auxiliary service. It must be less than the primary Hive metastore service's version. required: true - name: 'configOverrides' type: KeyValuePairs description: | A mapping of Hive metastore configuration key-value pairs to apply to the auxiliary Hive metastore (configured in hive-site.xml) in addition to the primary version's overrides. If keys are present in both the auxiliary version's overrides and the primary version's overrides, the value from the auxiliary version's overrides takes precedence. - name: 'networkConfig' type: NestedObject description: | The configuration specifying the network settings for the Dataproc Metastore service. immutable: true properties: - name: 'consumers' type: Array description: | The consumer-side network configuration for the Dataproc Metastore instance. required: true immutable: true item_type: type: NestedObject properties: - name: 'endpointUri' type: String description: | The URI of the endpoint used to access the metastore service. output: true - name: 'subnetwork' type: String description: | The subnetwork of the customer project from which an IP address is reserved and used as the Dataproc Metastore service's endpoint. It is accessible to hosts in the subnet and to all hosts in a subnet in the same region and same network. There must be at least one IP address available in the subnet's primary range. The subnet is specified in the following form: `projects/{projectNumber}/regions/{region_id}/subnetworks/{subnetwork_id} required: true - name: 'customRoutesEnabled' type: Boolean description: | Enables custom routes to be imported and exported for the Dataproc Metastore service's peered VPC network. min_version: 'beta' - name: 'databaseType' type: Enum description: | The database type that the Metastore service stores its data. immutable: true default_value: "MYSQL" enum_values: - 'MYSQL' - 'SPANNER' - name: 'releaseChannel' type: Enum description: | The release channel of the service. If unspecified, defaults to `STABLE`. immutable: true default_value: "STABLE" enum_values: - 'CANARY' - 'STABLE' - name: 'uid' type: String description: | The globally unique resource identifier of the metastore service. output: true - name: 'metadataIntegration' type: NestedObject description: | The setting that defines how metastore metadata should be integrated with external services and systems. properties: - name: 'dataCatalogConfig' type: NestedObject description: | The integration config for the Data Catalog service. required: true properties: - name: 'enabled' type: Boolean description: | Defines whether the metastore metadata should be synced to Data Catalog. The default value is to disable syncing metastore metadata to Data Catalog. required: true - name: 'telemetryConfig' type: NestedObject description: | The configuration specifying telemetry settings for the Dataproc Metastore service. If unspecified defaults to JSON. default_from_api: true properties: - name: 'logFormat' type: Enum description: | The output format of the Dataproc Metastore service's logs. default_value: "JSON" enum_values: - 'LEGACY' - 'JSON' - name: 'tags' type: KeyValuePairs description: | A map of resource manager tags. Resource manager tag keys and values have the same definition as resource manager tags. Keys must be in the format tagKeys/{tag_key_id}, and values are in the format tagValues/{tag_value_id}. immutable: true ignore_read: true