mmv1/products/storagecontrol/ProjectIntelligenceConfig.yaml (170 lines of code) (raw):
# Copyright 2025 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: 'ProjectIntelligenceConfig'
api_resource_type_kind: 'IntelligenceConfig'
kind: 'storagecontrol#intelligenceconfig'
# Resource description for the provider documentation.
description: |
The Project Storage Intelligence Config resource represents GCS Storage Intelligence operating on individual GCP project. Storage Intelligence Config is a singleton resource and individual instance exists on each GCP project.
Storage Intelligence is for Storage Admins to manage GCP storage assets at scale for performance, cost, security & compliance.
docs:
warning: |
Storage Intelligence Config is a singleton resource which cannot be created or deleted. A single instance of Storage Intelligence Config exist for each GCP Project. Terraform does not create or destroy this resource.
Terraform resource creation for this resource is simply an update operation on existing resource with specified properties, absence of any optional field in the create operation will result in clearance of that field. Terraform deletion won't have any effect on this resource rather it will only remove it from the state file.
# URL for the resource's standard Get method. https://google.aip.dev/131
self_link: 'projects/{{name}}/locations/global/intelligenceConfig'
custom_code:
pre_create: templates/terraform/pre_create/storage_control_intelligence_config.go.tmpl
constants: 'templates/terraform/constants/storage_control_intelligence.go.tmpl'
create_verb: 'PATCH'
# 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
exclude_delete: true
import_format:
- 'projects/{{name}}/locations/global/intelligenceConfig'
# If true, code for handling long-running operations is generated along with
# the resource. If false, that code is not generated.
autogen_async: false
examples:
- name: storage_control_project_intelligence_config_basic
primary_resource_id: example
vars:
project_id: "test-project"
exclude_test: true
exclude_import_test: true
properties:
- name: 'name'
type: String
required: true
immutable: true
url_param_only: true
description: |
Identifier of the GCP project. For GCP project, this field can be project name or project number.
- name: 'editionConfig'
type: String
required: false
default_from_api: true
description: |
Edition configuration of the Storage Intelligence resource. Valid values are INHERIT, TRIAL, DISABLED and STANDARD.
- name: 'updateTime'
type: String
output: true
description: |
The time at which the Storage Intelligence Config resource is last updated.
- name: 'filter'
type: NestedObject
diff_suppress_func: 'intelligenceFilterDiffSuppress'
description: |
Filter over location and bucket using include or exclude semantics. Resources that match the include or exclude filter are exclusively included or excluded from the Storage Intelligence plan.
properties:
- name: excludedCloudStorageBuckets
type: NestedObject
required: false
description: |
Buckets to exclude from the Storage Intelligence plan.
conflicts:
- 'filter.0.included_cloud_storage_buckets'
at_least_one_of:
- 'filter.0.included_cloud_storage_buckets'
- 'filter.0.excluded_cloud_storage_buckets'
- 'filter.0.included_cloud_storage_locations'
- 'filter.0.excluded_cloud_storage_locations'
diff_suppress_func: 'intelligenceFilterExcludedCloudStorageBucketsDiffSuppress'
properties:
- name: bucketIdRegexes
required: true
type: Array
send_empty_value: true
item_type:
type: String
description: |
List of bucket id regexes to exclude in the storage intelligence plan.
- name: includedCloudStorageBuckets
type: NestedObject
required: false
description: |
Buckets to include in the Storage Intelligence plan.
conflicts:
- 'filter.0.excluded_cloud_storage_buckets'
at_least_one_of:
- 'filter.0.included_cloud_storage_buckets'
- 'filter.0.excluded_cloud_storage_buckets'
- 'filter.0.included_cloud_storage_locations'
- 'filter.0.excluded_cloud_storage_locations'
diff_suppress_func: 'intelligenceFilterincludedCloudStorageBucketsDiffSuppress'
properties:
- name: bucketIdRegexes
required: true
send_empty_value: true
type: Array
item_type:
type: String
description: |
List of bucket id regexes to exclude in the storage intelligence plan.
- name: excludedCloudStorageLocations
type: NestedObject
required: false
description: |
Locations to exclude from the Storage Intelligence plan.
conflicts:
- 'filter.0.included_cloud_storage_locations'
at_least_one_of:
- 'filter.0.included_cloud_storage_buckets'
- 'filter.0.excluded_cloud_storage_buckets'
- 'filter.0.included_cloud_storage_locations'
- 'filter.0.excluded_cloud_storage_locations'
diff_suppress_func: 'intelligenceFilterExcludedCloudStorageLocationsDiffSuppress'
properties:
- name: locations
type: Array
required: true
send_empty_value: true
description: |
List of locations.
item_type:
type: String
- name: includedCloudStorageLocations
type: NestedObject
required: false
description: |
Locations to include in the Storage Intelligence plan.
conflicts:
- 'filter.0.excluded_cloud_storage_locations'
at_least_one_of:
- 'filter.0.included_cloud_storage_buckets'
- 'filter.0.excluded_cloud_storage_buckets'
- 'filter.0.included_cloud_storage_locations'
- 'filter.0.excluded_cloud_storage_locations'
diff_suppress_func: 'intelligenceFilterincludedCloudStorageLocationsDiffSuppress'
properties:
- name: locations
type: Array
required: true
send_empty_value: true
description: |
List of locations.
item_type:
type: String
- name: 'effectiveIntelligenceConfig'
output: true
description: |
The Intelligence config that is effective for the resource.
type: NestedObject
properties:
- name: intelligenceConfig
type: String
output: true
description: |
The Intelligence config resource that is applied for the target resource.
- name: effectiveEdition
type: String
output: true
description: |
The `StorageIntelligence` edition that is applicable for the resource.
- name: 'trialConfig'
output: true
description: |
The trial configuration of the Storage Intelligence resource.
type: NestedObject
properties:
- name: expireTime
type: String
output: true
description: |
The time at which the trial expires.