{
  "fullyEncodeReservedExpansion": true,
  "title": "Backup and DR Service API",
  "canonicalName": "Backupdr",
  "parameters": {
    "upload_protocol": {
      "location": "query",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "type": "string"
    },
    "access_token": {
      "location": "query",
      "description": "OAuth access token.",
      "type": "string"
    },
    "alt": {
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "description": "Data format for response.",
      "type": "string",
      "default": "json",
      "location": "query"
    },
    "callback": {
      "type": "string",
      "location": "query",
      "description": "JSONP"
    },
    "quotaUser": {
      "location": "query",
      "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.",
      "type": "string"
    },
    "fields": {
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query",
      "type": "string"
    },
    "prettyPrint": {
      "type": "boolean",
      "default": "true",
      "description": "Returns response with indentations and line breaks.",
      "location": "query"
    },
    "$.xgafv": {
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "location": "query",
      "type": "string"
    },
    "uploadType": {
      "location": "query",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "type": "string"
    },
    "key": {
      "type": "string",
      "location": "query",
      "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token."
    },
    "oauth_token": {
      "type": "string",
      "location": "query",
      "description": "OAuth 2.0 token for the current user."
    }
  },
  "version_module": true,
  "ownerName": "Google",
  "basePath": "",
  "endpoints": [
    {
      "endpointUrl": "https://backupdr.africa-south1.rep.googleapis.com/",
      "location": "africa-south1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.asia-east1.rep.googleapis.com/",
      "location": "asia-east1",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-east2.rep.googleapis.com/",
      "location": "asia-east2"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-northeast1.rep.googleapis.com/",
      "location": "asia-northeast1"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-northeast2.rep.googleapis.com/",
      "location": "asia-northeast2"
    },
    {
      "endpointUrl": "https://backupdr.asia-northeast3.rep.googleapis.com/",
      "location": "asia-northeast3",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-south1.rep.googleapis.com/",
      "location": "asia-south1"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-south2.rep.googleapis.com/",
      "location": "asia-south2"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-southeast1.rep.googleapis.com/",
      "location": "asia-southeast1"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-southeast2.rep.googleapis.com/",
      "location": "asia-southeast2"
    },
    {
      "endpointUrl": "https://backupdr.australia-southeast1.rep.googleapis.com/",
      "location": "australia-southeast1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.australia-southeast2.rep.googleapis.com/",
      "location": "australia-southeast2",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-central2.rep.googleapis.com/",
      "location": "europe-central2",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-north1.rep.googleapis.com/",
      "location": "europe-north1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-north2.rep.googleapis.com/",
      "location": "europe-north2",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-southwest1.rep.googleapis.com/",
      "location": "europe-southwest1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west1.rep.googleapis.com/",
      "location": "europe-west1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west2.rep.googleapis.com/",
      "location": "europe-west2",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west3.rep.googleapis.com/",
      "location": "europe-west3",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west4.rep.googleapis.com/",
      "location": "europe-west4",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.europe-west6.rep.googleapis.com/",
      "location": "europe-west6"
    },
    {
      "endpointUrl": "https://backupdr.europe-west8.rep.googleapis.com/",
      "location": "europe-west8",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west9.rep.googleapis.com/",
      "location": "europe-west9",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west10.rep.googleapis.com/",
      "location": "europe-west10",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.europe-west12.rep.googleapis.com/",
      "location": "europe-west12",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.me-central1.rep.googleapis.com/",
      "location": "me-central1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.me-central2.rep.googleapis.com/",
      "location": "me-central2",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.me-west1.rep.googleapis.com/",
      "location": "me-west1"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.northamerica-northeast1.rep.googleapis.com/",
      "location": "northamerica-northeast1"
    },
    {
      "endpointUrl": "https://backupdr.northamerica-northeast2.rep.googleapis.com/",
      "location": "northamerica-northeast2",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.northamerica-south1.rep.googleapis.com/",
      "location": "northamerica-south1"
    },
    {
      "endpointUrl": "https://backupdr.southamerica-east1.rep.googleapis.com/",
      "location": "southamerica-east1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.southamerica-west1.rep.googleapis.com/",
      "location": "southamerica-west1",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-central1.rep.googleapis.com/",
      "location": "us-central1"
    },
    {
      "endpointUrl": "https://backupdr.us-central2.rep.googleapis.com/",
      "location": "us-central2",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east1.rep.googleapis.com/",
      "location": "us-east1"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east4.rep.googleapis.com/",
      "location": "us-east4"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east5.rep.googleapis.com/",
      "location": "us-east5"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east7.rep.googleapis.com/",
      "location": "us-east7"
    },
    {
      "endpointUrl": "https://backupdr.us-south1.rep.googleapis.com/",
      "location": "us-south1",
      "description": "Regional Endpoint"
    },
    {
      "endpointUrl": "https://backupdr.us-west1.rep.googleapis.com/",
      "location": "us-west1",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-west2.rep.googleapis.com/",
      "location": "us-west2"
    },
    {
      "endpointUrl": "https://backupdr.us-west3.rep.googleapis.com/",
      "location": "us-west3",
      "description": "Regional Endpoint"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-west4.rep.googleapis.com/",
      "location": "us-west4"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-west8.rep.googleapis.com/",
      "location": "us-west8"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us.rep.googleapis.com/",
      "location": "us"
    },
    {
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.eu.rep.googleapis.com/",
      "location": "eu"
    }
  ],
  "id": "backupdr:v1",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "discoveryVersion": "v1",
  "description": "",
  "name": "backupdr",
  "kind": "discovery#restDescription",
  "servicePath": "",
  "rootUrl": "https://backupdr.googleapis.com/",
  "baseUrl": "https://backupdr.googleapis.com/",
  "ownerDomain": "google.com",
  "revision": "20260510",
  "mtlsRootUrl": "https://backupdr.mtls.googleapis.com/",
  "protocol": "rest",
  "batchPath": "batch",
  "resources": {
    "projects": {
      "resources": {
        "locations": {
          "methods": {
            "getTrial": {
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial",
              "httpMethod": "GET",
              "response": {
                "$ref": "Trial"
              },
              "parameters": {
                "name": {
                  "description": "Required. The project for which trial details need to be retrieved. Format: projects/{project}/locations/{location} Supported Locations are - us, eu and asia.",
                  "pattern": "^projects/[^/]+/locations/[^/]+/trial$",
                  "location": "path",
                  "required": true,
                  "type": "string"
                }
              },
              "path": "v1/{+name}",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "description": "Gets the Trial state for a given project",
              "parameterOrder": [
                "name"
              ],
              "id": "backupdr.projects.locations.getTrial"
            },
            "list": {
              "parameters": {
                "filter": {
                  "type": "string",
                  "location": "query",
                  "description": "A filter to narrow down results to a preferred subset. The filtering language accepts strings like `\"displayName=tokyo\"`, and is documented in more detail in [AIP-160](https://google.aip.dev/160)."
                },
                "pageSize": {
                  "type": "integer",
                  "location": "query",
                  "description": "The maximum number of results to return. If not set, the service selects a default.",
                  "format": "int32"
                },
                "pageToken": {
                  "location": "query",
                  "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.",
                  "type": "string"
                },
                "name": {
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^projects/[^/]+$",
                  "description": "The resource that owns the locations collection, if applicable."
                },
                "extraLocationTypes": {
                  "type": "string",
                  "repeated": true,
                  "description": "Optional. Do not use this field unless explicitly documented otherwise. This is primarily for internal usage.",
                  "location": "query"
                }
              },
              "flatPath": "v1/projects/{projectsId}/locations",
              "httpMethod": "GET",
              "response": {
                "$ref": "ListLocationsResponse"
              },
              "path": "v1/{+name}/locations",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "parameterOrder": [
                "name"
              ],
              "description": "Lists information about the supported locations for this service. This method lists locations based on the resource scope provided in the ListLocationsRequest.name field: * **Global locations**: If `name` is empty, the method lists the public locations available to all projects. * **Project-specific locations**: If `name` follows the format `projects/{project}`, the method lists locations visible to that specific project. This includes public, private, or other project-specific locations enabled for the project. For gRPC and client library implementations, the resource name is passed as the `name` field. For direct service calls, the resource name is incorporated into the request path based on the specific service implementation and version.",
              "id": "backupdr.projects.locations.list"
            },
            "get": {
              "id": "backupdr.projects.locations.get",
              "parameterOrder": [
                "name"
              ],
              "description": "Gets information about a location.",
              "path": "v1/{+name}",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "parameters": {
                "name": {
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "description": "Resource name for the location."
                }
              },
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}",
              "httpMethod": "GET",
              "response": {
                "$ref": "Location"
              }
            }
          },
          "resources": {
            "backupVaults": {
              "methods": {
                "testIamPermissions": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}:testIamPermissions",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "TestIamPermissionsResponse"
                  },
                  "parameters": {
                    "resource": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$",
                      "description": "REQUIRED: The resource for which the policy detail is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field."
                    }
                  },
                  "request": {
                    "$ref": "TestIamPermissionsRequest"
                  },
                  "path": "v1/{+resource}:testIamPermissions",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Returns the caller's permissions on a BackupVault resource. A caller is not required to have Google IAM permission to make this request.",
                  "parameterOrder": [
                    "resource"
                  ],
                  "id": "backupdr.projects.locations.backupVaults.testIamPermissions"
                },
                "list": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists BackupVaults in a given project and location.",
                  "id": "backupdr.projects.locations.backupVaults.list",
                  "parameters": {
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "format": "int32",
                      "location": "query",
                      "type": "integer"
                    },
                    "filter": {
                      "type": "string",
                      "description": "Optional. Filtering results.",
                      "location": "query"
                    },
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    },
                    "orderBy": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. Hint for how to order the results."
                    },
                    "view": {
                      "enumDescriptions": [
                        "If the value is not set, the default 'FULL' view is used.",
                        "Includes basic data about the Backup Vault, but not the full contents.",
                        "Includes all data about the Backup Vault. This is the default value (for both ListBackupVaults and GetBackupVault)."
                      ],
                      "enum": [
                        "BACKUP_VAULT_VIEW_UNSPECIFIED",
                        "BACKUP_VAULT_VIEW_BASIC",
                        "BACKUP_VAULT_VIEW_FULL"
                      ],
                      "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup Vault.",
                      "type": "string",
                      "location": "query"
                    },
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The project and location for which to retrieve backupvault stores information, in the format 'projects/{project_id}/locations/{location}'. In Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve backupvault stores for all locations, use \"-\" for the '{location}' value.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListBackupVaultsResponse"
                  },
                  "path": "v1/{+parent}/backupVaults",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "create": {
                  "description": "Creates a new BackupVault in a given project and location.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "backupdr.projects.locations.backupVaults.create",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "validateOnly": {
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. Value for parent."
                    },
                    "backupVaultId": {
                      "type": "string",
                      "location": "query",
                      "description": "Required. ID of the requesting object If auto-generating ID server-side, remove this field and backup_vault_id from the method_signature of Create RPC"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "BackupVault"
                  },
                  "path": "v1/{+parent}/backupVaults",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "patch": {
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "forceUpdateAccessRestriction": {
                      "type": "boolean",
                      "location": "query",
                      "description": "Optional. If set to true, we will force update access restriction even if some non compliant data sources are present. The default is 'false'."
                    },
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$",
                      "description": "Output only. Identifier. Name of the backup vault to create. It must have the format`\"projects/{project}/locations/{location}/backupVaults/{backupvault}\"`. `{backupvault}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the project and location."
                    },
                    "updateMask": {
                      "type": "string",
                      "description": "Required. Field mask is used to specify the fields to be overwritten in the BackupVault resource by the update. The fields specified in the update_mask are relative to the resource, not the full request. A field will be overwritten if it is in the mask. If the user does not provide a mask then the request will fail.",
                      "format": "google-fieldmask",
                      "location": "query"
                    },
                    "force": {
                      "location": "query",
                      "description": "Optional. If set to true, will not check plan duration against backup vault enforcement duration.",
                      "type": "boolean"
                    },
                    "validateOnly": {
                      "location": "query",
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "type": "boolean"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "BackupVault"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}",
                  "httpMethod": "PATCH",
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "backupdr.projects.locations.backupVaults.patch",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Updates the settings of a BackupVault."
                },
                "delete": {
                  "id": "backupdr.projects.locations.backupVaults.delete",
                  "description": "Deletes a BackupVault.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}",
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "validateOnly": {
                      "location": "query",
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "type": "boolean"
                    },
                    "force": {
                      "type": "boolean",
                      "location": "query",
                      "description": "Optional. If set to true, any data source from this backup vault will also be deleted."
                    },
                    "requestId": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000)."
                    },
                    "ignoreBackupPlanReferences": {
                      "type": "boolean",
                      "location": "query",
                      "description": "Optional. If set to true, backupvault deletion will proceed even if there are backup plans referencing the backupvault. The default is 'false'."
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. Name of the resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$"
                    },
                    "allowMissing": {
                      "type": "boolean",
                      "description": "Optional. If true and the BackupVault is not found, the request will succeed but no action will be taken.",
                      "location": "query"
                    },
                    "etag": {
                      "type": "string",
                      "location": "query",
                      "description": "The current etag of the backup vault. If an etag is provided and does not match the current etag of the connection, deletion will be blocked."
                    }
                  }
                },
                "fetchUsable": {
                  "id": "backupdr.projects.locations.backupVaults.fetchUsable",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "FetchUsableBackupVaults lists usable BackupVaults in a given project and location. Usable BackupVault are the ones that user has backupdr.backupVaults.get permission.",
                  "path": "v1/{+parent}/backupVaults:fetchUsable",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The project and location for which to retrieve backupvault stores information, in the format 'projects/{project_id}/locations/{location}'. In Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve backupvault stores for all locations, use \"-\" for the '{location}' value.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query"
                    },
                    "filter": {
                      "description": "Optional. Filtering results.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "type": "integer",
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "format": "int32"
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query",
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults:fetchUsable",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchUsableBackupVaultsResponse"
                  }
                },
                "get": {
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "BackupVault"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$",
                      "description": "Required. Name of the backupvault store resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{resource_name}'",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "view": {
                      "enumDescriptions": [
                        "If the value is not set, the default 'FULL' view is used.",
                        "Includes basic data about the Backup Vault, but not the full contents.",
                        "Includes all data about the Backup Vault. This is the default value (for both ListBackupVaults and GetBackupVault)."
                      ],
                      "enum": [
                        "BACKUP_VAULT_VIEW_UNSPECIFIED",
                        "BACKUP_VAULT_VIEW_BASIC",
                        "BACKUP_VAULT_VIEW_FULL"
                      ],
                      "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup Vault",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "id": "backupdr.projects.locations.backupVaults.get",
                  "description": "Gets details of a BackupVault.",
                  "parameterOrder": [
                    "name"
                  ]
                }
              },
              "resources": {
                "dataSources": {
                  "methods": {
                    "patch": {
                      "path": "v1/{+name}",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameters": {
                        "name": {
                          "description": "Output only. Identifier. Name of the datasource to create. It must have the format`\"projects/{project}/locations/{location}/backupVaults/{backupvault}/dataSources/{datasource}\"`. `{datasource}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the backup vault.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        },
                        "updateMask": {
                          "location": "query",
                          "description": "Required. Field mask is used to specify the fields to be overwritten in the DataSource resource by the update. The fields specified in the update_mask are relative to the resource, not the full request. A field will be overwritten if it is in the mask. If the user does not provide a mask then the request will fail.",
                          "format": "google-fieldmask",
                          "type": "string"
                        },
                        "allowMissing": {
                          "location": "query",
                          "description": "Optional. Enable upsert.",
                          "type": "boolean"
                        },
                        "requestId": {
                          "type": "string",
                          "location": "query",
                          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000)."
                        }
                      },
                      "request": {
                        "$ref": "DataSource"
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}",
                      "httpMethod": "PATCH",
                      "response": {
                        "$ref": "Operation"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.patch",
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Updates the settings of a DataSource."
                    },
                    "abandonBackup": {
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Internal only. Abandons a backup.",
                      "id": "backupdr.projects.locations.backupVaults.dataSources.abandonBackup",
                      "parameters": {
                        "dataSource": {
                          "type": "string",
                          "location": "path",
                          "required": true,
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'."
                        }
                      },
                      "request": {
                        "$ref": "AbandonBackupRequest"
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:abandonBackup",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      },
                      "path": "v1/{+dataSource}:abandonBackup",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    },
                    "fetchAccessToken": {
                      "path": "v1/{+name}:fetchAccessToken",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:fetchAccessToken",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "FetchAccessTokenResponse"
                      },
                      "parameters": {
                        "name": {
                          "type": "string",
                          "location": "path",
                          "required": true,
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "description": "Required. The resource name for the location for which static IPs should be returned. Must be in the format 'projects/*/locations/*/backupVaults/*/dataSources'."
                        }
                      },
                      "request": {
                        "$ref": "FetchAccessTokenRequest"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.fetchAccessToken",
                      "description": "Internal only. Fetch access token for a given data source.",
                      "parameterOrder": [
                        "name"
                      ]
                    },
                    "setInternalStatus": {
                      "path": "v1/{+dataSource}:setInternalStatus",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:setInternalStatus",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "dataSource": {
                          "type": "string",
                          "location": "path",
                          "required": true,
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'."
                        }
                      },
                      "request": {
                        "$ref": "SetInternalStatusRequest"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.setInternalStatus",
                      "description": "Sets the internal status of a DataSource.",
                      "parameterOrder": [
                        "dataSource"
                      ]
                    },
                    "remove": {
                      "path": "v1/{+name}:remove",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:remove",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "name": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. Name of the resource.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$"
                        }
                      },
                      "request": {
                        "$ref": "RemoveDataSourceRequest"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.remove",
                      "description": "Deletes a DataSource. This is a custom method instead of a standard delete method because external clients will not delete DataSources except for BackupDR backup appliances.",
                      "parameterOrder": [
                        "name"
                      ]
                    },
                    "list": {
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "ListDataSourcesResponse"
                      },
                      "parameters": {
                        "pageSize": {
                          "type": "integer",
                          "location": "query",
                          "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                          "format": "int32"
                        },
                        "filter": {
                          "description": "Optional. Filtering results.",
                          "location": "query",
                          "type": "string"
                        },
                        "pageToken": {
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "location": "query",
                          "type": "string"
                        },
                        "orderBy": {
                          "location": "query",
                          "description": "Optional. Hint for how to order the results.",
                          "type": "string"
                        },
                        "parent": {
                          "description": "Required. The project and location for which to retrieve data sources information, in the format 'projects/{project_id}/locations/{location}'. In Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve data sources for all locations, use \"-\" for the '{location}' value.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        }
                      },
                      "path": "v1/{+parent}/dataSources",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "description": "Lists DataSources in a given project and location.",
                      "parameterOrder": [
                        "parent"
                      ],
                      "id": "backupdr.projects.locations.backupVaults.dataSources.list"
                    },
                    "finalizeBackup": {
                      "id": "backupdr.projects.locations.backupVaults.dataSources.finalizeBackup",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Internal only. Finalize a backup that was started by a call to InitiateBackup.",
                      "path": "v1/{+dataSource}:finalizeBackup",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameters": {
                        "dataSource": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$"
                        }
                      },
                      "request": {
                        "$ref": "FinalizeBackupRequest"
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:finalizeBackup",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      }
                    },
                    "initiateBackup": {
                      "id": "backupdr.projects.locations.backupVaults.dataSources.initiateBackup",
                      "description": "Internal only. Initiates a backup.",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "path": "v1/{+dataSource}:initiateBackup",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:initiateBackup",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "InitiateBackupResponse"
                      },
                      "parameters": {
                        "dataSource": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$"
                        }
                      },
                      "request": {
                        "$ref": "InitiateBackupRequest"
                      }
                    },
                    "get": {
                      "path": "v1/{+name}",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "DataSource"
                      },
                      "parameters": {
                        "name": {
                          "type": "string",
                          "location": "path",
                          "required": true,
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "description": "Required. Name of the data source resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{resource_name}/dataSource/{resource_name}'"
                        }
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.get",
                      "description": "Gets details of a DataSource.",
                      "parameterOrder": [
                        "name"
                      ]
                    }
                  },
                  "resources": {
                    "backups": {
                      "methods": {
                        "get": {
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "httpMethod": "GET",
                          "response": {
                            "$ref": "Backup"
                          },
                          "parameters": {
                            "name": {
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$",
                              "description": "Required. Name of the data source resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{backupVault}/dataSources/{datasource}/backups/{backup}'",
                              "type": "string",
                              "location": "path",
                              "required": true
                            },
                            "view": {
                              "type": "string",
                              "location": "query",
                              "enumDescriptions": [
                                "If the value is not set, the default 'FULL' view is used.",
                                "Includes basic data about the Backup, but not the full contents.",
                                "Includes all data about the Backup. This is the default value (for both ListBackups and GetBackup)."
                              ],
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ],
                              "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup resource."
                            }
                          },
                          "path": "v1/{+name}",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "description": "Gets details of a Backup.",
                          "parameterOrder": [
                            "name"
                          ],
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.get"
                        },
                        "patch": {
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Updates the settings of a Backup.",
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.patch",
                          "parameters": {
                            "requestId": {
                              "type": "string",
                              "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                              "location": "query"
                            },
                            "name": {
                              "description": "Output only. Identifier. Name of the backup to create. It must have the format`\"projects//locations//backupVaults//dataSources/{datasource}/backups/{backup}\"`. `{backup}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the datasource.",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$",
                              "location": "path",
                              "required": true,
                              "type": "string"
                            },
                            "updateMask": {
                              "type": "string",
                              "description": "Required. Field mask is used to specify the fields to be overwritten in the Backup resource by the update. The fields specified in the update_mask are relative to the resource, not the full request. A field will be overwritten if it is in the mask. If the user does not provide a mask then the request will fail.",
                              "format": "google-fieldmask",
                              "location": "query"
                            }
                          },
                          "request": {
                            "$ref": "Backup"
                          },
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "httpMethod": "PATCH",
                          "response": {
                            "$ref": "Operation"
                          },
                          "path": "v1/{+name}",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ]
                        },
                        "delete": {
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "httpMethod": "DELETE",
                          "response": {
                            "$ref": "Operation"
                          },
                          "parameters": {
                            "name": {
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$",
                              "description": "Required. Name of the resource.",
                              "type": "string",
                              "location": "path",
                              "required": true
                            },
                            "requestId": {
                              "location": "query",
                              "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                              "type": "string"
                            }
                          },
                          "path": "v1/{+name}",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "description": "Deletes a Backup.",
                          "parameterOrder": [
                            "name"
                          ],
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.delete"
                        },
                        "list": {
                          "parameters": {
                            "filter": {
                              "location": "query",
                              "description": "Optional. Filtering results.",
                              "type": "string"
                            },
                            "pageSize": {
                              "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                              "format": "int32",
                              "location": "query",
                              "type": "integer"
                            },
                            "pageToken": {
                              "description": "Optional. A token identifying a page of results the server should return.",
                              "location": "query",
                              "type": "string"
                            },
                            "parent": {
                              "type": "string",
                              "location": "path",
                              "required": true,
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                              "description": "Required. The project and location for which to retrieve backup information, in the format 'projects/{project_id}/locations/{location}'. In Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve data sources for all locations, use \"-\" for the '{location}' value."
                            },
                            "orderBy": {
                              "description": "Optional. Hint for how to order the results.",
                              "location": "query",
                              "type": "string"
                            },
                            "view": {
                              "enumDescriptions": [
                                "If the value is not set, the default 'FULL' view is used.",
                                "Includes basic data about the Backup, but not the full contents.",
                                "Includes all data about the Backup. This is the default value (for both ListBackups and GetBackup)."
                              ],
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ],
                              "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup resource.",
                              "type": "string",
                              "location": "query"
                            }
                          },
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups",
                          "httpMethod": "GET",
                          "response": {
                            "$ref": "ListBackupsResponse"
                          },
                          "path": "v1/{+parent}/backups",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "parameterOrder": [
                            "parent"
                          ],
                          "description": "Lists Backups in a given project and location.",
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.list"
                        },
                        "restore": {
                          "path": "v1/{+name}:restore",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "parameters": {
                            "name": {
                              "type": "string",
                              "location": "path",
                              "required": true,
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$",
                              "description": "Required. The resource name of the Backup instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/*/backups/'."
                            }
                          },
                          "request": {
                            "$ref": "RestoreBackupRequest"
                          },
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}:restore",
                          "httpMethod": "POST",
                          "response": {
                            "$ref": "Operation"
                          },
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.restore",
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Restore from a Backup"
                        },
                        "fetchForResourceType": {
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.fetchForResourceType",
                          "description": "Fetch Backups for a given resource type.",
                          "parameterOrder": [
                            "parent"
                          ],
                          "path": "v1/{+parent}/backups:fetchForResourceType",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups:fetchForResourceType",
                          "httpMethod": "GET",
                          "response": {
                            "$ref": "FetchBackupsForResourceTypeResponse"
                          },
                          "parameters": {
                            "parent": {
                              "description": "Required. Datasources are the parent resource for the backups. Format: projects/{project}/locations/{location}/backupVaults/{backupVaultId}/dataSources/{datasourceId}",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                              "location": "path",
                              "required": true,
                              "type": "string"
                            },
                            "orderBy": {
                              "location": "query",
                              "description": "Optional. A comma-separated list of fields to order by, sorted in ascending order. Use \"desc\" after a field name for descending. Supported fields: * name",
                              "type": "string"
                            },
                            "view": {
                              "enumDescriptions": [
                                "If the value is not set, the default 'FULL' view is used.",
                                "Includes basic data about the Backup, but not the full contents.",
                                "Includes all data about the Backup. This is the default value (for both ListBackups and GetBackup)."
                              ],
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ],
                              "description": "Optional. This parameter is used to specify the view of the backup. If not specified, the default view is BASIC.",
                              "type": "string",
                              "location": "query"
                            },
                            "pageToken": {
                              "location": "query",
                              "description": "Optional. A page token, received from a previous call of `FetchBackupsForResourceType`. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `FetchBackupsForResourceType` must match the call that provided the page token.",
                              "type": "string"
                            },
                            "resourceType": {
                              "description": "Required. The type of the Google Cloud resource. Ex: sqladmin.googleapis.com/Instance",
                              "location": "query",
                              "type": "string"
                            },
                            "filter": {
                              "description": "Optional. A filter expression that filters the results fetched in the response. The expression must specify the field name, a comparison operator, and the value that you want to use for filtering. Supported fields: * name * state * backup_type * create_time * expire_time * enforced_retention_end_time * gcp_backup_plan_info.backup_plan * cloud_sql_instance_backup_properties.instance_tier * cloud_sql_instance_backup_properties.database_installed_version",
                              "location": "query",
                              "type": "string"
                            },
                            "pageSize": {
                              "location": "query",
                              "description": "Optional. The maximum number of Backups to return. The service may return fewer than this value. If unspecified, at most 50 Backups will be returned. The maximum value is 100; values above 100 will be coerced to 100.",
                              "format": "int32",
                              "type": "integer"
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            },
            "trial": {
              "methods": {
                "end": {
                  "description": "Ends the trial for a project",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "backupdr.projects.locations.trial.end",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial:end",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Trial"
                  },
                  "parameters": {
                    "parent": {
                      "description": "Required. The parent resource where the trial has been created. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "EndTrialRequest"
                  },
                  "path": "v1/{+parent}/trial:end",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "subscribe": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial:subscribe",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Trial"
                  },
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The project where this trial will be created. Format: projects/{project}/locations/{location} Supported Locations are - us, eu and asia."
                    }
                  },
                  "request": {
                    "$ref": "SubscribeTrialRequest"
                  },
                  "path": "v1/{+parent}/trial:subscribe",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Subscribes to a trial for a project",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "backupdr.projects.locations.trial.subscribe"
                }
              }
            },
            "backupPlans": {
              "methods": {
                "list": {
                  "id": "backupdr.projects.locations.backupPlans.list",
                  "description": "Lists BackupPlans in a given project and location.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/backupPlans",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListBackupPlansResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. The value of next_page_token received from a previous `ListBackupPlans` call. Provide this to retrieve the subsequent page in a multi-page list of results. When paginating, all other parameters provided to `ListBackupPlans` must match the call that provided the page token.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "type": "integer",
                      "location": "query",
                      "description": "Optional. The maximum number of `BackupPlans` to return in a single response. If not specified, a default value will be chosen by the service. Note that the response may include a partial list and a caller should only rely on the response's next_page_token to determine if there are more instances left to be queried.",
                      "format": "int32"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Field match expression used to filter the results.",
                      "type": "string"
                    },
                    "orderBy": {
                      "location": "query",
                      "description": "Optional. Field by which to sort the results.",
                      "type": "string"
                    },
                    "parent": {
                      "description": "Required. The project and location for which to retrieve `BackupPlans` information. Format: `projects/{project}/locations/{location}`. In Google Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve backup plans for all locations, use \"-\" for the `{location}` value.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  }
                },
                "create": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Create a BackupPlan",
                  "id": "backupdr.projects.locations.backupPlans.create",
                  "parameters": {
                    "requestId": {
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and t he request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "location": "query",
                      "type": "string"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The `BackupPlan` project and location in the format `projects/{project}/locations/{location}`. In Google Cloud Backup and DR locations map to Google Cloud regions, for example **us-central1**.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "backupPlanId": {
                      "type": "string",
                      "description": "Required. The name of the `BackupPlan` to create. The name must be unique for the specified project and location.The name must start with a lowercase letter followed by up to 62 lowercase letters, numbers, or hyphens. Pattern, /a-z{,62}/.",
                      "location": "query"
                    }
                  },
                  "request": {
                    "$ref": "BackupPlan"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1/{+parent}/backupPlans",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "patch": {
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Update a BackupPlan.",
                  "id": "backupdr.projects.locations.backupPlans.patch",
                  "parameters": {
                    "name": {
                      "description": "Output only. Identifier. The resource name of the `BackupPlan`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "updateMask": {
                      "type": "string",
                      "location": "query",
                      "description": "Required. The list of fields to update. Field mask is used to specify the fields to be overwritten in the BackupPlan resource by the update. The fields specified in the update_mask are relative to the resource, not the full request. A field will be overwritten if it is in the mask. If the user does not provide a mask then the request will fail. Currently, these fields are supported in update: description, schedules, retention period, adding and removing Backup Rules.",
                      "format": "google-fieldmask"
                    },
                    "requestId": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and t he request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000)."
                    }
                  },
                  "request": {
                    "$ref": "BackupPlan"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "httpMethod": "PATCH",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "delete": {
                  "id": "backupdr.projects.locations.backupPlans.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a single BackupPlan.",
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+$",
                      "description": "Required. The resource name of the `BackupPlan` to delete. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "get": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The resource name of the `BackupPlan` to retrieve. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+$"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "BackupPlan"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single BackupPlan.",
                  "id": "backupdr.projects.locations.backupPlans.get"
                }
              },
              "resources": {
                "revisions": {
                  "methods": {
                    "list": {
                      "description": "Lists BackupPlanRevisions in a given project and location.",
                      "parameterOrder": [
                        "parent"
                      ],
                      "id": "backupdr.projects.locations.backupPlans.revisions.list",
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}/revisions",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "ListBackupPlanRevisionsResponse"
                      },
                      "parameters": {
                        "pageSize": {
                          "type": "integer",
                          "description": "Optional. The maximum number of `BackupPlans` to return in a single response. If not specified, a default value will be chosen by the service. Note that the response may include a partial list and a caller should only rely on the response's next_page_token to determine if there are more instances left to be queried.",
                          "format": "int32",
                          "location": "query"
                        },
                        "parent": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The project and location for which to retrieve `BackupPlanRevisions` information. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`. In Google Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+$"
                        },
                        "pageToken": {
                          "type": "string",
                          "location": "query",
                          "description": "Optional. The value of next_page_token received from a previous `ListBackupPlans` call. Provide this to retrieve the subsequent page in a multi-page list of results. When paginating, all other parameters provided to `ListBackupPlans` must match the call that provided the page token."
                        }
                      },
                      "path": "v1/{+parent}/revisions",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    },
                    "get": {
                      "parameters": {
                        "name": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The resource name of the `BackupPlanRevision` to retrieve. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}/revisions/{revision}`",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+/revisions/[^/]+$"
                        }
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}/revisions/{revisionsId}",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "BackupPlanRevision"
                      },
                      "path": "v1/{+name}",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Gets details of a single BackupPlanRevision.",
                      "id": "backupdr.projects.locations.backupPlans.revisions.get"
                    }
                  }
                }
              }
            },
            "managementServers": {
              "methods": {
                "create": {
                  "path": "v1/{+parent}/managementServers",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The management server project and location in the format 'projects/{project_id}/locations/{location}'. In Cloud Backup and DR locations map to Google Cloud regions, for example **us-central1**."
                    },
                    "requestId": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000)."
                    },
                    "managementServerId": {
                      "location": "query",
                      "description": "Required. The name of the management server to create. The name must be unique for the specified project and location.",
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "ManagementServer"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "backupdr.projects.locations.managementServers.create",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Creates a new ManagementServer in a given project and location."
                },
                "delete": {
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}",
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$",
                      "description": "Required. Name of the resource"
                    },
                    "requestId": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000)."
                    }
                  },
                  "id": "backupdr.projects.locations.managementServers.delete",
                  "description": "Deletes a single ManagementServer.",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "setIamPolicy": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:setIamPolicy",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Policy"
                  },
                  "parameters": {
                    "resource": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$",
                      "description": "REQUIRED: The resource for which the policy is being specified. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field."
                    }
                  },
                  "request": {
                    "$ref": "SetIamPolicyRequest"
                  },
                  "path": "v1/{+resource}:setIamPolicy",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Sets the access control policy on the specified resource. Replaces any existing policy. Can return `NOT_FOUND`, `INVALID_ARGUMENT`, and `PERMISSION_DENIED` errors.",
                  "parameterOrder": [
                    "resource"
                  ],
                  "id": "backupdr.projects.locations.managementServers.setIamPolicy"
                },
                "getIamPolicy": {
                  "parameterOrder": [
                    "resource"
                  ],
                  "description": "Gets the access control policy for a resource. Returns an empty policy if the resource exists and does not have a policy set.",
                  "id": "backupdr.projects.locations.managementServers.getIamPolicy",
                  "parameters": {
                    "resource": {
                      "description": "REQUIRED: The resource for which the policy is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "options.requestedPolicyVersion": {
                      "description": "Optional. The maximum policy version that will be used to format the policy. Valid values are 0, 1, and 3. Requests specifying an invalid value will be rejected. Requests for policies with any conditional role bindings must specify version 3. Policies with no conditional role bindings may specify any valid value or leave the field unset. The policy in the response might use the policy version that you specified, or it might use a lower policy version. For example, if you specify version 3, but the policy has no conditional role bindings, the response uses version 1. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).",
                      "format": "int32",
                      "location": "query",
                      "type": "integer"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:getIamPolicy",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "Policy"
                  },
                  "path": "v1/{+resource}:getIamPolicy",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "list": {
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "format": "int32",
                      "type": "integer"
                    },
                    "filter": {
                      "type": "string",
                      "description": "Optional. Filtering results.",
                      "location": "query"
                    },
                    "orderBy": {
                      "location": "query",
                      "description": "Optional. Hint for how to order the results.",
                      "type": "string"
                    },
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The project and location for which to retrieve management servers information, in the format 'projects/{project_id}/locations/{location}'. In Google Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve management servers for all locations, use \"-\" for the '{location}' value."
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListManagementServersResponse"
                  },
                  "path": "v1/{+parent}/managementServers",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists ManagementServers in a given project and location.",
                  "id": "backupdr.projects.locations.managementServers.list"
                },
                "testIamPermissions": {
                  "id": "backupdr.projects.locations.managementServers.testIamPermissions",
                  "description": "Returns permissions that a caller has on the specified resource. If the resource does not exist, this will return an empty set of permissions, not a `NOT_FOUND` error. Note: This operation is designed to be used for building permission-aware UIs and command-line tools, not for authorization checking. This operation may \"fail open\" without warning.",
                  "parameterOrder": [
                    "resource"
                  ],
                  "path": "v1/{+resource}:testIamPermissions",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:testIamPermissions",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "TestIamPermissionsResponse"
                  },
                  "parameters": {
                    "resource": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "REQUIRED: The resource for which the policy detail is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$"
                    }
                  },
                  "request": {
                    "$ref": "TestIamPermissionsRequest"
                  }
                },
                "get": {
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single ManagementServer.",
                  "id": "backupdr.projects.locations.managementServers.get",
                  "parameters": {
                    "name": {
                      "description": "Required. Name of the management server resource name, in the format 'projects/{project_id}/locations/{location}/managementServers/{resource_name}'",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ManagementServer"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "msComplianceMetadata": {
                  "description": "Returns the Assured Workloads compliance metadata for a given project.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "backupdr.projects.locations.managementServers.msComplianceMetadata",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers:msComplianceMetadata",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "FetchMsComplianceMetadataResponse"
                  },
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers$",
                      "description": "Required. The project and location to be used to check CSS metadata for target project information, in the format 'projects/{project_id}/locations/{location}'. In Google Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**."
                    }
                  },
                  "request": {
                    "$ref": "FetchMsComplianceMetadataRequest"
                  },
                  "path": "v1/{+parent}:msComplianceMetadata",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            },
            "resourceBackupConfigs": {
              "methods": {
                "list": {
                  "path": "v1/{+parent}/resourceBackupConfigs",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "filter": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. Filtering results."
                    },
                    "pageSize": {
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will use 100 as default. Maximum value is 500 and values above 500 will be coerced to 500.",
                      "format": "int32",
                      "type": "integer"
                    },
                    "pageToken": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. A token identifying a page of results the server should return."
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The project and location for which to retrieve resource backup configs. Format: 'projects/{project_id}/locations/{location}'. In Google Cloud Backup and DR, locations map to Google Cloud regions, for example **us-central1**.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "orderBy": {
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query",
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/resourceBackupConfigs",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListResourceBackupConfigsResponse"
                  },
                  "id": "backupdr.projects.locations.resourceBackupConfigs.list",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists ResourceBackupConfigs."
                },
                "fetch": {
                  "path": "v1/{+parent}/resourceBackupConfigs:fetch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "pageSize": {
                      "type": "integer",
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will use 100 as default. Maximum value is 500 and values above 500 will be coerced to 500.",
                      "format": "int32"
                    },
                    "filter": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. Filtering results."
                    },
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string"
                    },
                    "orderBy": {
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query",
                      "type": "string"
                    },
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The project, folder or organization and location for which to retrieve resource backup configs. Format: 'projects/{project_id}/locations/{location}', 'folders/{folder_id}/locations/{location}', or 'organizations/{organization_id}/locations/{location}'."
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/resourceBackupConfigs:fetch",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchResourceBackupConfigsResponse"
                  },
                  "id": "backupdr.projects.locations.resourceBackupConfigs.fetch",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Fetches ResourceBackupConfigs."
                }
              }
            },
            "backupPlanAssociations": {
              "methods": {
                "list": {
                  "path": "v1/{+parent}/backupPlanAssociations",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    },
                    "parent": {
                      "description": "Required. The project and location for which to retrieve backup Plan Associations information, in the format `projects/{project_id}/locations/{location}`. In Backup and DR, locations map to Google Cloud regions, for example **us-central1**. To retrieve backup plan associations for all locations, use \"-\" for the `{location}` value.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Filtering results",
                      "type": "string"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "format": "int32",
                      "location": "query",
                      "type": "integer"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListBackupPlanAssociationsResponse"
                  },
                  "id": "backupdr.projects.locations.backupPlanAssociations.list",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists BackupPlanAssociations in a given project and location."
                },
                "create": {
                  "path": "v1/{+parent}/backupPlanAssociations",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "backupPlanAssociationId": {
                      "location": "query",
                      "description": "Required. The name of the backup plan association to create. The name must be unique for the specified project and location.",
                      "type": "string"
                    },
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The backup plan association project and location in the format `projects/{project_id}/locations/{location}`. In Backup and DR locations map to Google Cloud regions, for example **us-central1**.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "requestId": {
                      "type": "string",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and t he request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "location": "query"
                    }
                  },
                  "request": {
                    "$ref": "BackupPlanAssociation"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "backupdr.projects.locations.backupPlanAssociations.create",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Create a BackupPlanAssociation"
                },
                "patch": {
                  "id": "backupdr.projects.locations.backupPlanAssociations.patch",
                  "description": "Update a BackupPlanAssociation.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "httpMethod": "PATCH",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and t he request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    },
                    "name": {
                      "description": "Output only. Identifier. The resource name of BackupPlanAssociation in below format Format : projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "updateMask": {
                      "type": "string",
                      "description": "Required. The list of fields to update. Field mask is used to specify the fields to be overwritten in the BackupPlanAssociation resource by the update. The fields specified in the update_mask are relative to the resource, not the full request. A field will be overwritten if it is in the mask. If the user does not provide a mask then the request will fail. Currently backup_plan_association.backup_plan is the only supported field.",
                      "format": "google-fieldmask",
                      "location": "query"
                    }
                  },
                  "request": {
                    "$ref": "BackupPlanAssociation"
                  }
                },
                "delete": {
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a single BackupPlanAssociation.",
                  "id": "backupdr.projects.locations.backupPlanAssociations.delete",
                  "parameters": {
                    "name": {
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "fetchForResourceType": {
                  "description": "List BackupPlanAssociations for a given resource type.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "backupdr.projects.locations.backupPlanAssociations.fetchForResourceType",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations:fetchForResourceType",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchBackupPlanAssociationsForResourceTypeResponse"
                  },
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}"
                    },
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. A comma-separated list of fields to order by, sorted in ascending order. Use \"desc\" after a field name for descending. Supported fields: * name",
                      "location": "query"
                    },
                    "resourceType": {
                      "description": "Required. The type of the Google Cloud resource. Ex: sql.googleapis.com/Instance",
                      "location": "query",
                      "type": "string"
                    },
                    "filter": {
                      "type": "string",
                      "description": "Optional. A filter expression that filters the results fetched in the response. The expression must specify the field name, a comparison operator, and the value that you want to use for filtering. Supported fields: * resource * backup_plan * state * data_source * cloud_sql_instance_backup_plan_association_properties.instance_create_time",
                      "location": "query"
                    },
                    "pageSize": {
                      "type": "integer",
                      "description": "Optional. The maximum number of BackupPlanAssociations to return. The service may return fewer than this value. If unspecified, at most 50 BackupPlanAssociations will be returned. The maximum value is 100; values above 100 will be coerced to 100.",
                      "format": "int32",
                      "location": "query"
                    },
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A page token, received from a previous call of `FetchBackupPlanAssociationsForResourceType`. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `FetchBackupPlanAssociationsForResourceType` must match the call that provided the page token.",
                      "type": "string"
                    }
                  },
                  "path": "v1/{+parent}/backupPlanAssociations:fetchForResourceType",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "get": {
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single BackupPlanAssociation.",
                  "id": "backupdr.projects.locations.backupPlanAssociations.get",
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$",
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "BackupPlanAssociation"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "triggerBackup": {
                  "description": "Triggers a new Backup.",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "backupdr.projects.locations.backupPlanAssociations.triggerBackup",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}:triggerBackup",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "name": {
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "TriggerBackupRequest"
                  },
                  "path": "v1/{+name}:triggerBackup",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            },
            "serviceConfig": {
              "methods": {
                "initialize": {
                  "path": "v1/{+name}:initialize",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/serviceConfig:initialize",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/serviceConfig$",
                      "description": "Required. The resource name of the serviceConfig used to initialize the service. The location must be the location of the BackupVault. Format: `projects/{project_id}/locations/{location}/serviceConfig`.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "InitializeServiceRequest"
                  },
                  "id": "backupdr.projects.locations.serviceConfig.initialize",
                  "description": "Initializes the service related config for a project.",
                  "parameterOrder": [
                    "name"
                  ]
                }
              }
            },
            "operations": {
              "methods": {
                "list": {
                  "path": "v1/{+name}/operations",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListOperationsResponse"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "The name of the operation's parent resource.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "returnPartialSuccess": {
                      "location": "query",
                      "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.",
                      "type": "boolean"
                    },
                    "pageToken": {
                      "description": "The standard list page token.",
                      "location": "query",
                      "type": "string"
                    },
                    "filter": {
                      "type": "string",
                      "location": "query",
                      "description": "The standard list filter."
                    },
                    "pageSize": {
                      "type": "integer",
                      "location": "query",
                      "description": "The standard list page size.",
                      "format": "int32"
                    }
                  },
                  "id": "backupdr.projects.locations.operations.list",
                  "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "delete": {
                  "id": "backupdr.projects.locations.operations.delete",
                  "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "Empty"
                  },
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource to be deleted.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  }
                },
                "cancel": {
                  "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "backupdr.projects.locations.operations.cancel",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}:cancel",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Empty"
                  },
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource to be cancelled.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "CancelOperationRequest"
                  },
                  "path": "v1/{+name}:cancel",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "get": {
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.",
                  "id": "backupdr.projects.locations.operations.get",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "The name of the operation resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            },
            "dataSourceReferences": {
              "methods": {
                "list": {
                  "id": "backupdr.projects.locations.dataSourceReferences.list",
                  "description": "Lists DataSourceReferences for a given project and location.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/dataSourceReferences",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListDataSourceReferencesResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. A page token, received from a previous `ListDataSourceReferences` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListDataSourceReferences` must match the call that provided the page token.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "description": "Optional. The maximum number of DataSourceReferences to return. The service may return fewer than this value. If unspecified, at most 50 DataSourceReferences will be returned. The maximum value is 100; values above 100 will be coerced to 100.",
                      "format": "int32",
                      "type": "integer"
                    },
                    "filter": {
                      "description": "Optional. A filter expression that filters the results listed in the response. The expression must specify the field name, a comparison operator, and the value that you want to use for filtering. The following field and operator combinations are supported: * data_source_gcp_resource_info.gcp_resourcename with `=`, `!=` * data_source_gcp_resource_info.type with `=`, `!=`",
                      "location": "query",
                      "type": "string"
                    },
                    "orderBy": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. A comma-separated list of fields to order by, sorted in ascending order. Use \"desc\" after a field name for descending. Supported fields: * data_source * data_source_gcp_resource_info.gcp_resourcename"
                    },
                    "parent": {
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  }
                },
                "get": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences/{dataSourceReferencesId}",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "DataSourceReference"
                  },
                  "parameters": {
                    "name": {
                      "description": "Required. The name of the DataSourceReference to retrieve. Format: projects/{project}/locations/{location}/dataSourceReferences/{data_source_reference}",
                      "pattern": "^projects/[^/]+/locations/[^/]+/dataSourceReferences/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Gets details of a single DataSourceReference.",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "backupdr.projects.locations.dataSourceReferences.get"
                },
                "fetchForResourceType": {
                  "id": "backupdr.projects.locations.dataSourceReferences.fetchForResourceType",
                  "description": "Fetch DataSourceReferences for a given project, location and resource type.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/dataSourceReferences:fetchForResourceType",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences:fetchForResourceType",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchDataSourceReferencesForResourceTypeResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. A page token, received from a previous call of `FetchDataSourceReferencesForResourceType`. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `FetchDataSourceReferencesForResourceType` must match the call that provided the page token."
                    },
                    "resourceType": {
                      "description": "Required. The type of the Google Cloud resource. Ex: sql.googleapis.com/Instance",
                      "location": "query",
                      "type": "string"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. A filter expression that filters the results fetched in the response. The expression must specify the field name, a comparison operator, and the value that you want to use for filtering. Supported fields: * data_source * data_source_gcp_resource_info.gcp_resourcename * data_source_backup_config_state * data_source_backup_count * data_source_backup_config_info.last_backup_state * data_source_gcp_resource_info.gcp_resourcename * data_source_gcp_resource_info.type * data_source_gcp_resource_info.location * data_source_gcp_resource_info.cloud_sql_instance_properties.instance_create_time",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "description": "Optional. The maximum number of DataSourceReferences to return. The service may return fewer than this value. If unspecified, at most 50 DataSourceReferences will be returned. The maximum value is 100; values above 100 will be coerced to 100.",
                      "format": "int32",
                      "type": "integer"
                    },
                    "parent": {
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "orderBy": {
                      "description": "Optional. A comma-separated list of fields to order by, sorted in ascending order. Use \"desc\" after a field name for descending. Supported fields: * name",
                      "location": "query",
                      "type": "string"
                    }
                  }
                }
              }
            }
          }
        }
      }
    },
    "folders": {
      "resources": {
        "locations": {
          "resources": {
            "resourceBackupConfigs": {
              "methods": {
                "fetch": {
                  "path": "v1/{+parent}/resourceBackupConfigs:fetch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/folders/{foldersId}/locations/{locationsId}/resourceBackupConfigs:fetch",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchResourceBackupConfigsResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    },
                    "pageSize": {
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will use 100 as default. Maximum value is 500 and values above 500 will be coerced to 500.",
                      "format": "int32",
                      "type": "integer"
                    },
                    "filter": {
                      "type": "string",
                      "description": "Optional. Filtering results.",
                      "location": "query"
                    },
                    "orderBy": {
                      "location": "query",
                      "description": "Optional. Hint for how to order the results.",
                      "type": "string"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The project, folder or organization and location for which to retrieve resource backup configs. Format: 'projects/{project_id}/locations/{location}', 'folders/{folder_id}/locations/{location}', or 'organizations/{organization_id}/locations/{location}'.",
                      "pattern": "^folders/[^/]+/locations/[^/]+$"
                    }
                  },
                  "id": "backupdr.folders.locations.resourceBackupConfigs.fetch",
                  "description": "Fetches ResourceBackupConfigs.",
                  "parameterOrder": [
                    "parent"
                  ]
                }
              }
            }
          }
        }
      }
    },
    "organizations": {
      "resources": {
        "locations": {
          "resources": {
            "resourceBackupConfigs": {
              "methods": {
                "fetch": {
                  "id": "backupdr.organizations.locations.resourceBackupConfigs.fetch",
                  "description": "Fetches ResourceBackupConfigs.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/resourceBackupConfigs:fetch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/organizations/{organizationsId}/locations/{locationsId}/resourceBackupConfigs:fetch",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchResourceBackupConfigsResponse"
                  },
                  "parameters": {
                    "orderBy": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. Hint for how to order the results."
                    },
                    "parent": {
                      "pattern": "^organizations/[^/]+/locations/[^/]+$",
                      "description": "Required. The project, folder or organization and location for which to retrieve resource backup configs. Format: 'projects/{project_id}/locations/{location}', 'folders/{folder_id}/locations/{location}', or 'organizations/{organization_id}/locations/{location}'.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "pageSize": {
                      "type": "integer",
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will use 100 as default. Maximum value is 500 and values above 500 will be coerced to 500.",
                      "format": "int32"
                    },
                    "filter": {
                      "type": "string",
                      "location": "query",
                      "description": "Optional. Filtering results."
                    },
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  },
  "version": "v1",
  "schemas": {
    "FetchResourceBackupConfigsResponse": {
      "id": "FetchResourceBackupConfigsResponse",
      "type": "object",
      "description": "Response for FetchResourceBackupConfigs.",
      "properties": {
        "resourceBackupConfigs": {
          "description": "The list of ResourceBackupConfigs for the specified scope.",
          "type": "array",
          "items": {
            "$ref": "ResourceBackupConfig"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      }
    },
    "FetchMsComplianceMetadataRequest": {
      "id": "FetchMsComplianceMetadataRequest",
      "type": "object",
      "properties": {
        "projectId": {
          "description": "Required. The project id of the target project",
          "type": "string"
        }
      },
      "description": "Request message for GetMsComplianceMetadata"
    },
    "SetIamPolicyRequest": {
      "properties": {
        "policy": {
          "description": "REQUIRED: The complete policy to be applied to the `resource`. The size of the policy is limited to a few 10s of KB. An empty policy is a valid policy but certain Google Cloud services (such as Projects) might reject them.",
          "$ref": "Policy"
        },
        "updateMask": {
          "type": "string",
          "description": "OPTIONAL: A FieldMask specifying which fields of the policy to modify. Only the fields in the mask will be modified. If no mask is provided, the following default mask is used: `paths: \"bindings, etag\"`",
          "format": "google-fieldmask"
        }
      },
      "description": "Request message for `SetIamPolicy` method.",
      "id": "SetIamPolicyRequest",
      "type": "object"
    },
    "FetchAccessTokenRequest": {
      "properties": {
        "generationId": {
          "description": "Required. The generation of the backup to update.",
          "format": "int32",
          "type": "integer"
        }
      },
      "description": "Request message for FetchAccessToken.",
      "id": "FetchAccessTokenRequest",
      "type": "object"
    },
    "AcceleratorConfig": {
      "description": "A specification of the type and number of accelerator cards attached to the instance.",
      "properties": {
        "acceleratorCount": {
          "type": "integer",
          "description": "Optional. The number of the guest accelerator cards exposed to this instance.",
          "format": "int32"
        },
        "acceleratorType": {
          "description": "Optional. Full or partial URL of the accelerator type resource to attach to this instance.",
          "type": "string"
        }
      },
      "id": "AcceleratorConfig",
      "type": "object"
    },
    "RemoveDataSourceRequest": {
      "id": "RemoveDataSourceRequest",
      "type": "object",
      "properties": {
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        }
      },
      "description": "Message for deleting a DataSource."
    },
    "FinalizeBackupRequest": {
      "id": "FinalizeBackupRequest",
      "type": "object",
      "description": "Message for finalizing a Backup.",
      "properties": {
        "recoveryRangeStartTime": {
          "type": "string",
          "description": "The earliest timestamp of data available in this Backup. This will set on the newly created Backup.",
          "format": "google-datetime"
        },
        "retentionDuration": {
          "type": "string",
          "description": "The ExpireTime on the backup will be set to FinalizeTime plus this duration. If the resulting ExpireTime is less than EnforcedRetentionEndTime, then ExpireTime is set to EnforcedRetentionEndTime.",
          "format": "google-duration"
        },
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        },
        "consistencyTime": {
          "type": "string",
          "description": "The point in time when this backup was captured from the source. This will be assigned to the consistency_time field of the newly created Backup.",
          "format": "google-datetime"
        },
        "description": {
          "description": "This will be assigned to the description field of the newly created Backup.",
          "type": "string"
        },
        "recoveryRangeEndTime": {
          "type": "string",
          "description": "The latest timestamp of data available in this Backup. This will be set on the newly created Backup.",
          "format": "google-datetime"
        },
        "backupId": {
          "description": "Required. Resource ID of the Backup resource to be finalized. This must be the same backup_id that was used in the InitiateBackupRequest.",
          "type": "string"
        }
      }
    },
    "Policy": {
      "id": "Policy",
      "type": "object",
      "description": "An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** ``` { \"bindings\": [ { \"role\": \"roles/resourcemanager.organizationAdmin\", \"members\": [ \"user:mike@example.com\", \"group:admins@example.com\", \"domain:google.com\", \"serviceAccount:my-project-id@appspot.gserviceaccount.com\" ] }, { \"role\": \"roles/resourcemanager.organizationViewer\", \"members\": [ \"user:eve@example.com\" ], \"condition\": { \"title\": \"expirable access\", \"description\": \"Does not grant access after Sep 2020\", \"expression\": \"request.time \u003c timestamp('2020-10-01T00:00:00.000Z')\", } } ], \"etag\": \"BwWWja0YfJA=\", \"version\": 3 } ``` **YAML example:** ``` bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time \u003c timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/).",
      "properties": {
        "auditConfigs": {
          "description": "Specifies cloud audit logging configuration for this policy.",
          "type": "array",
          "items": {
            "$ref": "AuditConfig"
          }
        },
        "version": {
          "description": "Specifies the format of the policy. Valid values are `0`, `1`, and `3`. Requests that specify an invalid value are rejected. Any operation that affects conditional role bindings must specify version `3`. This requirement applies to the following operations: * Getting a policy that includes a conditional role binding * Adding a conditional role binding to a policy * Changing a conditional role binding in a policy * Removing any role binding, with or without a condition, from a policy that includes conditions **Important:** If you use IAM Conditions, you must include the `etag` field whenever you call `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a version `3` policy with a version `1` policy, and all of the conditions in the version `3` policy are lost. If a policy does not include any conditions, operations on that policy may specify any valid version or leave the field unset. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).",
          "format": "int32",
          "type": "integer"
        },
        "etag": {
          "type": "string",
          "description": "`etag` is used for optimistic concurrency control as a way to help prevent simultaneous updates of a policy from overwriting each other. It is strongly suggested that systems make use of the `etag` in the read-modify-write cycle to perform policy updates in order to avoid race conditions: An `etag` is returned in the response to `getIamPolicy`, and systems are expected to put that etag in the request to `setIamPolicy` to ensure that their change will be applied to the same version of the policy. **Important:** If you use IAM Conditions, you must include the `etag` field whenever you call `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a version `3` policy with a version `1` policy, and all of the conditions in the version `3` policy are lost.",
          "format": "byte"
        },
        "bindings": {
          "type": "array",
          "items": {
            "$ref": "Binding"
          },
          "description": "Associates a list of `members`, or principals, with a `role`. Optionally, may specify a `condition` that determines how and when the `bindings` are applied. Each of the `bindings` must contain at least one principal. The `bindings` in a `Policy` can refer to up to 1,500 principals; up to 250 of these principals can be Google groups. Each occurrence of a principal counts towards these limits. For example, if the `bindings` grant 50 different roles to `user:alice@example.com`, and not to any other principal, then you can add another 1,450 principals to the `bindings` in the `Policy`."
        }
      }
    },
    "FilestoreInstanceDataSourceProperties": {
      "description": "FilestoreInstanceDataSourceProperties represents the properties of a Filestore resource that are stored in the DataSource. .",
      "properties": {
        "instanceCreateTime": {
          "description": "Output only. The instance creation timestamp.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "name": {
          "description": "Output only. Name of the Filestore instance backed up by the datasource.",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "FilestoreInstanceDataSourceProperties",
      "type": "object"
    },
    "TargetResource": {
      "id": "TargetResource",
      "type": "object",
      "properties": {
        "gcpResource": {
          "description": "Details of the native Google Cloud resource created as part of restore.",
          "$ref": "GcpResource"
        }
      },
      "description": "Details of the target resource created/modified as part of restore."
    },
    "ComputeInstanceRestoreProperties": {
      "properties": {
        "params": {
          "description": "Input only. Additional params passed with the request, but not persisted as part of resource payload.",
          "$ref": "InstanceParams"
        },
        "tags": {
          "description": "Optional. Tags to apply to this instance. Tags are used to identify valid sources or targets for network firewalls and are specified by the client during instance creation.",
          "$ref": "Tags"
        },
        "guestAccelerators": {
          "description": "Optional. A list of the type and count of accelerator cards attached to the instance.",
          "type": "array",
          "items": {
            "$ref": "AcceleratorConfig"
          }
        },
        "canIpForward": {
          "description": "Optional. Allows this instance to send and receive packets with non-matching destination or source IPs.",
          "type": "boolean"
        },
        "reservationAffinity": {
          "description": "Optional. Specifies the reservations that this instance can consume from.",
          "$ref": "AllocationAffinity"
        },
        "minCpuPlatform": {
          "description": "Optional. Minimum CPU platform to use for this instance.",
          "type": "string"
        },
        "machineType": {
          "description": "Optional. Full or partial URL of the machine type resource to use for this instance.",
          "type": "string"
        },
        "keyRevocationActionType": {
          "description": "Optional. KeyRevocationActionType of the instance.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Indicates user chose no operation.",
            "Indicates user chose to opt for VM shutdown on key revocation."
          ],
          "enum": [
            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
            "NONE",
            "STOP"
          ]
        },
        "advancedMachineFeatures": {
          "description": "Optional. Controls for advanced machine-related behavior features.",
          "$ref": "AdvancedMachineFeatures"
        },
        "labels": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Labels to apply to this instance."
        },
        "confidentialInstanceConfig": {
          "description": "Optional. Controls Confidential compute options on the instance",
          "$ref": "ConfidentialInstanceConfig"
        },
        "disks": {
          "description": "Optional. Array of disks associated with this instance. Persistent disks must be created before you can assign them. Source regional persistent disks will be restored with default replica zones if not specified.",
          "type": "array",
          "items": {
            "$ref": "AttachedDisk"
          }
        },
        "hostname": {
          "description": "Optional. Specifies the hostname of the instance. The specified hostname must be RFC1035 compliant. If hostname is not specified, the default hostname is [INSTANCE_NAME].c.[PROJECT_ID].internal when using the global DNS, and [INSTANCE_NAME].[ZONE].c.[PROJECT_ID].internal when using zonal DNS.",
          "type": "string"
        },
        "deletionProtection": {
          "description": "Optional. Whether the resource should be protected against deletion.",
          "type": "boolean"
        },
        "name": {
          "description": "Required. Name of the compute instance.",
          "type": "string"
        },
        "description": {
          "description": "Optional. An optional description of this resource. Provide this property when you create the resource.",
          "type": "string"
        },
        "instanceEncryptionKey": {
          "description": "Optional. Encrypts suspended data for an instance with a customer-managed encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "networkInterfaces": {
          "description": "Optional. An array of network configurations for this instance. These specify how interfaces are configured to interact with other network services, such as connecting to the internet. Multiple interfaces are supported per instance. Required to restore in different project or region.",
          "type": "array",
          "items": {
            "$ref": "NetworkInterface"
          }
        },
        "networkPerformanceConfig": {
          "description": "Optional. Configure network performance such as egress bandwidth tier.",
          "$ref": "NetworkPerformanceConfig"
        },
        "privateIpv6GoogleAccess": {
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Each network interface inherits PrivateIpv6GoogleAccess from its subnetwork.",
            "Outbound private IPv6 access from VMs in this subnet to Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before.",
            "Bidirectional private IPv6 access to/from Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before."
          ],
          "enum": [
            "INSTANCE_PRIVATE_IPV6_GOOGLE_ACCESS_UNSPECIFIED",
            "INHERIT_FROM_SUBNETWORK",
            "ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE",
            "ENABLE_BIDIRECTIONAL_ACCESS_TO_GOOGLE"
          ],
          "description": "Optional. The private IPv6 google access type for the VM. If not specified, use INHERIT_FROM_SUBNETWORK as default."
        },
        "resourcePolicies": {
          "description": "Optional. Resource policies applied to this instance. By default, no resource policies will be applied.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "metadata": {
          "description": "Optional. This includes custom metadata and predefined keys.",
          "$ref": "Metadata"
        },
        "displayDevice": {
          "description": "Optional. Enables display device for the instance.",
          "$ref": "DisplayDevice"
        },
        "serviceAccounts": {
          "description": "Optional. A list of service accounts, with their specified scopes, authorized for this instance. Only one service account per VM instance is supported.",
          "type": "array",
          "items": {
            "$ref": "ServiceAccount"
          }
        },
        "scheduling": {
          "description": "Optional. Sets the scheduling options for this instance.",
          "$ref": "Scheduling"
        }
      },
      "description": "ComputeInstanceRestoreProperties represents Compute Engine instance properties to be overridden during restore.",
      "id": "ComputeInstanceRestoreProperties",
      "type": "object"
    },
    "FetchBackupPlanAssociationsForResourceTypeResponse": {
      "id": "FetchBackupPlanAssociationsForResourceTypeResponse",
      "type": "object",
      "description": "Response for the FetchBackupPlanAssociationsForResourceType method.",
      "properties": {
        "backupPlanAssociations": {
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "BackupPlanAssociation"
          },
          "description": "Output only. The BackupPlanAssociations from the specified parent."
        },
        "nextPageToken": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        }
      }
    },
    "Binding": {
      "id": "Binding",
      "type": "object",
      "properties": {
        "role": {
          "description": "Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an overview of the IAM roles and permissions, see the [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For a list of the available pre-defined roles, see [here](https://cloud.google.com/iam/docs/understanding-roles).",
          "type": "string"
        },
        "members": {
          "description": "Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `alice@example.com` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `my-other-app@appspot.gserviceaccount.com`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `admins@example.com`. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. * `principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workforce identity pool. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`: All workforce identities in a group. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All workforce identities with a specific attribute value. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/*`: All identities in a workforce identity pool. * `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workload identity pool. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload identity pool group. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All identities in a workload identity pool with a certain attribute. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/*`: All identities in a workload identity pool. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `alice@example.com?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `admins@example.com?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "condition": {
          "description": "The condition that is associated with this binding. If the condition evaluates to `true`, then this binding applies to the current request. If the condition evaluates to `false`, then this binding does not apply to the current request. However, a different role binding might grant the same role to one or more of the principals in this binding. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).",
          "$ref": "Expr"
        }
      },
      "description": "Associates `members`, or principals, with a `role`."
    },
    "BackupConfigInfo": {
      "id": "BackupConfigInfo",
      "type": "object",
      "properties": {
        "backupApplianceBackupConfig": {
          "description": "Configuration for an application backed up by a Backup Appliance.",
          "$ref": "BackupApplianceBackupConfig"
        },
        "lastSuccessfulBackupConsistencyTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. If the last backup were successful, this field has the consistency date.",
          "format": "google-datetime"
        },
        "lastBackupState": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "Status not set.",
            "The first backup has not yet completed",
            "The most recent backup was successful",
            "The most recent backup failed",
            "The most recent backup could not be run/failed because of the lack of permissions"
          ],
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "SUCCEEDED",
            "FAILED",
            "PERMISSION_DENIED"
          ],
          "description": "Output only. The status of the last backup to this BackupVault"
        },
        "gcpBackupConfig": {
          "description": "Configuration for a Google Cloud resource.",
          "$ref": "GcpBackupConfig"
        },
        "lastBackupError": {
          "description": "Output only. If the last backup failed, this field has the error message.",
          "readOnly": true,
          "$ref": "Status"
        }
      },
      "description": "BackupConfigInfo has information about how the resource is configured for Backup and about the most recent backup to this vault."
    },
    "CloudSqlInstanceInitializationConfig": {
      "properties": {
        "edition": {
          "description": "Required. The edition of the Cloud SQL instance.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified edition.",
            "Enterprise edition.",
            "Enterprise Plus edition."
          ],
          "enum": [
            "EDITION_UNSPECIFIED",
            "ENTERPRISE",
            "ENTERPRISE_PLUS"
          ]
        }
      },
      "description": "CloudSqlInstanceInitializationConfig contains the configuration for initializing a Cloud SQL instance.",
      "id": "CloudSqlInstanceInitializationConfig",
      "type": "object"
    },
    "ComputeInstanceDataSourceProperties": {
      "id": "ComputeInstanceDataSourceProperties",
      "type": "object",
      "description": "ComputeInstanceDataSourceProperties represents the properties of a ComputeEngine resource that are stored in the DataSource.",
      "properties": {
        "name": {
          "description": "Name of the compute instance backed up by the datasource.",
          "type": "string"
        },
        "description": {
          "description": "The description of the Compute Engine instance.",
          "type": "string"
        },
        "totalDiskSizeGb": {
          "type": "string",
          "description": "The sum of all the disk sizes.",
          "format": "int64"
        },
        "machineType": {
          "description": "The machine type of the instance.",
          "type": "string"
        },
        "totalDiskCount": {
          "type": "string",
          "description": "The total number of disks attached to the Instance.",
          "format": "int64"
        }
      }
    },
    "FilestoreInstanceBackupPlanAssociationProperties": {
      "id": "FilestoreInstanceBackupPlanAssociationProperties",
      "type": "object",
      "properties": {
        "instanceCreateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime"
        }
      },
      "description": "Filestore instance's BPA properties."
    },
    "ListLocationsResponse": {
      "id": "ListLocationsResponse",
      "type": "object",
      "description": "The response message for Locations.ListLocations.",
      "properties": {
        "locations": {
          "type": "array",
          "items": {
            "$ref": "Location"
          },
          "description": "A list of locations that matches the specified filter in the request."
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        }
      }
    },
    "AlloyDBClusterBackupPlanAssociationProperties": {
      "properties": {
        "clusterUid": {
          "description": "Output only. The cluster UID of the AlloyDB cluster.",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "Properties for an AlloyDB cluster backup plan association.",
      "id": "AlloyDBClusterBackupPlanAssociationProperties",
      "type": "object"
    },
    "NodeAffinity": {
      "description": "Node Affinity: the configuration of desired nodes onto which this Instance could be scheduled.",
      "properties": {
        "values": {
          "description": "Optional. Corresponds to the label values of Node resource.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "key": {
          "description": "Optional. Corresponds to the label key of Node resource.",
          "type": "string"
        },
        "operator": {
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Requires Compute Engine to seek for matched nodes.",
            "Requires Compute Engine to avoid certain nodes."
          ],
          "enum": [
            "OPERATOR_UNSPECIFIED",
            "IN",
            "NOT_IN"
          ],
          "description": "Optional. Defines the operation of node selection."
        }
      },
      "id": "NodeAffinity",
      "type": "object"
    },
    "BackupApplianceBackupProperties": {
      "id": "BackupApplianceBackupProperties",
      "type": "object",
      "properties": {
        "generationId": {
          "description": "Output only. The numeric generation ID of the backup (monotonically increasing).",
          "format": "int32",
          "readOnly": true,
          "type": "integer"
        },
        "recoveryRangeStartTime": {
          "type": "string",
          "description": "Optional. The earliest timestamp of data available in this Backup.",
          "format": "google-datetime"
        },
        "finalizeTime": {
          "description": "Output only. The time when this backup object was finalized (if none, backup is not finalized).",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "recoveryRangeEndTime": {
          "type": "string",
          "description": "Optional. The latest timestamp of data available in this Backup.",
          "format": "google-datetime"
        }
      },
      "description": "BackupApplianceBackupProperties represents BackupDR backup appliance's properties."
    },
    "BackupDrTemplateConfig": {
      "id": "BackupDrTemplateConfig",
      "type": "object",
      "description": "Provides additional information about Google Cloud Backup and DR's Template backup configuration.",
      "properties": {
        "firstPartyManagementUri": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The URI of the BackupDr template resource for the first party identity users."
        },
        "thirdPartyManagementUri": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The URI of the BackupDr template resource for the third party identity users."
        }
      }
    },
    "ServiceAccount": {
      "id": "ServiceAccount",
      "type": "object",
      "description": "A service account.",
      "properties": {
        "email": {
          "description": "Optional. Email address of the service account.",
          "type": "string"
        },
        "scopes": {
          "description": "Optional. The list of scopes to be made available for this service account.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "Backup": {
      "description": "Message describing a Backup object.",
      "properties": {
        "kmsKeyVersions": {
          "description": "Optional. Output only. The list of KMS key versions used to encrypt the backup.",
          "readOnly": true,
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "serviceLocks": {
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "BackupLock"
          },
          "description": "Output only. The list of BackupLocks taken by the service to prevent the deletion of the backup."
        },
        "backupType": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "Backup type is unspecified.",
            "Scheduled backup.",
            "On demand backup.",
            "Operational backup."
          ],
          "enum": [
            "BACKUP_TYPE_UNSPECIFIED",
            "SCHEDULED",
            "ON_DEMAND",
            "ON_DEMAND_OPERATIONAL"
          ],
          "description": "Output only. Type of the backup, unspecified, scheduled or ondemand."
        },
        "labels": {
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined.",
          "additionalProperties": {
            "type": "string"
          },
          "type": "object"
        },
        "filestoreInstanceBackupProperties": {
          "readOnly": true,
          "$ref": "FilestoreInstanceBackupProperties",
          "description": "Output only. Filestore specific backup properties."
        },
        "backupApplianceBackupProperties": {
          "description": "Output only. Backup Appliance specific backup properties.",
          "readOnly": true,
          "$ref": "BackupApplianceBackupProperties"
        },
        "gcpBackupPlanInfo": {
          "description": "Output only. Configuration for a Google Cloud resource.",
          "readOnly": true,
          "$ref": "GCPBackupPlanInfo"
        },
        "createTime": {
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "satisfiesPzi": {
          "description": "Optional. Output only. Reserved for future use.",
          "readOnly": true,
          "type": "boolean"
        },
        "diskBackupProperties": {
          "description": "Output only. Disk specific backup properties.",
          "readOnly": true,
          "$ref": "DiskBackupProperties"
        },
        "satisfiesPzs": {
          "description": "Optional. Output only. Reserved for future use.",
          "readOnly": true,
          "type": "boolean"
        },
        "computeInstanceBackupProperties": {
          "readOnly": true,
          "$ref": "ComputeInstanceBackupProperties",
          "description": "Output only. Compute Engine specific backup properties."
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "enforcedRetentionEndTime": {
          "type": "string",
          "description": "Optional. The backup can not be deleted before this time.",
          "format": "google-datetime"
        },
        "expireTime": {
          "description": "Optional. When this backup is automatically expired.",
          "format": "google-datetime",
          "type": "string"
        },
        "consistencyTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The point in time when this backup was captured from the source.",
          "format": "google-datetime"
        },
        "backupRetentionInheritance": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "Inheritance behavior not set. This will default to `INHERIT_VAULT_RETENTION`.",
            "The enforced retention end time of a backup will be inherited from the backup vault's `backup_minimum_enforced_retention_duration` field. This is the default behavior.",
            "The enforced retention end time of a backup will always match the expire time of the backup. If this is set, the backup's enforced retention end time will be set to match the expire time during creation of the backup. When updating, the ERET and expire time must be updated together and have the same value. Invalid update requests will be rejected by the server."
          ],
          "enum": [
            "BACKUP_RETENTION_INHERITANCE_UNSPECIFIED",
            "INHERIT_VAULT_RETENTION",
            "MATCH_BACKUP_EXPIRE_TIME"
          ],
          "description": "Output only. Setting for how the enforced retention end time is inherited. This value is copied from this backup's BackupVault."
        },
        "backupApplianceLocks": {
          "type": "array",
          "items": {
            "$ref": "BackupLock"
          },
          "description": "Optional. The list of BackupLocks taken by the accessor Backup Appliance."
        },
        "gcpResource": {
          "readOnly": true,
          "$ref": "BackupGcpResource",
          "description": "Output only. Unique identifier of the GCP resource that is being backed up."
        },
        "etag": {
          "description": "Optional. Server specified ETag to prevent updates from overwriting each other.",
          "type": "string"
        },
        "state": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "State not set.",
            "The backup is being created.",
            "The backup has been created and is fully usable.",
            "The backup is being deleted.",
            "The backup is experiencing an issue and might be unusable.",
            "The backup is being uploaded."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR",
            "UPLOADING"
          ],
          "description": "Output only. The Backup resource instance state."
        },
        "alloyDbBackupProperties": {
          "readOnly": true,
          "$ref": "AlloyDbClusterBackupProperties",
          "description": "Output only. AlloyDB specific backup properties."
        },
        "resourceSizeBytes": {
          "description": "Output only. source resource size in bytes at the time of the backup.",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        },
        "cloudSqlInstanceBackupProperties": {
          "readOnly": true,
          "$ref": "CloudSqlInstanceBackupProperties",
          "description": "Output only. Cloud SQL specific backup properties."
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Identifier. Name of the backup to create. It must have the format`\"projects//locations//backupVaults//dataSources/{datasource}/backups/{backup}\"`. `{backup}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the datasource."
        },
        "description": {
          "description": "Output only. The description of the Backup instance (2048 characters or less).",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "Backup",
      "type": "object"
    },
    "ListBackupsResponse": {
      "id": "ListBackupsResponse",
      "type": "object",
      "properties": {
        "backups": {
          "description": "The list of Backup instances in the project for the specified location. If the '{location}' value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return data sources in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations.",
          "type": "array",
          "items": {
            "$ref": "Backup"
          }
        },
        "unreachable": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached."
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "description": "Response message for listing Backups."
    },
    "ListBackupPlanAssociationsResponse": {
      "id": "ListBackupPlanAssociationsResponse",
      "type": "object",
      "properties": {
        "unreachable": {
          "description": "Locations that could not be reached.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "backupPlanAssociations": {
          "description": "The list of Backup Plan Associations in the project for the specified location. If the `{location}` value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return backup plan associations in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations.",
          "type": "array",
          "items": {
            "$ref": "BackupPlanAssociation"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "description": "Response message for List BackupPlanAssociation"
    },
    "AlloyDBClusterDataSourceProperties": {
      "id": "AlloyDBClusterDataSourceProperties",
      "type": "object",
      "properties": {
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the AlloyDB cluster backed up by the datasource."
        },
        "pitrWindows": {
          "description": "Output only. Point in time recovery windows. The order is guaranteed to be ascending by start time.",
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "AlloyDbPitrWindow"
          }
        },
        "clusterUid": {
          "description": "Output only. The cluster UID of the AlloyDB cluster backed up by the datasource.",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "AlloyDBClusterDataSourceProperties represents the properties of a AlloyDB cluster resource that are stored in the DataSource. ."
    },
    "Status": {
      "id": "Status",
      "type": "object",
      "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
      "properties": {
        "details": {
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "type": "array",
          "items": {
            "type": "object",
            "additionalProperties": {
              "type": "any",
              "description": "Properties of the object. Contains field @type with type URL."
            }
          }
        },
        "message": {
          "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.",
          "type": "string"
        },
        "code": {
          "type": "integer",
          "description": "The status code, which should be an enum value of google.rpc.Code.",
          "format": "int32"
        }
      }
    },
    "AuditConfig": {
      "description": "Specifies the audit configuration for a service. The configuration determines which permission types are logged, and what identities, if any, are exempted from logging. An AuditConfig must have one or more AuditLogConfigs. If there are AuditConfigs for both `allServices` and a specific service, the union of the two AuditConfigs is used for that service: the log_types specified in each AuditConfig are enabled, and the exempted_members in each AuditLogConfig are exempted. Example Policy with multiple AuditConfigs: { \"audit_configs\": [ { \"service\": \"allServices\", \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\", \"exempted_members\": [ \"user:jose@example.com\" ] }, { \"log_type\": \"DATA_WRITE\" }, { \"log_type\": \"ADMIN_READ\" } ] }, { \"service\": \"sampleservice.googleapis.com\", \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\" }, { \"log_type\": \"DATA_WRITE\", \"exempted_members\": [ \"user:aliya@example.com\" ] } ] } ] } For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ logging. It also exempts `jose@example.com` from DATA_READ logging, and `aliya@example.com` from DATA_WRITE logging.",
      "properties": {
        "auditLogConfigs": {
          "type": "array",
          "items": {
            "$ref": "AuditLogConfig"
          },
          "description": "The configuration for logging of each type of permission."
        },
        "service": {
          "description": "Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.",
          "type": "string"
        }
      },
      "id": "AuditConfig",
      "type": "object"
    },
    "CloudSqlInstanceBackupProperties": {
      "id": "CloudSqlInstanceBackupProperties",
      "type": "object",
      "properties": {
        "sourceInstance": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The source instance of the backup. Format: projects/{project}/instances/{instance}"
        },
        "instanceDeleteTime": {
          "description": "Output only. The instance delete timestamp.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "databaseInstalledVersion": {
          "description": "Output only. The installed database version of the Cloud SQL instance when the backup was taken.",
          "readOnly": true,
          "type": "string"
        },
        "instanceCreateTime": {
          "description": "Output only. The instance creation timestamp.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "finalBackup": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Whether the backup is a final backup."
        },
        "instanceTier": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The tier (or machine type) for this instance. Example: `db-custom-1-3840`"
        }
      },
      "description": "CloudSqlInstanceBackupProperties represents Cloud SQL Instance Backup properties."
    },
    "ListBackupPlansResponse": {
      "properties": {
        "backupPlans": {
          "type": "array",
          "items": {
            "$ref": "BackupPlan"
          },
          "description": "The list of `BackupPlans` in the project for the specified location. If the `{location}` value in the request is \"-\", the response contains a list of resources from all locations. In case any location is unreachable, the response will only return backup plans in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations. BackupPlan"
        },
        "unreachable": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached."
        },
        "nextPageToken": {
          "description": "A token which may be sent as page_token in a subsequent `ListBackupPlans` call to retrieve the next page of results. If this field is omitted or empty, then there are no more results to return.",
          "type": "string"
        }
      },
      "description": "The response message for getting a list of `BackupPlan`.",
      "id": "ListBackupPlansResponse",
      "type": "object"
    },
    "ListManagementServersResponse": {
      "id": "ListManagementServersResponse",
      "type": "object",
      "description": "Response message for listing management servers.",
      "properties": {
        "unreachable": {
          "description": "Locations that could not be reached.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        },
        "managementServers": {
          "type": "array",
          "items": {
            "$ref": "ManagementServer"
          },
          "description": "The list of ManagementServer instances in the project for the specified location. If the '{location}' value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return management servers in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations."
        }
      }
    },
    "AbandonBackupRequest": {
      "id": "AbandonBackupRequest",
      "type": "object",
      "properties": {
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        }
      },
      "description": "request message for AbandonBackup."
    },
    "TestIamPermissionsRequest": {
      "properties": {
        "permissions": {
          "description": "The set of permissions to check for the `resource`. Permissions with wildcards (such as `*` or `storage.*`) are not allowed. For more information see [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions).",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "description": "Request message for `TestIamPermissions` method.",
      "id": "TestIamPermissionsRequest",
      "type": "object"
    },
    "Location": {
      "id": "Location",
      "type": "object",
      "properties": {
        "displayName": {
          "description": "The friendly name for this location, typically a nearby city name. For example, \"Tokyo\".",
          "type": "string"
        },
        "name": {
          "description": "Resource name for the location, which may vary between implementations. For example: `\"projects/example-project/locations/us-east1\"`",
          "type": "string"
        },
        "locationId": {
          "description": "The canonical id for this location. For example: `\"us-east1\"`.",
          "type": "string"
        },
        "metadata": {
          "description": "Service-specific metadata. For example the available capacity at the given location.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "labels": {
          "description": "Cross-service attributes for the location. For example {\"cloud.googleapis.com/region\": \"us-east1\"}",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        }
      },
      "description": "A resource that represents a Google Cloud location."
    },
    "CloudSqlInstanceDataSourceReferenceProperties": {
      "id": "CloudSqlInstanceDataSourceReferenceProperties",
      "type": "object",
      "description": "CloudSqlInstanceDataSourceReferenceProperties represents the properties of a Cloud SQL resource that are stored in the DataSourceReference.",
      "properties": {
        "databaseInstalledVersion": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The installed database version of the Cloud SQL instance."
        },
        "instanceCreateTime": {
          "description": "Output only. The instance creation timestamp.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "instanceTier": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The tier (or machine type) for this instance. Example: `db-custom-1-3840`"
        },
        "name": {
          "description": "Output only. Name of the Cloud SQL instance backed up by the datasource. Format: projects/{project}/instances/{instance}",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "ConfidentialInstanceConfig": {
      "properties": {
        "enableConfidentialCompute": {
          "description": "Optional. Defines whether the instance should have confidential compute enabled.",
          "type": "boolean"
        }
      },
      "description": "A set of Confidential Instance options.",
      "id": "ConfidentialInstanceConfig",
      "type": "object"
    },
    "CloudSqlInstanceBackupPlanAssociationProperties": {
      "id": "CloudSqlInstanceBackupPlanAssociationProperties",
      "type": "object",
      "description": "Cloud SQL instance's BPA properties.",
      "properties": {
        "instanceCreateTime": {
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "FilestoreInstanceBackupProperties": {
      "id": "FilestoreInstanceBackupProperties",
      "type": "object",
      "properties": {
        "sourceInstance": {
          "description": "Output only. The source instance of the backup.",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "FilestoreInstanceBackupProperties represents the properties of a Filestore instance that are backed up by the datasource. ."
    },
    "BackupGcpResource": {
      "id": "BackupGcpResource",
      "type": "object",
      "properties": {
        "gcpResourcename": {
          "description": "Name of the Google Cloud resource.",
          "type": "string"
        },
        "location": {
          "description": "Location of the resource: //\"global\"/\"unspecified\".",
          "type": "string"
        },
        "type": {
          "description": "Type of the resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance.",
          "type": "string"
        }
      },
      "description": "Minimum details to identify a Google Cloud resource for a backup."
    },
    "AccessConfig": {
      "properties": {
        "name": {
          "description": "Optional. The name of this access configuration.",
          "type": "string"
        },
        "natIP": {
          "description": "Optional. The external IP address of this access configuration.",
          "type": "string"
        },
        "networkTier": {
          "description": "Optional. This signifies the networking tier used for configuring this access",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "High quality, Google-grade network tier, support for all networking products.",
            "Public internet quality, only limited support for other networking products."
          ],
          "enum": [
            "NETWORK_TIER_UNSPECIFIED",
            "PREMIUM",
            "STANDARD"
          ]
        },
        "setPublicPtr": {
          "description": "Optional. Specifies whether a public DNS 'PTR' record should be created to map the external IP address of the instance to a DNS domain name.",
          "type": "boolean"
        },
        "type": {
          "description": "Optional. In accessConfigs (IPv4), the default and only option is ONE_TO_ONE_NAT. In ipv6AccessConfigs, the default and only option is DIRECT_IPV6.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "ONE_TO_ONE_NAT",
            "Direct IPv6 access."
          ],
          "enum": [
            "ACCESS_TYPE_UNSPECIFIED",
            "ONE_TO_ONE_NAT",
            "DIRECT_IPV6"
          ]
        },
        "externalIpv6": {
          "description": "Optional. The external IPv6 address of this access configuration.",
          "type": "string"
        },
        "publicPtrDomainName": {
          "description": "Optional. The DNS domain name for the public PTR record.",
          "type": "string"
        },
        "externalIpv6PrefixLength": {
          "type": "integer",
          "description": "Optional. The prefix length of the external IPv6 range.",
          "format": "int32"
        }
      },
      "description": "An access configuration attached to an instance's network interface. Only one access config per instance is supported.",
      "id": "AccessConfig",
      "type": "object"
    },
    "Entry": {
      "id": "Entry",
      "type": "object",
      "description": "A key/value pair to be used for storing metadata.",
      "properties": {
        "key": {
          "description": "Optional. Key for the metadata entry.",
          "type": "string"
        },
        "value": {
          "description": "Optional. Value for the metadata entry. These are free-form strings, and only have meaning as interpreted by the image running in the instance. The only restriction placed on values is that their size must be less than or equal to 262144 bytes (256 KiB).",
          "type": "string"
        }
      }
    },
    "FilestoreInstanceDataSourceReferenceProperties": {
      "description": "FilestoreInstanceDataSourceReferenceProperties represents the properties of a Filestore resource that are stored in the DataSourceReference. .",
      "properties": {
        "instanceCreateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The instance creation timestamp.",
          "format": "google-datetime"
        },
        "name": {
          "description": "Output only. Name of the Filestore instance backed up by the datasource. Format: projects/{project}/instances/{instance}",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "FilestoreInstanceDataSourceReferenceProperties",
      "type": "object"
    },
    "AlloyDBClusterDataSourceReferenceProperties": {
      "id": "AlloyDBClusterDataSourceReferenceProperties",
      "type": "object",
      "properties": {
        "name": {
          "description": "Output only. Name of the AlloyDB cluster backed up by the datasource. Format: projects/{project}/locations/{location}/clusters/{cluster}",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "AlloyDBClusterDataSourceReferenceProperties represents the properties of an AlloyDB cluster that are stored in the DataSourceReference."
    },
    "LocationMetadata": {
      "properties": {
        "unsupportedFeatures": {
          "type": "array",
          "items": {
            "type": "string",
            "enumDescriptions": [
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "Remove once parity achieved between BV_AF and BV_CUSTOM_PROBERS.",
              ""
            ],
            "enum": [
              "FEATURE_UNSPECIFIED",
              "MANAGEMENT_SERVER",
              "COMPUTE_INSTANCE",
              "PROTECTION_SUMMARY",
              "DISK",
              "CLOUD_SQL",
              "ALLOY_DB",
              "FILESTORE",
              "BV_AF",
              "CEP_MONITORING_COMPUTE_INSTANCE",
              "CEP_MONITORING_DISK",
              "BV_CUSTOM_PROBERS",
              "FT_CUSTOM_PROBERS"
            ]
          },
          "description": "List of features that are not supported in the location."
        }
      },
      "id": "LocationMetadata",
      "type": "object"
    },
    "Tags": {
      "id": "Tags",
      "type": "object",
      "properties": {
        "items": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Optional. An array of tags. Each tag must be 1-63 characters long, and comply with RFC1035."
        }
      },
      "description": "A set of instance tags."
    },
    "WorkforceIdentityBasedManagementURI": {
      "id": "WorkforceIdentityBasedManagementURI",
      "type": "object",
      "description": "ManagementURI depending on the Workforce Identity i.e. either 1p or 3p.",
      "properties": {
        "thirdPartyManagementUri": {
          "description": "Output only. Third party Management URI for External Identity Providers.",
          "readOnly": true,
          "type": "string"
        },
        "firstPartyManagementUri": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. First party Management URI for Google Identities."
        }
      }
    },
    "InitiateBackupRequest": {
      "id": "InitiateBackupRequest",
      "type": "object",
      "description": "request message for InitiateBackup.",
      "properties": {
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        },
        "backupId": {
          "description": "Required. Resource ID of the Backup resource.",
          "type": "string"
        }
      }
    },
    "BackupPlanAssociation": {
      "properties": {
        "resourceType": {
          "description": "Required. Immutable. Resource type of workload on which backupplan is applied",
          "type": "string"
        },
        "filestoreInstanceBackupPlanAssociationProperties": {
          "readOnly": true,
          "$ref": "FilestoreInstanceBackupPlanAssociationProperties",
          "description": "Output only. Filestore instance's backup plan association properties."
        },
        "backupPlan": {
          "description": "Required. Resource name of backup plan which needs to be applied on workload. Format: projects/{project}/locations/{location}/backupPlans/{backupPlanId}",
          "type": "string"
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "backupPlanRevisionId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc."
        },
        "alloydbClusterBackupPlanAssociationProperties": {
          "readOnly": true,
          "$ref": "AlloyDBClusterBackupPlanAssociationProperties",
          "description": "Output only. AlloyDB cluster's backup plan association properties."
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Identifier. The resource name of BackupPlanAssociation in below format Format : projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}"
        },
        "backupPlanRevisionName": {
          "description": "Output only. The resource id of the `BackupPlanRevision`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}/revisions/{revision_id}`",
          "readOnly": true,
          "type": "string"
        },
        "resource": {
          "description": "Required. Immutable. Resource name of workload on which the backup plan is applied. The format can either be the resource name (e.g., \"projects/my-project/zones/us-central1-a/instances/my-instance\") or the full resource URI (e.g., \"https://www.googleapis.com/compute/v1/projects/my-project/zones/us-central1-a/instances/my-instance\").",
          "type": "string"
        },
        "cloudSqlInstanceBackupPlanAssociationProperties": {
          "description": "Output only. Cloud SQL instance's backup plan association properties.",
          "readOnly": true,
          "$ref": "CloudSqlInstanceBackupPlanAssociationProperties"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime"
        },
        "dataSource": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Resource name of data source which will be used as storage location for backups taken. Format : projects/{project}/locations/{location}/backupVaults/{backupvault}/dataSources/{datasource}"
        },
        "rulesConfigInfo": {
          "description": "Output only. The config info related to backup rules.",
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "RuleConfigInfo"
          }
        },
        "state": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "State not set.",
            "The resource is being created.",
            "The resource has been created and is fully usable.",
            "The resource is being deleted.",
            "The resource has been created but is not usable.",
            "The resource is being updated."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE",
            "UPDATING"
          ],
          "description": "Output only. The BackupPlanAssociation resource state."
        }
      },
      "description": "A BackupPlanAssociation represents a single BackupPlanAssociation which contains details like workload, backup plan etc",
      "id": "BackupPlanAssociation",
      "type": "object"
    },
    "DataSourceGcpResourceInfo": {
      "description": "The Google Cloud resource that the DataSource is associated with.",
      "properties": {
        "cloudSqlInstanceProperties": {
          "readOnly": true,
          "$ref": "CloudSqlInstanceDataSourceReferenceProperties",
          "description": "Output only. The properties of the Cloud SQL instance."
        },
        "filestoreInstanceProperties": {
          "description": "Output only. The properties of the Filestore instance.",
          "readOnly": true,
          "$ref": "FilestoreInstanceDataSourceReferenceProperties"
        },
        "gcpResourcename": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The resource name of the Google Cloud resource. Ex: projects/{project}/zones/{zone}/instances/{instance}"
        },
        "type": {
          "description": "Output only. The type of the Google Cloud resource. Ex: compute.googleapis.com/Instance",
          "readOnly": true,
          "type": "string"
        },
        "location": {
          "description": "Output only. The location of the Google Cloud resource. Ex: //\"global\"/\"unspecified\"",
          "readOnly": true,
          "type": "string"
        },
        "alloyDbClusterProperties": {
          "description": "Output only. The properties of the AlloyDB cluster.",
          "readOnly": true,
          "$ref": "AlloyDBClusterDataSourceReferenceProperties"
        }
      },
      "id": "DataSourceGcpResourceInfo",
      "type": "object"
    },
    "AlloyDbClusterBackupProperties": {
      "id": "AlloyDbClusterBackupProperties",
      "type": "object",
      "description": "AlloyDbClusterBackupProperties represents AlloyDB cluster backup properties. .",
      "properties": {
        "chainId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The chain id of this backup. Backups belonging to the same chain are sharing the same chain id. This property is calculated and maintained by BackupDR."
        },
        "databaseVersion": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The PostgreSQL major version of the AlloyDB cluster when the backup was taken."
        },
        "description": {
          "description": "An optional text description for the backup.",
          "type": "string"
        },
        "storedBytes": {
          "description": "Output only. Storage usage of this particular backup",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "BackupWindow": {
      "id": "BackupWindow",
      "type": "object",
      "properties": {
        "startHourOfDay": {
          "type": "integer",
          "description": "Required. The hour of day (0-23) when the window starts for example if value of start hour of day is 6 that mean backup window start at 6:00.",
          "format": "int32"
        },
        "endHourOfDay": {
          "type": "integer",
          "description": "Required. The hour of day (1-24) when the window end for example if value of end hour of day is 10 that mean backup window end time is 10:00. End hour of day should be greater than start hour of day. 0 \u003c= start_hour_of_day \u003c end_hour_of_day \u003c= 24 End hour of day is not include in backup window that mean if end_hour_of_day= 10 jobs should start before 10:00.",
          "format": "int32"
        }
      },
      "description": "`BackupWindow` defines a window of the day during which backup jobs will run."
    },
    "Expr": {
      "id": "Expr",
      "type": "object",
      "description": "Represents a textual expression in the Common Expression Language (CEL) syntax. CEL is a C-like expression language. The syntax and semantics of CEL are documented at https://github.com/google/cel-spec. Example (Comparison): title: \"Summary size limit\" description: \"Determines if a summary is less than 100 chars\" expression: \"document.summary.size() \u003c 100\" Example (Equality): title: \"Requestor is owner\" description: \"Determines if requestor is the document owner\" expression: \"document.owner == request.auth.claims.email\" Example (Logic): title: \"Public documents\" description: \"Determine whether the document should be publicly visible\" expression: \"document.type != 'private' && document.type != 'internal'\" Example (Data Manipulation): title: \"Notification string\" description: \"Create a notification string with a timestamp.\" expression: \"'New message received at ' + string(document.create_time)\" The exact variables and functions that may be referenced within an expression are determined by the service that evaluates it. See the service documentation for additional information.",
      "properties": {
        "expression": {
          "description": "Textual representation of an expression in Common Expression Language syntax.",
          "type": "string"
        },
        "title": {
          "description": "Optional. Title for the expression, i.e. a short string describing its purpose. This can be used e.g. in UIs which allow to enter the expression.",
          "type": "string"
        },
        "description": {
          "description": "Optional. Description of the expression. This is a longer text which describes the expression, e.g. when hovered over it in a UI.",
          "type": "string"
        },
        "location": {
          "description": "Optional. String indicating the location of the expression for error reporting, e.g. a file name and a position in the file.",
          "type": "string"
        }
      }
    },
    "ComputeInstanceBackupProperties": {
      "id": "ComputeInstanceBackupProperties",
      "type": "object",
      "description": "ComputeInstanceBackupProperties represents Compute Engine instance backup properties.",
      "properties": {
        "guestAccelerator": {
          "type": "array",
          "items": {
            "$ref": "AcceleratorConfig"
          },
          "description": "A list of guest accelerator cards' type and count to use for instances created from these properties."
        },
        "disk": {
          "type": "array",
          "items": {
            "$ref": "AttachedDisk"
          },
          "description": "An array of disks that are associated with the instances that are created from these properties."
        },
        "tags": {
          "description": "A list of tags to apply to the instances that are created from these properties. The tags identify valid sources or targets for network firewalls. The setTags method can modify this list of tags. Each tag within the list must comply with RFC1035 (https://www.ietf.org/rfc/rfc1035.txt).",
          "$ref": "Tags"
        },
        "networkInterface": {
          "type": "array",
          "items": {
            "$ref": "NetworkInterface"
          },
          "description": "An array of network access configurations for this interface."
        },
        "canIpForward": {
          "description": "Enables instances created based on these properties to send packets with source IP addresses other than their own and receive packets with destination IP addresses other than their own. If these instances will be used as an IP gateway or it will be set as the next-hop in a Route resource, specify `true`. If unsure, leave this set to `false`. See the https://cloud.google.com/vpc/docs/using-routes#canipforward documentation for more information.",
          "type": "boolean"
        },
        "minCpuPlatform": {
          "description": "Minimum cpu/platform to be used by instances. The instance may be scheduled on the specified or newer cpu/platform. Applicable values are the friendly names of CPU platforms, such as `minCpuPlatform: Intel Haswell` or `minCpuPlatform: Intel Sandy Bridge`. For more information, read https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform.",
          "type": "string"
        },
        "description": {
          "description": "An optional text description for the instances that are created from these properties.",
          "type": "string"
        },
        "machineType": {
          "description": "The machine type to use for instances that are created from these properties.",
          "type": "string"
        },
        "keyRevocationActionType": {
          "description": "KeyRevocationActionType of the instance. Supported options are \"STOP\" and \"NONE\". The default value is \"NONE\" if it is not specified.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Indicates user chose no operation.",
            "Indicates user chose to opt for VM shutdown on key revocation."
          ],
          "enum": [
            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
            "NONE",
            "STOP"
          ]
        },
        "serviceAccount": {
          "type": "array",
          "items": {
            "$ref": "ServiceAccount"
          },
          "description": "A list of service accounts with specified scopes. Access tokens for these service accounts are available to the instances that are created from these properties. Use metadata queries to obtain the access tokens for these instances."
        },
        "metadata": {
          "description": "The metadata key/value pairs to assign to instances that are created from these properties. These pairs can consist of custom metadata or predefined keys. See https://cloud.google.com/compute/docs/metadata/overview for more information.",
          "$ref": "Metadata"
        },
        "sourceInstance": {
          "description": "The source instance used to create this backup. This can be a partial or full URL to the resource. For example, the following are valid values: -https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/instance -projects/project/zones/zone/instances/instance",
          "type": "string"
        },
        "guestFlush": {
          "description": "Optional. Indicates whether to perform a guest flush operation before taking a compute backup. When set to false, the system will create crash-consistent backups. Default value is false.",
          "type": "boolean"
        },
        "scheduling": {
          "description": "Specifies the scheduling options for the instances that are created from these properties.",
          "$ref": "Scheduling"
        },
        "labels": {
          "description": "Labels to apply to instances that are created from these properties.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        }
      }
    },
    "DiskRestoreProperties": {
      "id": "DiskRestoreProperties",
      "type": "object",
      "properties": {
        "provisionedThroughput": {
          "type": "string",
          "description": "Optional. Indicates how much throughput to provision for the disk. This sets the number of throughput MB per second that the disk can handle.",
          "format": "int64"
        },
        "resourceManagerTags": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Resource manager tags to be bound to the disk."
        },
        "name": {
          "description": "Required. Name of the disk.",
          "type": "string"
        },
        "description": {
          "description": "Optional. An optional description of this resource. Provide this property when you create the resource.",
          "type": "string"
        },
        "diskEncryptionKey": {
          "description": "Optional. Encrypts the disk using a customer-supplied encryption key or a customer-managed encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "provisionedIops": {
          "description": "Optional. Indicates how many IOPS to provision for the disk. This sets the number of I/O operations per second that the disk can handle.",
          "format": "int64",
          "type": "string"
        },
        "licenses": {
          "description": "Optional. A list of publicly available licenses that are applicable to this backup. This is applicable if the original image had licenses attached, e.g. Windows image",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "storagePool": {
          "description": "Optional. The storage pool in which the new disk is created. You can provide this as a partial or full URL to the resource.",
          "type": "string"
        },
        "architecture": {
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Disks with architecture X86_64",
            "Disks with architecture ARM64"
          ],
          "enum": [
            "ARCHITECTURE_UNSPECIFIED",
            "X86_64",
            "ARM64"
          ],
          "description": "Optional. The architecture of the source disk. Valid values are ARM64 or X86_64."
        },
        "accessMode": {
          "description": "Optional. The access mode of the disk.",
          "type": "string",
          "enumDescriptions": [
            "The default AccessMode, means the disk can be attached to single instance in RW mode.",
            "The AccessMode means the disk can be attached to multiple instances in RW mode.",
            "The AccessMode means the disk can be attached to multiple instances in RO mode."
          ],
          "enum": [
            "READ_WRITE_SINGLE",
            "READ_WRITE_MANY",
            "READ_ONLY_MANY"
          ]
        },
        "enableConfidentialCompute": {
          "description": "Optional. Indicates whether this disk is using confidential compute mode. Encryption with a Cloud KMS key is required to enable this option.",
          "type": "boolean"
        },
        "type": {
          "description": "Required. URL of the disk type resource describing which disk type to use to create the disk.",
          "type": "string"
        },
        "resourcePolicy": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Optional. Resource policies applied to this disk."
        },
        "guestOsFeature": {
          "type": "array",
          "items": {
            "$ref": "GuestOsFeature"
          },
          "description": "Optional. A list of features to enable in the guest operating system. This is applicable only for bootable images."
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Labels to apply to this disk. These can be modified later using setLabels method. Label values can be empty."
        },
        "physicalBlockSizeBytes": {
          "description": "Optional. Physical block size of the persistent disk, in bytes. If not present in a request, a default value is used. Currently, the supported size is 4096.",
          "format": "int64",
          "type": "string"
        },
        "sizeGb": {
          "type": "string",
          "description": "Required. The size of the disk in GB.",
          "format": "int64"
        }
      },
      "description": "DiskRestoreProperties represents the properties of a Disk restore."
    },
    "DiskTargetEnvironment": {
      "id": "DiskTargetEnvironment",
      "type": "object",
      "properties": {
        "zone": {
          "description": "Required. Target zone for the disk.",
          "type": "string"
        },
        "project": {
          "description": "Required. Target project for the disk.",
          "type": "string"
        }
      },
      "description": "DiskTargetEnvironment represents the target environment for the disk."
    },
    "AllocationAffinity": {
      "id": "AllocationAffinity",
      "type": "object",
      "description": "Specifies the reservations that this instance can consume from.",
      "properties": {
        "consumeReservationType": {
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Do not consume from any allocated capacity.",
            "Consume any allocation available.",
            "Must consume from a specific reservation. Must specify key value fields for specifying the reservations."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "NO_RESERVATION",
            "ANY_RESERVATION",
            "SPECIFIC_RESERVATION"
          ],
          "description": "Optional. Specifies the type of reservation from which this instance can consume"
        },
        "values": {
          "description": "Optional. Corresponds to the label values of a reservation resource.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "key": {
          "description": "Optional. Corresponds to the label key of a reservation resource.",
          "type": "string"
        }
      }
    },
    "CloudSqlInstanceDataSourceProperties": {
      "description": "CloudSqlInstanceDataSourceProperties represents the properties of a Cloud SQL resource that are stored in the DataSource.",
      "properties": {
        "databaseInstalledVersion": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The installed database version of the Cloud SQL instance."
        },
        "instanceCreateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The instance creation timestamp.",
          "format": "google-datetime"
        },
        "instanceTier": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The tier (or machine type) for this instance. Example: `db-custom-1-3840`"
        },
        "name": {
          "description": "Output only. Name of the Cloud SQL instance backed up by the datasource. Format: projects/{project}/instances/{instance}",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "CloudSqlInstanceDataSourceProperties",
      "type": "object"
    },
    "GcpBackupConfig": {
      "id": "GcpBackupConfig",
      "type": "object",
      "properties": {
        "backupPlan": {
          "description": "The name of the backup plan.",
          "type": "string"
        },
        "backupPlanDescription": {
          "description": "The description of the backup plan.",
          "type": "string"
        },
        "backupPlanAssociation": {
          "description": "The name of the backup plan association.",
          "type": "string"
        },
        "backupPlanRules": {
          "description": "The names of the backup plan rules which point to this backupvault",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "backupPlanRevisionId": {
          "description": "The user friendly id of the backup plan revision. E.g. v0, v1 etc.",
          "type": "string"
        },
        "backupPlanRevisionName": {
          "description": "The name of the backup plan revision.",
          "type": "string"
        }
      },
      "description": "GcpBackupConfig captures the Backup configuration details for Google Cloud resources. All Google Cloud resources regardless of type are protected with backup plan associations."
    },
    "Scheduling": {
      "id": "Scheduling",
      "type": "object",
      "description": "Sets the scheduling options for an Instance.",
      "properties": {
        "minNodeCpus": {
          "description": "Optional. The minimum number of virtual CPUs this instance will consume when running on a sole-tenant node.",
          "format": "int32",
          "type": "integer"
        },
        "automaticRestart": {
          "description": "Optional. Specifies whether the instance should be automatically restarted if it is terminated by Compute Engine (not terminated by a user).",
          "type": "boolean"
        },
        "preemptible": {
          "description": "Optional. Defines whether the instance is preemptible.",
          "type": "boolean"
        },
        "nodeAffinities": {
          "type": "array",
          "items": {
            "$ref": "NodeAffinity"
          },
          "description": "Optional. A set of node affinity and anti-affinity configurations. Overrides reservationAffinity."
        },
        "onHostMaintenance": {
          "description": "Optional. Defines the maintenance behavior for this instance.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Tells Compute Engine to terminate and (optionally) restart the instance away from the maintenance activity.",
            "Default, Allows Compute Engine to automatically migrate instances out of the way of maintenance events."
          ],
          "enum": [
            "ON_HOST_MAINTENANCE_UNSPECIFIED",
            "TERMINATE",
            "MIGRATE"
          ]
        },
        "provisioningModel": {
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is not used.",
            "Standard provisioning with user controlled runtime, no discounts.",
            "Heavily discounted, no guaranteed runtime."
          ],
          "enum": [
            "PROVISIONING_MODEL_UNSPECIFIED",
            "STANDARD",
            "SPOT"
          ],
          "description": "Optional. Specifies the provisioning model of the instance."
        },
        "instanceTerminationAction": {
          "description": "Optional. Specifies the termination action for the instance.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Delete the VM.",
            "Stop the VM without storing in-memory content. default action."
          ],
          "enum": [
            "INSTANCE_TERMINATION_ACTION_UNSPECIFIED",
            "DELETE",
            "STOP"
          ]
        },
        "localSsdRecoveryTimeout": {
          "description": "Optional. Specifies the maximum amount of time a Local Ssd Vm should wait while recovery of the Local Ssd state is attempted. Its value should be in between 0 and 168 hours with hour granularity and the default value being 1 hour.",
          "$ref": "SchedulingDuration"
        }
      }
    },
    "BackupPlanRevision": {
      "description": "`BackupPlanRevision` represents a snapshot of a `BackupPlan` at a point in time.",
      "properties": {
        "revisionId": {
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc.",
          "readOnly": true,
          "type": "string"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The timestamp that the revision was created.",
          "format": "google-datetime"
        },
        "name": {
          "description": "Output only. Identifier. The resource name of the `BackupPlanRevision`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}/revisions/{revision}`",
          "readOnly": true,
          "type": "string"
        },
        "state": {
          "enumDescriptions": [
            "State not set.",
            "The resource is being created.",
            "The resource has been created and is fully usable.",
            "The resource is being deleted.",
            "The resource has been created but is not usable."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE"
          ],
          "description": "Output only. Resource State",
          "readOnly": true,
          "type": "string"
        },
        "backupPlanSnapshot": {
          "description": "The Backup Plan being encompassed by this revision.",
          "$ref": "BackupPlan"
        }
      },
      "id": "BackupPlanRevision",
      "type": "object"
    },
    "GuestOsFeature": {
      "properties": {
        "type": {
          "description": "The ID of a supported feature.",
          "type": "string",
          "enumDescriptions": [
            "Default value, which is unused.",
            "VIRTIO_SCSI_MULTIQUEUE feature type.",
            "WINDOWS feature type.",
            "MULTI_IP_SUBNET feature type.",
            "UEFI_COMPATIBLE feature type.",
            "SECURE_BOOT feature type.",
            "GVNIC feature type.",
            "SEV_CAPABLE feature type.",
            "BARE_METAL_LINUX_COMPATIBLE feature type.",
            "SUSPEND_RESUME_COMPATIBLE feature type.",
            "SEV_LIVE_MIGRATABLE feature type.",
            "SEV_SNP_CAPABLE feature type.",
            "TDX_CAPABLE feature type.",
            "IDPF feature type.",
            "SEV_LIVE_MIGRATABLE_V2 feature type."
          ],
          "enum": [
            "FEATURE_TYPE_UNSPECIFIED",
            "VIRTIO_SCSI_MULTIQUEUE",
            "WINDOWS",
            "MULTI_IP_SUBNET",
            "UEFI_COMPATIBLE",
            "SECURE_BOOT",
            "GVNIC",
            "SEV_CAPABLE",
            "BARE_METAL_LINUX_COMPATIBLE",
            "SUSPEND_RESUME_COMPATIBLE",
            "SEV_LIVE_MIGRATABLE",
            "SEV_SNP_CAPABLE",
            "TDX_CAPABLE",
            "IDPF",
            "SEV_LIVE_MIGRATABLE_V2"
          ]
        }
      },
      "description": "Feature type of the Guest OS.",
      "id": "GuestOsFeature",
      "type": "object"
    },
    "ListDataSourceReferencesResponse": {
      "id": "ListDataSourceReferencesResponse",
      "type": "object",
      "description": "Response for the ListDataSourceReferences method.",
      "properties": {
        "unreachable": {
          "description": "Locations that could not be reached.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "dataSourceReferences": {
          "description": "The DataSourceReferences from the specified parent.",
          "type": "array",
          "items": {
            "$ref": "DataSourceReference"
          }
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      }
    },
    "DataSourceGcpResource": {
      "description": "DataSourceGcpResource is used for protected resources that are Google Cloud Resources. This name is easeier to understand than GcpResourceDataSource or GcpDataSourceResource",
      "properties": {
        "gcpResourcename": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Full resource pathname URL of the source Google Cloud resource."
        },
        "diskDatasourceProperties": {
          "description": "DiskDataSourceProperties has a subset of Disk properties that are useful at the Datasource level.",
          "$ref": "DiskDataSourceProperties"
        },
        "type": {
          "description": "The type of the Google Cloud resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance.",
          "type": "string"
        },
        "cloudSqlInstanceDatasourceProperties": {
          "description": "Output only. CloudSqlInstanceDataSourceProperties has a subset of Cloud SQL Instance properties that are useful at the Datasource level.",
          "readOnly": true,
          "$ref": "CloudSqlInstanceDataSourceProperties"
        },
        "computeInstanceDatasourceProperties": {
          "description": "ComputeInstanceDataSourceProperties has a subset of Compute Instance properties that are useful at the Datasource level.",
          "$ref": "ComputeInstanceDataSourceProperties"
        },
        "filestoreInstanceDatasourceProperties": {
          "description": "Output only. FilestoreInstanceDataSourceProperties has a subset of FileStore instance properties that are useful at the Datasource level.",
          "readOnly": true,
          "$ref": "FilestoreInstanceDataSourceProperties"
        },
        "alloyDbClusterDatasourceProperties": {
          "description": "Output only. AlloyDBClusterDataSourceProperties has a subset of AlloyDB cluster properties that are useful at the Datasource level. Currently none of its child properties are auditable. If new auditable properties are added, the AUDIT annotation should be added.",
          "readOnly": true,
          "$ref": "AlloyDBClusterDataSourceProperties"
        },
        "location": {
          "description": "Location of the resource: //\"global\"/\"unspecified\".",
          "type": "string"
        }
      },
      "id": "DataSourceGcpResource",
      "type": "object"
    },
    "BackupDrPlanConfig": {
      "properties": {
        "backupDrPlanRules": {
          "type": "array",
          "items": {
            "$ref": "BackupDrPlanRule"
          },
          "description": "Backup rules of the backup plan resource."
        }
      },
      "description": "BackupDrPlanConfig has additional information about Google Cloud Backup and DR's Plan backup configuration.",
      "id": "BackupDrPlanConfig",
      "type": "object"
    },
    "BackupLock": {
      "id": "BackupLock",
      "type": "object",
      "properties": {
        "lockUntilTime": {
          "description": "Required. The time after which this lock is not considered valid and will no longer protect the Backup from deletion.",
          "format": "google-datetime",
          "type": "string"
        },
        "backupApplianceLockInfo": {
          "description": "If the client is a backup and recovery appliance, this contains metadata about why the lock exists.",
          "$ref": "BackupApplianceLockInfo"
        },
        "serviceLockInfo": {
          "description": "Output only. Contains metadata about the lock exist for Google Cloud native backups.",
          "readOnly": true,
          "$ref": "ServiceLockInfo"
        }
      },
      "description": "BackupLock represents a single lock on a Backup resource. An unexpired lock on a Backup prevents the Backup from being deleted."
    },
    "ListOperationsResponse": {
      "properties": {
        "operations": {
          "description": "A list of operations that matches the specified filter in the request.",
          "type": "array",
          "items": {
            "$ref": "Operation"
          }
        },
        "unreachable": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations."
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        }
      },
      "description": "The response message for Operations.ListOperations.",
      "id": "ListOperationsResponse",
      "type": "object"
    },
    "ComputeInstanceTargetEnvironment": {
      "description": "ComputeInstanceTargetEnvironment represents Compute Engine target environment to be used during restore.",
      "properties": {
        "project": {
          "description": "Required. Target project for the Compute Engine instance.",
          "type": "string"
        },
        "zone": {
          "description": "Required. The zone of the Compute Engine instance.",
          "type": "string"
        }
      },
      "id": "ComputeInstanceTargetEnvironment",
      "type": "object"
    },
    "PitrSettings": {
      "description": "Point in time recovery settings of the backup configuration resource.",
      "properties": {
        "retentionDays": {
          "readOnly": true,
          "type": "integer",
          "description": "Output only. Number of days to retain the backup.",
          "format": "int32"
        }
      },
      "id": "PitrSettings",
      "type": "object"
    },
    "ListBackupVaultsResponse": {
      "id": "ListBackupVaultsResponse",
      "type": "object",
      "description": "Response message for listing BackupVaults.",
      "properties": {
        "backupVaults": {
          "type": "array",
          "items": {
            "$ref": "BackupVault"
          },
          "description": "The list of BackupVault instances in the project for the specified location. If the '{location}' value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return backup vaults in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations."
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        },
        "unreachable": {
          "description": "Locations that could not be reached.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "AdvancedMachineFeatures": {
      "description": "Specifies options for controlling advanced machine features.",
      "properties": {
        "visibleCoreCount": {
          "description": "Optional. The number of physical cores to expose to an instance. Multiply by the number of threads per core to compute the total number of virtual CPUs to expose to the instance. If unset, the number of cores is inferred from the instance's nominal CPU count and the underlying platform's SMT width.",
          "format": "int32",
          "type": "integer"
        },
        "enableUefiNetworking": {
          "description": "Optional. Whether to enable UEFI networking for instance creation.",
          "type": "boolean"
        },
        "enableNestedVirtualization": {
          "description": "Optional. Whether to enable nested virtualization or not (default is false).",
          "type": "boolean"
        },
        "threadsPerCore": {
          "type": "integer",
          "description": "Optional. The number of threads per physical core. To disable simultaneous multithreading (SMT) set this to 1. If unset, the maximum number of threads supported per core by the underlying processor is assumed.",
          "format": "int32"
        }
      },
      "id": "AdvancedMachineFeatures",
      "type": "object"
    },
    "InstanceParams": {
      "id": "InstanceParams",
      "type": "object",
      "description": "Additional instance params.",
      "properties": {
        "resourceManagerTags": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Resource manager tags to be bound to the instance."
        }
      }
    },
    "DataSource": {
      "id": "DataSource",
      "type": "object",
      "properties": {
        "state": {
          "description": "Output only. The DataSource resource instance state.",
          "enumDescriptions": [
            "State not set.",
            "The data source is being created.",
            "The data source has been created and is fully usable.",
            "The data source is being deleted.",
            "The data source is experiencing an issue and might be unusable."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR"
          ],
          "readOnly": true,
          "type": "string"
        },
        "etag": {
          "description": "Server specified ETag for the ManagementServer resource to prevent simultaneous updates from overwiting each other.",
          "type": "string"
        },
        "backupBlockedByVaultAccessRestriction": {
          "description": "Output only. This field is set to true if the backup is blocked by vault access restriction.",
          "readOnly": true,
          "type": "boolean"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime"
        },
        "backupCount": {
          "type": "string",
          "description": "Number of backups in the data source.",
          "format": "int64"
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Identifier. Name of the datasource to create. It must have the format`\"projects/{project}/locations/{location}/backupVaults/{backupvault}/dataSources/{datasource}\"`. `{datasource}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the backup vault."
        },
        "configState": {
          "enumDescriptions": [
            "The possible states of backup configuration. Status not set.",
            "The data source is actively protected (i.e. there is a BackupPlanAssociation or Appliance SLA pointing to it)",
            "The data source is no longer protected (but may have backups under it)"
          ],
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ],
          "description": "Output only. The backup configuration state.",
          "readOnly": true,
          "type": "string"
        },
        "dataSourceGcpResource": {
          "description": "The backed up resource is a Google Cloud resource. The word 'DataSource' was included in the names to indicate that this is the representation of the Google Cloud resource used within the DataSource object.",
          "$ref": "DataSourceGcpResource"
        },
        "dataSourceBackupApplianceApplication": {
          "description": "The backed up resource is a backup appliance application.",
          "$ref": "DataSourceBackupApplianceApplication"
        },
        "backupConfigInfo": {
          "description": "Output only. Details of how the resource is configured for backup.",
          "readOnly": true,
          "$ref": "BackupConfigInfo"
        },
        "updateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime"
        },
        "totalStoredBytes": {
          "description": "The number of bytes (metadata and data) stored in this datasource.",
          "format": "int64",
          "type": "string"
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined:"
        }
      },
      "description": "Message describing a DataSource object. Datasource object used to represent Datasource details for both admin and basic view."
    },
    "AlloyDbPitrWindow": {
      "id": "AlloyDbPitrWindow",
      "type": "object",
      "description": "Point in time recovery window for an AlloyDB cluster.",
      "properties": {
        "logRetentionDays": {
          "description": "Output only. Log retention days for the PITR window.",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        },
        "startTime": {
          "description": "Output only. The start time of the PITR window.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "endTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The end time of the PITR window. It is not set if the corresponding Backup Plan Association is active.",
          "format": "google-datetime"
        }
      }
    },
    "BackupApplianceLockInfo": {
      "properties": {
        "jobName": {
          "description": "The job name on the backup/recovery appliance that created this lock.",
          "type": "string"
        },
        "lockReason": {
          "description": "Required. The reason for the lock: e.g. MOUNT/RESTORE/BACKUP/etc. The value of this string is only meaningful to the client and it is not interpreted by the BackupVault service.",
          "type": "string"
        },
        "slaId": {
          "description": "The SLA on the backup/recovery appliance that owns the lock.",
          "format": "int64",
          "type": "string"
        },
        "backupImage": {
          "description": "The image name that depends on this Backup.",
          "type": "string"
        },
        "backupApplianceName": {
          "description": "Required. The name of the backup/recovery appliance that created this lock.",
          "type": "string"
        },
        "backupApplianceId": {
          "type": "string",
          "description": "Required. The ID of the backup/recovery appliance that created this lock.",
          "format": "int64"
        }
      },
      "description": "BackupApplianceLockInfo contains metadata about the backupappliance that created the lock.",
      "id": "BackupApplianceLockInfo",
      "type": "object"
    },
    "BackupApplianceBackupConfig": {
      "id": "BackupApplianceBackupConfig",
      "type": "object",
      "description": "BackupApplianceBackupConfig captures the backup configuration for applications that are protected by Backup Appliances.",
      "properties": {
        "sltName": {
          "description": "The name of the SLT associated with the application.",
          "type": "string"
        },
        "slaId": {
          "description": "The ID of the SLA of this application.",
          "format": "int64",
          "type": "string"
        },
        "slpName": {
          "description": "The name of the SLP associated with the application.",
          "type": "string"
        },
        "hostName": {
          "description": "The name of the host where the application is running.",
          "type": "string"
        },
        "backupApplianceName": {
          "description": "The name of the backup appliance.",
          "type": "string"
        },
        "backupApplianceId": {
          "type": "string",
          "description": "The ID of the backup appliance.",
          "format": "int64"
        },
        "applicationName": {
          "description": "The name of the application.",
          "type": "string"
        }
      }
    },
    "SetInternalStatusRequest": {
      "id": "SetInternalStatusRequest",
      "type": "object",
      "description": "Request message for SetStatusInternal method.",
      "properties": {
        "value": {
          "type": "string",
          "description": "Required. The value required for this method to work. This field must be the 32-byte SHA256 hash of the DataSourceID. The DataSourceID used here is only the final piece of the fully qualified resource path for this DataSource (i.e. the part after '.../dataSources/'). This field exists to make this method difficult to call since it is intended for use only by Backup Appliances.",
          "format": "byte"
        },
        "backupConfigState": {
          "enumDescriptions": [
            "The possible states of backup configuration. Status not set.",
            "The data source is actively protected (i.e. there is a BackupPlanAssociation or Appliance SLA pointing to it)",
            "The data source is no longer protected (but may have backups under it)"
          ],
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ],
          "description": "Required. Output only. The new BackupConfigState to set for the DataSource.",
          "readOnly": true,
          "type": "string"
        },
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        }
      }
    },
    "FetchMsComplianceMetadataResponse": {
      "properties": {
        "isAssuredWorkload": {
          "description": "The ms compliance metadata of the target project, if the project is an Assured Workloads project, values will be true, otherwise false.",
          "type": "boolean"
        }
      },
      "description": "Response message for GetMsComplianceMetadata",
      "id": "FetchMsComplianceMetadataResponse",
      "type": "object"
    },
    "GcpResource": {
      "id": "GcpResource",
      "type": "object",
      "description": "Minimum details to identify a Google Cloud resource",
      "properties": {
        "type": {
          "description": "Type of the resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance.",
          "type": "string"
        },
        "gcpResourcename": {
          "description": "Name of the Google Cloud resource.",
          "type": "string"
        },
        "location": {
          "description": "Location of the resource: //\"global\"/\"unspecified\".",
          "type": "string"
        }
      }
    },
    "Empty": {
      "properties": {},
      "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }",
      "id": "Empty",
      "type": "object"
    },
    "CustomerEncryptionKey": {
      "properties": {
        "rawKey": {
          "description": "Optional. Specifies a 256-bit customer-supplied encryption key.",
          "type": "string"
        },
        "kmsKeyServiceAccount": {
          "description": "Optional. The service account being used for the encryption request for the given KMS key. If absent, the Compute Engine default service account is used.",
          "type": "string"
        },
        "rsaEncryptedKey": {
          "description": "Optional. RSA-wrapped 2048-bit customer-supplied encryption key to either encrypt or decrypt this resource.",
          "type": "string"
        },
        "kmsKeyName": {
          "description": "Optional. The name of the encryption key that is stored in Google Cloud KMS.",
          "type": "string"
        }
      },
      "description": "A customer-supplied encryption key.",
      "id": "CustomerEncryptionKey",
      "type": "object"
    },
    "TriggerBackupRequest": {
      "properties": {
        "customRetentionDays": {
          "type": "integer",
          "description": "Optional. The duration for which backup data will be kept, while taking an on-demand backup with custom retention. It is defined in \"days\". It is mutually exclusive with rule_id. This field is required if rule_id is not provided.",
          "format": "int32"
        },
        "ruleId": {
          "description": "Optional. backup rule_id for which a backup needs to be triggered. If not specified, on-demand backup with custom retention will be triggered.",
          "type": "string"
        },
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        },
        "labels": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Labels to be applied on the backup."
        }
      },
      "description": "Request message for triggering a backup.",
      "id": "TriggerBackupRequest",
      "type": "object"
    },
    "AuditLogConfig": {
      "id": "AuditLogConfig",
      "type": "object",
      "description": "Provides the configuration for logging a type of permissions. Example: { \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\", \"exempted_members\": [ \"user:jose@example.com\" ] }, { \"log_type\": \"DATA_WRITE\" } ] } This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting jose@example.com from DATA_READ logging.",
      "properties": {
        "logType": {
          "type": "string",
          "enumDescriptions": [
            "Default case. Should never be this.",
            "Admin reads. Example: CloudIAM getIamPolicy",
            "Data writes. Example: CloudSQL Users create",
            "Data reads. Example: CloudSQL Users list"
          ],
          "enum": [
            "LOG_TYPE_UNSPECIFIED",
            "ADMIN_READ",
            "DATA_WRITE",
            "DATA_READ"
          ],
          "description": "The log type that this config enables."
        },
        "exemptedMembers": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members."
        }
      }
    },
    "CancelOperationRequest": {
      "id": "CancelOperationRequest",
      "type": "object",
      "description": "The request message for Operations.CancelOperation.",
      "properties": {}
    },
    "ComputeInstanceBackupPlanProperties": {
      "id": "ComputeInstanceBackupPlanProperties",
      "type": "object",
      "properties": {
        "guestFlush": {
          "description": "Optional. Indicates whether to perform a guest flush operation before taking a compute backup. When set to false, the system will create crash-consistent backups. Default value is false.",
          "type": "boolean"
        }
      },
      "description": "Properties for a compute instance backup plan."
    },
    "Trial": {
      "id": "Trial",
      "type": "object",
      "properties": {
        "state": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The state of the trial.",
          "enumDescriptions": [
            "State not set.",
            "Trial is subscribed.",
            "Trial is unsubscribed before expiration.",
            "Trial is expired post 30 days of subscription.",
            "Trial is eligible for enablement.",
            "Trial is not eligible for enablement."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "SUBSCRIBED",
            "UNSUBSCRIBED",
            "EXPIRED",
            "ELIGIBLE",
            "NOT_ELIGIBLE"
          ]
        },
        "name": {
          "description": "Identifier. The resource name of the trial. Format: projects/{project}/locations/{location}/trial",
          "type": "string"
        },
        "startTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the trial was subscribed.",
          "format": "google-datetime"
        },
        "endReason": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "End reason not set.",
            "Trial is deliberately ended by the user to transition to paid usage.",
            "Trial is discontinued before expiration."
          ],
          "enum": [
            "END_REASON_UNSPECIFIED",
            "MOVE_TO_PAID",
            "DISCONTINUED"
          ],
          "description": "Output only. The reason for ending the trial."
        },
        "endTime": {
          "description": "Output only. The time when the trial will expire.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "Represents a Trial for a project."
    },
    "ServiceLockInfo": {
      "id": "ServiceLockInfo",
      "type": "object",
      "properties": {
        "operation": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The name of the operation that created this lock. The lock will automatically be released when the operation completes."
        }
      },
      "description": "ServiceLockInfo represents the details of a lock taken by the service on a Backup resource."
    },
    "EndTrialRequest": {
      "description": "Request message for ending a trial.",
      "properties": {
        "endReason": {
          "type": "string",
          "enumDescriptions": [
            "End reason not set.",
            "Trial is deliberately ended by the user to transition to paid usage.",
            "Trial is discontinued before expiration."
          ],
          "enum": [
            "END_REASON_UNSPECIFIED",
            "MOVE_TO_PAID",
            "DISCONTINUED"
          ],
          "description": "Required. The reason for ending the trial."
        }
      },
      "id": "EndTrialRequest",
      "type": "object"
    },
    "NetworkConfig": {
      "properties": {
        "network": {
          "description": "Optional. The resource name of the Google Compute Engine VPC network to which the ManagementServer instance is connected.",
          "type": "string"
        },
        "peeringMode": {
          "type": "string",
          "enumDescriptions": [
            "Peering mode not set.",
            "Connect using Private Service Access to the Management Server. Private services access provides an IP address range for multiple Google Cloud services, including Google Cloud Backup and DR."
          ],
          "enum": [
            "PEERING_MODE_UNSPECIFIED",
            "PRIVATE_SERVICE_ACCESS"
          ],
          "description": "Optional. The network connect mode of the ManagementServer instance. For this version, only PRIVATE_SERVICE_ACCESS is supported."
        }
      },
      "description": "Network configuration for ManagementServer instance.",
      "id": "NetworkConfig",
      "type": "object"
    },
    "AliasIpRange": {
      "properties": {
        "ipCidrRange": {
          "description": "Optional. The IP alias ranges to allocate for this interface.",
          "type": "string"
        },
        "subnetworkRangeName": {
          "description": "Optional. The name of a subnetwork secondary IP range from which to allocate an IP alias range. If not specified, the primary range of the subnetwork is used.",
          "type": "string"
        }
      },
      "description": "An alias IP range attached to an instance's network interface.",
      "id": "AliasIpRange",
      "type": "object"
    },
    "RuleConfigInfo": {
      "id": "RuleConfigInfo",
      "type": "object",
      "properties": {
        "lastBackupState": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "State not set.",
            "The first backup is pending.",
            "The most recent backup could not be run/failed because of the lack of permissions.",
            "The last backup operation succeeded.",
            "The last backup operation failed."
          ],
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "PERMISSION_DENIED",
            "SUCCEEDED",
            "FAILED"
          ],
          "description": "Output only. The last backup state for rule."
        },
        "lastBackupError": {
          "description": "Output only. google.rpc.Status object to store the last backup error.",
          "readOnly": true,
          "$ref": "Status"
        },
        "ruleId": {
          "description": "Output only. Backup Rule id fetched from backup plan.",
          "readOnly": true,
          "type": "string"
        },
        "lastSuccessfulBackupConsistencyTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The point in time when the last successful backup was captured from the source.",
          "format": "google-datetime"
        }
      },
      "description": "Message for rules config info."
    },
    "SubscribeTrialRequest": {
      "id": "SubscribeTrialRequest",
      "type": "object",
      "properties": {},
      "description": "Request message for subscribing to a trial."
    },
    "ResourceBackupConfig": {
      "id": "ResourceBackupConfig",
      "type": "object",
      "properties": {
        "vaulted": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Whether the target resource is protected by a backup vault. This is true if the backup_configs_details is not empty and any of the ResourceBackupConfig.backup_configs_details has a backup configuration with BackupConfigDetails.backup_vault set."
        },
        "name": {
          "description": "Identifier. The resource name of the ResourceBackupConfig. Format: projects/{project}/locations/{location}/resourceBackupConfigs/{uid}",
          "type": "string"
        },
        "targetResourceType": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The type of the target resource.",
          "enumDescriptions": [
            "Resource type not set.",
            "Cloud SQL instance.",
            "Compute Engine VM.",
            "Compute Engine Disk.",
            "Compute Engine Regional Disk.",
            "Filestore Instance."
          ],
          "enum": [
            "RESOURCE_TYPE_UNSPECIFIED",
            "CLOUD_SQL_INSTANCE",
            "COMPUTE_ENGINE_VM",
            "COMPUTE_ENGINE_DISK",
            "COMPUTE_ENGINE_REGIONAL_DISK",
            "FILESTORE_INSTANCE"
          ]
        },
        "targetResource": {
          "description": "Output only. The [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format) of the cloud resource that this configuration applies to. Supported resource types are ResourceBackupConfig.ResourceType.",
          "readOnly": true,
          "type": "string"
        },
        "backupConfigsDetails": {
          "type": "array",
          "items": {
            "$ref": "BackupConfigDetails"
          },
          "description": "Backup configurations applying to the target resource, including those targeting its related/child resources. For example, backup configuration applicable to Compute Engine disks will be populated in this field for a Compute Engine VM which has the disk associated."
        },
        "targetResourceLabels": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Labels associated with the target resource."
        },
        "uid": {
          "description": "Output only. The unique identifier of the resource backup config.",
          "readOnly": true,
          "type": "string"
        },
        "targetResourceDisplayName": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The human friendly name of the target resource."
        },
        "backupConfigured": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Whether the target resource is configured for backup. This is true if the backup_configs_details is not empty."
        }
      },
      "description": "ResourceBackupConfig represents a resource along with its backup configurations."
    },
    "ManagementURI": {
      "description": "ManagementURI for the Management Server resource.",
      "properties": {
        "webUi": {
          "description": "Output only. The ManagementServer AGM/RD WebUI URL.",
          "readOnly": true,
          "type": "string"
        },
        "api": {
          "description": "Output only. The ManagementServer AGM/RD API URL.",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "ManagementURI",
      "type": "object"
    },
    "FetchDataSourceReferencesForResourceTypeResponse": {
      "id": "FetchDataSourceReferencesForResourceTypeResponse",
      "type": "object",
      "properties": {
        "dataSourceReferences": {
          "type": "array",
          "items": {
            "$ref": "DataSourceReference"
          },
          "description": "The DataSourceReferences from the specified parent."
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "description": "Response for the FetchDataSourceReferencesForResourceType method."
    },
    "FetchUsableBackupVaultsResponse": {
      "id": "FetchUsableBackupVaultsResponse",
      "type": "object",
      "properties": {
        "unreachable": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached."
        },
        "backupVaults": {
          "type": "array",
          "items": {
            "$ref": "BackupVault"
          },
          "description": "The list of BackupVault instances in the project for the specified location. If the '{location}' value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return backup vaults in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations."
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "description": "Response message for fetching usable BackupVaults."
    },
    "DataSourceReference": {
      "description": "DataSourceReference is a reference to a DataSource resource.",
      "properties": {
        "dataSource": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The resource name of the DataSource. Format: projects/{project}/locations/{location}/backupVaults/{backupVault}/dataSources/{dataSource}"
        },
        "createTime": {
          "description": "Output only. The time when the DataSourceReference was created.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "dataSourceBackupConfigState": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The backup configuration state of the DataSource.",
          "enumDescriptions": [
            "The possible states of backup configuration. Status not set.",
            "The data source is actively protected (i.e. there is a BackupPlanAssociation or Appliance SLA pointing to it)",
            "The data source is no longer protected (but may have backups under it)"
          ],
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ]
        },
        "dataSourceGcpResourceInfo": {
          "readOnly": true,
          "$ref": "DataSourceGcpResourceInfo",
          "description": "Output only. The Google Cloud resource that the DataSource is associated with."
        },
        "name": {
          "description": "Identifier. The resource name of the DataSourceReference. Format: projects/{project}/locations/{location}/dataSourceReferences/{data_source_reference}",
          "type": "string"
        },
        "dataSourceBackupCount": {
          "description": "Output only. Number of backups in the DataSource.",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        },
        "dataSourceBackupConfigInfo": {
          "readOnly": true,
          "$ref": "DataSourceBackupConfigInfo",
          "description": "Output only. Information of backup configuration on the DataSource."
        },
        "totalStoredBytes": {
          "description": "Output only. Total size of the storage used by all backup resources for the referenced datasource.",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "DataSourceReference",
      "type": "object"
    },
    "ListBackupPlanRevisionsResponse": {
      "id": "ListBackupPlanRevisionsResponse",
      "type": "object",
      "description": "The response message for getting a list of `BackupPlanRevision`.",
      "properties": {
        "backupPlanRevisions": {
          "type": "array",
          "items": {
            "$ref": "BackupPlanRevision"
          },
          "description": "The list of `BackupPlanRevisions` in the project for the specified location. If the `{location}` value in the request is \"-\", the response contains a list of resources from all locations. In case any location is unreachable, the response will only return backup plans in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations."
        },
        "unreachable": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached."
        },
        "nextPageToken": {
          "description": "A token which may be sent as page_token in a subsequent `ListBackupPlanRevisions` call to retrieve the next page of results. If this field is omitted or empty, then there are no more results to return.",
          "type": "string"
        }
      }
    },
    "GoogleCloudBackupdrV1OperationMetadata": {
      "id": "GoogleCloudBackupdrV1OperationMetadata",
      "type": "object",
      "properties": {
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time the operation was created.",
          "format": "google-datetime"
        },
        "statusMessage": {
          "description": "Output only. Human-readable status of the operation, if any.",
          "readOnly": true,
          "type": "string"
        },
        "requestedCancellation": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Identifies whether the user has requested cancellation of the operation. Operations that have successfully been cancelled have google.longrunning.Operation.error value with a google.rpc.Status.code of 1, corresponding to 'Code.CANCELLED'."
        },
        "endTime": {
          "description": "Output only. The time the operation finished running.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "target": {
          "description": "Output only. Server-defined resource path for the target of the operation.",
          "readOnly": true,
          "type": "string"
        },
        "additionalInfo": {
          "additionalProperties": {
            "type": "string"
          },
          "readOnly": true,
          "type": "object",
          "description": "Output only. AdditionalInfo contains additional Info related to backup plan association resource."
        },
        "apiVersion": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. API version used to start the operation."
        },
        "verb": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the verb executed by the operation."
        }
      },
      "description": "Represents the metadata of the long-running operation."
    },
    "ManagementServer": {
      "id": "ManagementServer",
      "type": "object",
      "properties": {
        "labels": {
          "description": "Optional. Resource labels to represent user provided metadata. Labels currently defined: 1. migrate_from_go= If set to true, the MS is created in migration ready mode.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "oauth2ClientId": {
          "description": "Output only. The OAuth 2.0 client id is required to make API calls to the Backup and DR instance API of this ManagementServer. This is the value that should be provided in the 'aud' field of the OIDC ID Token (see openid specification https://openid.net/specs/openid-connect-core-1_0.html#IDToken).",
          "readOnly": true,
          "type": "string"
        },
        "satisfiesPzs": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Reserved for future use."
        },
        "workforceIdentityBasedManagementUri": {
          "readOnly": true,
          "$ref": "WorkforceIdentityBasedManagementURI",
          "description": "Output only. The hostnames of the exposed AGM endpoints for both types of user i.e. 1p and 3p, used to connect AGM/RM UI."
        },
        "networks": {
          "type": "array",
          "items": {
            "$ref": "NetworkConfig"
          },
          "description": "Optional. VPC networks to which the ManagementServer instance is connected. For this version, only a single network is supported. This field is optional if MS is created without PSA"
        },
        "satisfiesPzi": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Reserved for future use."
        },
        "name": {
          "description": "Output only. Identifier. The resource name.",
          "readOnly": true,
          "type": "string"
        },
        "description": {
          "description": "Optional. The description of the ManagementServer instance (2048 characters or less).",
          "type": "string"
        },
        "baProxyUri": {
          "description": "Output only. The hostname or ip address of the exposed AGM endpoints, used by BAs to connect to BA proxy.",
          "readOnly": true,
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "createTime": {
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "type": {
          "type": "string",
          "enumDescriptions": [
            "Instance type is not mentioned.",
            "Instance for backup and restore management (i.e., AGM)."
          ],
          "enum": [
            "INSTANCE_TYPE_UNSPECIFIED",
            "BACKUP_RESTORE"
          ],
          "description": "Optional. The type of the ManagementServer resource."
        },
        "workforceIdentityBasedOauth2ClientId": {
          "readOnly": true,
          "$ref": "WorkforceIdentityBasedOAuth2ClientID",
          "description": "Output only. The OAuth client IDs for both types of user i.e. 1p and 3p."
        },
        "managementUri": {
          "readOnly": true,
          "$ref": "ManagementURI",
          "description": "Output only. The hostname or ip address of the exposed AGM endpoints, used by clients to connect to AGM/RD graphical user interface and APIs."
        },
        "state": {
          "description": "Output only. The ManagementServer state.",
          "enumDescriptions": [
            "State not set.",
            "The instance is being created.",
            "The instance has been created and is fully usable.",
            "The instance configuration is being updated. Certain kinds of updates may cause the instance to become unusable while the update is in progress.",
            "The instance is being deleted.",
            "The instance is being repaired and may be unstable.",
            "Maintenance is being performed on this instance.",
            "The instance is experiencing an issue and might be unusable. You can get further details from the statusMessage field of Instance resource."
          ],
          "enum": [
            "INSTANCE_STATE_UNSPECIFIED",
            "CREATING",
            "READY",
            "UPDATING",
            "DELETING",
            "REPAIRING",
            "MAINTENANCE",
            "ERROR"
          ],
          "readOnly": true,
          "type": "string"
        },
        "etag": {
          "description": "Optional. Server specified ETag for the ManagementServer resource to prevent simultaneous updates from overwiting each other.",
          "type": "string"
        }
      },
      "description": "ManagementServer describes a single BackupDR ManagementServer instance."
    },
    "DiskDataSourceProperties": {
      "id": "DiskDataSourceProperties",
      "type": "object",
      "description": "DiskDataSourceProperties represents the properties of a Disk resource that are stored in the DataSource. .",
      "properties": {
        "type": {
          "description": "The type of the disk.",
          "type": "string"
        },
        "sizeGb": {
          "description": "The size of the disk in GB.",
          "format": "int64",
          "type": "string"
        },
        "name": {
          "description": "Name of the disk backed up by the datasource.",
          "type": "string"
        },
        "description": {
          "description": "The description of the disk.",
          "type": "string"
        }
      }
    },
    "DiskBackupProperties": {
      "properties": {
        "description": {
          "description": "A description of the source disk.",
          "type": "string"
        },
        "region": {
          "description": "Region and zone are mutually exclusive fields. The URL of the region of the source disk.",
          "type": "string"
        },
        "provisionedThroughput": {
          "type": "string",
          "description": "The number of throughput provisioned for the source disk.",
          "format": "int64"
        },
        "licenses": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "A list of publicly available licenses that are applicable to this backup. This is applicable if the original image had licenses attached, e.g. Windows image."
        },
        "storagePool": {
          "description": "The storage pool of the source disk.",
          "type": "string"
        },
        "provisionedIops": {
          "type": "string",
          "description": "The number of IOPS provisioned for the source disk.",
          "format": "int64"
        },
        "accessMode": {
          "description": "The access mode of the source disk.",
          "type": "string"
        },
        "type": {
          "description": "The URL of the type of the disk.",
          "type": "string"
        },
        "replicaZones": {
          "description": "The URL of the Zones where the source disk should be replicated.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "enableConfidentialCompute": {
          "description": "Indicates whether the source disk is using confidential compute mode.",
          "type": "boolean"
        },
        "architecture": {
          "description": "The architecture of the source disk. Valid values are ARM64 or X86_64.",
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Disks with architecture X86_64",
            "Disks with architecture ARM64"
          ],
          "enum": [
            "ARCHITECTURE_UNSPECIFIED",
            "X86_64",
            "ARM64"
          ]
        },
        "guestOsFeature": {
          "description": "A list of guest OS features that are applicable to this backup.",
          "type": "array",
          "items": {
            "$ref": "GuestOsFeature"
          }
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "The labels of the source disk."
        },
        "zone": {
          "description": "The URL of the Zone where the source disk.",
          "type": "string"
        },
        "sourceDisk": {
          "description": "The source disk used to create this backup.",
          "type": "string"
        },
        "physicalBlockSizeBytes": {
          "type": "string",
          "description": "The physical block size of the source disk.",
          "format": "int64"
        },
        "sizeGb": {
          "type": "string",
          "description": "Size(in GB) of the source disk.",
          "format": "int64"
        },
        "guestFlush": {
          "description": "Optional. Defines if the guest flush is enabled for the source disk. Default value is false.",
          "type": "boolean"
        }
      },
      "description": "DiskBackupProperties represents the properties of a Disk backup.",
      "id": "DiskBackupProperties",
      "type": "object"
    },
    "Metadata": {
      "id": "Metadata",
      "type": "object",
      "description": "A metadata key/value entry.",
      "properties": {
        "items": {
          "description": "Optional. Array of key/value pairs. The total size of all keys and values must be less than 512 KB.",
          "type": "array",
          "items": {
            "$ref": "Entry"
          }
        }
      }
    },
    "FetchBackupsForResourceTypeResponse": {
      "id": "FetchBackupsForResourceTypeResponse",
      "type": "object",
      "description": "Response for the FetchBackupsForResourceType method.",
      "properties": {
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "backups": {
          "description": "The Backups from the specified parent.",
          "type": "array",
          "items": {
            "$ref": "Backup"
          }
        }
      }
    },
    "InitializeServiceRequest": {
      "id": "InitializeServiceRequest",
      "type": "object",
      "properties": {
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes since the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        },
        "cloudSqlInstanceInitializationConfig": {
          "description": "Optional. The configuration for initializing a Cloud SQL instance.",
          "$ref": "CloudSqlInstanceInitializationConfig"
        },
        "resourceType": {
          "description": "Required. The resource type to which the default service config will be applied. Examples include, \"compute.googleapis.com/Instance\" and \"storage.googleapis.com/Bucket\".",
          "type": "string"
        },
        "backupPlanLocation": {
          "description": "Optional. The location where the BackupPlan will be created. This field is required for multi-region BackupVaults and is optional for regional BackupVaults. It is useful when creating a Backup Vault in a multi-region, allowing the BackupPlan to reside in a specific region within that multi-region. If this field is not provided, the BackupPlan will be created in the same location as specified in the `name` field.",
          "type": "string"
        },
        "validateOnly": {
          "description": "Optional. If set, validates the request and returns the result, but does not actually run it.",
          "type": "boolean"
        }
      },
      "description": "Request message for initializing the service."
    },
    "InitializeParams": {
      "id": "InitializeParams",
      "type": "object",
      "description": "Specifies the parameters to initialize this disk.",
      "properties": {
        "diskName": {
          "description": "Optional. Specifies the disk name. If not specified, the default is to use the name of the instance.",
          "type": "string"
        },
        "replicaZones": {
          "description": "Optional. URL of the zone where the disk should be created. Required for each regional disk associated with the instance.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "SetInternalStatusResponse": {
      "id": "SetInternalStatusResponse",
      "type": "object",
      "properties": {},
      "description": "Response message from SetStatusInternal method."
    },
    "AttachedDisk": {
      "description": "An instance-attached disk resource.",
      "properties": {
        "boot": {
          "description": "Optional. Indicates that this is a boot disk. The virtual machine will use the first partition of the disk for its root filesystem.",
          "type": "boolean"
        },
        "diskType": {
          "description": "Optional. Output only. The URI of the disk type resource. For example: projects/project/zones/zone/diskTypes/pd-standard or pd-ssd",
          "readOnly": true,
          "type": "string"
        },
        "savedState": {
          "description": "Optional. Output only. The state of the disk.",
          "enumDescriptions": [
            "Default Disk state has not been preserved.",
            "Disk state has been preserved."
          ],
          "enum": [
            "DISK_SAVED_STATE_UNSPECIFIED",
            "PRESERVED"
          ],
          "readOnly": true,
          "type": "string"
        },
        "diskSizeGb": {
          "type": "string",
          "description": "Optional. The size of the disk in GB.",
          "format": "int64"
        },
        "initializeParams": {
          "description": "Optional. Specifies the parameters to initialize this disk.",
          "$ref": "InitializeParams"
        },
        "guestOsFeature": {
          "type": "array",
          "items": {
            "$ref": "GuestOsFeature"
          },
          "description": "Optional. A list of features to enable on the guest operating system. Applicable only for bootable images."
        },
        "license": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Optional. Any valid publicly visible licenses."
        },
        "source": {
          "description": "Optional. Specifies a valid partial or full URL to an existing Persistent Disk resource.",
          "type": "string"
        },
        "mode": {
          "description": "Optional. The mode in which to attach this disk.",
          "type": "string",
          "enumDescriptions": [
            "Default value, which is unused.",
            "Attaches this disk in read-write mode. Only one virtual machine at a time can be attached to a disk in read-write mode.",
            "Attaches this disk in read-only mode. Multiple virtual machines can use a disk in read-only mode at a time.",
            "The disk is locked for administrative reasons. Nobody else can use the disk. This mode is used (for example) when taking a snapshot of a disk to prevent mounting the disk while it is being snapshotted."
          ],
          "enum": [
            "DISK_MODE_UNSPECIFIED",
            "READ_WRITE",
            "READ_ONLY",
            "LOCKED"
          ]
        },
        "deviceName": {
          "description": "Optional. This is used as an identifier for the disks. This is the unique name has to provided to modify disk parameters like disk_name and replica_zones (in case of RePDs)",
          "type": "string"
        },
        "type": {
          "description": "Optional. Specifies the type of the disk.",
          "type": "string",
          "enumDescriptions": [
            "Default value, which is unused.",
            "A scratch disk type.",
            "A persistent disk type."
          ],
          "enum": [
            "DISK_TYPE_UNSPECIFIED",
            "SCRATCH",
            "PERSISTENT"
          ]
        },
        "autoDelete": {
          "description": "Optional. Specifies whether the disk will be auto-deleted when the instance is deleted (but not when the disk is detached from the instance).",
          "type": "boolean"
        },
        "kind": {
          "description": "Optional. Type of the resource.",
          "type": "string"
        },
        "diskEncryptionKey": {
          "description": "Optional. Encrypts or decrypts a disk using a customer-supplied encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "diskTypeDeprecated": {
          "deprecated": true,
          "description": "Specifies the type of the disk.",
          "enumDescriptions": [
            "Default value, which is unused.",
            "A scratch disk type.",
            "A persistent disk type."
          ],
          "enum": [
            "DISK_TYPE_UNSPECIFIED",
            "SCRATCH",
            "PERSISTENT"
          ],
          "type": "string"
        },
        "diskInterface": {
          "description": "Optional. Specifies the disk interface to use for attaching this disk.",
          "type": "string",
          "enumDescriptions": [
            "Default value, which is unused.",
            "SCSI Disk Interface.",
            "NVME Disk Interface.",
            "NVDIMM Disk Interface.",
            "ISCSI Disk Interface."
          ],
          "enum": [
            "DISK_INTERFACE_UNSPECIFIED",
            "SCSI",
            "NVME",
            "NVDIMM",
            "ISCSI"
          ]
        },
        "index": {
          "description": "Optional. A zero-based index to this disk, where 0 is reserved for the boot disk.",
          "format": "int64",
          "type": "string"
        }
      },
      "id": "AttachedDisk",
      "type": "object"
    },
    "BackupVault": {
      "id": "BackupVault",
      "type": "object",
      "description": "Message describing a BackupVault object.",
      "properties": {
        "name": {
          "description": "Output only. Identifier. Name of the backup vault to create. It must have the format`\"projects/{project}/locations/{location}/backupVaults/{backupvault}\"`. `{backupvault}` cannot be changed after creation. It must be between 3-63 characters long and must be unique within the project and location.",
          "readOnly": true,
          "type": "string"
        },
        "description": {
          "description": "Optional. The description of the BackupVault instance (2048 characters or less).",
          "type": "string"
        },
        "backupCount": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The number of backups in this backup vault.",
          "format": "int64"
        },
        "annotations": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. User annotations. See https://google.aip.dev/128#annotations Stores small amounts of arbitrary data."
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime"
        },
        "effectiveTime": {
          "type": "string",
          "description": "Optional. Time after which the BackupVault resource is locked.",
          "format": "google-datetime"
        },
        "etag": {
          "description": "Optional. Server specified ETag for the backup vault resource to prevent simultaneous updates from overwiting each other.",
          "type": "string"
        },
        "state": {
          "enumDescriptions": [
            "State not set.",
            "The backup vault is being created.",
            "The backup vault has been created and is fully usable.",
            "The backup vault is being deleted.",
            "The backup vault is experiencing an issue and might be unusable.",
            "The backup vault is being updated."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR",
            "UPDATING"
          ],
          "description": "Output only. The BackupVault resource instance state.",
          "readOnly": true,
          "type": "string"
        },
        "deletable": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Set to true when there are no backups nested under this resource."
        },
        "encryptionConfig": {
          "description": "Optional. The encryption config of the backup vault.",
          "$ref": "EncryptionConfig"
        },
        "labels": {
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined:",
          "additionalProperties": {
            "type": "string"
          },
          "type": "object"
        },
        "backupRetentionInheritance": {
          "type": "string",
          "enumDescriptions": [
            "Inheritance behavior not set. This will default to `INHERIT_VAULT_RETENTION`.",
            "The enforced retention end time of a backup will be inherited from the backup vault's `backup_minimum_enforced_retention_duration` field. This is the default behavior.",
            "The enforced retention end time of a backup will always match the expire time of the backup. If this is set, the backup's enforced retention end time will be set to match the expire time during creation of the backup. When updating, the ERET and expire time must be updated together and have the same value. Invalid update requests will be rejected by the server."
          ],
          "enum": [
            "BACKUP_RETENTION_INHERITANCE_UNSPECIFIED",
            "INHERIT_VAULT_RETENTION",
            "MATCH_BACKUP_EXPIRE_TIME"
          ],
          "description": "Optional. Setting for how a backup's enforced retention end time is inherited."
        },
        "updateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime"
        },
        "totalStoredBytes": {
          "description": "Output only. Total size of the storage used by all backup resources.",
          "format": "int64",
          "readOnly": true,
          "type": "string"
        },
        "accessRestriction": {
          "description": "Optional. Note: This field is added for future use case and will not be supported in the current release. Access restriction for the backup vault. Default value is WITHIN_ORGANIZATION if not provided during creation.",
          "type": "string",
          "enumDescriptions": [
            "Access restriction not set. If user does not provide any value or pass this value, it will be changed to WITHIN_ORGANIZATION.",
            "Access to or from resources outside your current project will be denied.",
            "Access to or from resources outside your current organization will be denied.",
            "No access restriction.",
            "Access to or from resources outside your current organization will be denied except for backup appliance."
          ],
          "enum": [
            "ACCESS_RESTRICTION_UNSPECIFIED",
            "WITHIN_PROJECT",
            "WITHIN_ORGANIZATION",
            "UNRESTRICTED",
            "WITHIN_ORG_BUT_UNRESTRICTED_FOR_BA"
          ]
        },
        "backupMinimumEnforcedRetentionDuration": {
          "description": "Required. The default and minimum enforced retention for each backup within the backup vault. The enforced retention for each backup can be extended. Note: Longer minimum enforced retention period impacts potential storage costs post introductory trial. We recommend starting with a short duration of 3 days or less.",
          "format": "google-duration",
          "type": "string"
        },
        "serviceAccount": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Service account used by the BackupVault Service for this BackupVault. The user should grant this account permissions in their workload project to enable the service to run backups and restores there."
        },
        "uid": {
          "description": "Output only. Immutable after resource creation until resource deletion.",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "RegionDiskTargetEnvironment": {
      "id": "RegionDiskTargetEnvironment",
      "type": "object",
      "properties": {
        "project": {
          "description": "Required. Target project for the disk.",
          "type": "string"
        },
        "replicaZones": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Required. Target URLs of the replica zones for the disk."
        },
        "region": {
          "description": "Required. Target region for the disk.",
          "type": "string"
        }
      },
      "description": "RegionDiskTargetEnvironment represents the target environment for the disk."
    },
    "ListDataSourcesResponse": {
      "id": "ListDataSourcesResponse",
      "type": "object",
      "description": "Response message for listing DataSources.",
      "properties": {
        "dataSources": {
          "description": "The list of DataSource instances in the project for the specified location. If the '{location}' value in the request is \"-\", the response contains a list of instances from all locations. In case any location is unreachable, the response will only return data sources in reachable locations and the 'unreachable' field will be populated with a list of unreachable locations.",
          "type": "array",
          "items": {
            "$ref": "DataSource"
          }
        },
        "unreachable": {
          "description": "Locations that could not be reached.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      }
    },
    "NetworkInterface": {
      "id": "NetworkInterface",
      "type": "object",
      "properties": {
        "accessConfigs": {
          "type": "array",
          "items": {
            "$ref": "AccessConfig"
          },
          "description": "Optional. An array of configurations for this interface. Currently, only one access config,ONE_TO_ONE_NAT is supported. If there are no accessConfigs specified, then this instance will have no external internet access."
        },
        "networkAttachment": {
          "description": "Optional. The URL of the network attachment that this interface should connect to in the following format: projects/{project_number}/regions/{region_name}/networkAttachments/{network_attachment_name}.",
          "type": "string"
        },
        "ipv6AccessType": {
          "type": "string",
          "enumDescriptions": [
            "IPv6 access type not set. Means this network interface hasn't been turned on IPv6 yet.",
            "This network interface can have internal IPv6.",
            "This network interface can have external IPv6."
          ],
          "enum": [
            "UNSPECIFIED_IPV6_ACCESS_TYPE",
            "INTERNAL",
            "EXTERNAL"
          ],
          "description": "Optional. [Output Only] One of EXTERNAL, INTERNAL to indicate whether the IP can be accessed from the Internet. This field is always inherited from its subnetwork."
        },
        "ipv6Address": {
          "description": "Optional. An IPv6 internal network address for this network interface. To use a static internal IP address, it must be unused and in the same region as the instance's zone. If not specified, Google Cloud will automatically assign an internal IPv6 address from the instance's subnetwork.",
          "type": "string"
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. [Output Only] The name of the network interface, which is generated by the server."
        },
        "stackType": {
          "description": "The stack type for this network interface.",
          "type": "string",
          "enumDescriptions": [
            "Default should be STACK_TYPE_UNSPECIFIED.",
            "The network interface will be assigned IPv4 address.",
            "The network interface can have both IPv4 and IPv6 addresses."
          ],
          "enum": [
            "STACK_TYPE_UNSPECIFIED",
            "IPV4_ONLY",
            "IPV4_IPV6"
          ]
        },
        "internalIpv6PrefixLength": {
          "description": "Optional. The prefix length of the primary internal IPv6 range.",
          "format": "int32",
          "type": "integer"
        },
        "ipv6AccessConfigs": {
          "type": "array",
          "items": {
            "$ref": "AccessConfig"
          },
          "description": "Optional. An array of IPv6 access configurations for this interface. Currently, only one IPv6 access config, DIRECT_IPV6, is supported. If there is no ipv6AccessConfig specified, then this instance will have no external IPv6 Internet access."
        },
        "subnetwork": {
          "description": "Optional. The URL of the Subnetwork resource for this instance.",
          "type": "string"
        },
        "network": {
          "description": "Optional. URL of the VPC network resource for this instance.",
          "type": "string"
        },
        "networkIP": {
          "description": "Optional. An IPv4 internal IP address to assign to the instance for this network interface. If not specified by the user, an unused internal IP is assigned by the system.",
          "type": "string"
        },
        "nicType": {
          "description": "Optional. The type of vNIC to be used on this interface. This may be gVNIC or VirtioNet.",
          "type": "string",
          "enumDescriptions": [
            "Default should be NIC_TYPE_UNSPECIFIED.",
            "VIRTIO",
            "GVNIC"
          ],
          "enum": [
            "NIC_TYPE_UNSPECIFIED",
            "VIRTIO_NET",
            "GVNIC"
          ]
        },
        "aliasIpRanges": {
          "description": "Optional. An array of alias IP ranges for this network interface. You can only specify this field for network interfaces in VPC networks.",
          "type": "array",
          "items": {
            "$ref": "AliasIpRange"
          }
        },
        "queueCount": {
          "type": "integer",
          "description": "Optional. The networking queue count that's specified by users for the network interface. Both Rx and Tx queues will be set to this number. It'll be empty if not specified by the users.",
          "format": "int32"
        }
      },
      "description": "A network interface resource attached to an instance. s"
    },
    "BackupLocation": {
      "properties": {
        "type": {
          "enumDescriptions": [
            "Location type is unspecified.",
            "Location type is zonal.",
            "Location type is regional.",
            "Location type is multi regional."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "ZONAL",
            "REGIONAL",
            "MULTI_REGIONAL"
          ],
          "description": "Output only. The type of the location.",
          "readOnly": true,
          "type": "string"
        },
        "locationId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The id of the cloud location. Example: \"us-central1\""
        }
      },
      "description": "BackupLocation represents a cloud location where a backup can be stored.",
      "id": "BackupLocation",
      "type": "object"
    },
    "TestIamPermissionsResponse": {
      "id": "TestIamPermissionsResponse",
      "type": "object",
      "properties": {
        "permissions": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "A subset of `TestPermissionsRequest.permissions` that the caller is allowed."
        }
      },
      "description": "Response message for `TestIamPermissions` method."
    },
    "GCPBackupPlanInfo": {
      "properties": {
        "backupPlanRevisionId": {
          "description": "The user friendly id of the backup plan revision which triggered this backup in case of scheduled backup or used for on demand backup.",
          "type": "string"
        },
        "backupPlanRuleId": {
          "description": "The rule id of the backup plan which triggered this backup in case of scheduled backup or used for",
          "type": "string"
        },
        "backupPlanRevisionName": {
          "description": "Resource name of the backup plan revision which triggered this backup in case of scheduled backup or used for on demand backup. Format: projects/{project}/locations/{location}/backupPlans/{backupPlanId}/revisions/{revisionId}",
          "type": "string"
        },
        "backupPlan": {
          "description": "Resource name of backup plan by which workload is protected at the time of the backup. Format: projects/{project}/locations/{location}/backupPlans/{backupPlanId}",
          "type": "string"
        }
      },
      "description": "GCPBackupPlanInfo captures the plan configuration details of Google Cloud resources at the time of backup.",
      "id": "GCPBackupPlanInfo",
      "type": "object"
    },
    "BackupPlan": {
      "description": "A `BackupPlan` specifies some common fields, such as `description` as well as one or more `BackupRule` messages. Each `BackupRule` has a retention policy and defines a schedule by which the system is to perform backup workloads.",
      "properties": {
        "backupVault": {
          "description": "Required. Resource name of backup vault which will be used as storage location for backups. Format: projects/{project}/locations/{location}/backupVaults/{backupvault}",
          "type": "string"
        },
        "name": {
          "description": "Output only. Identifier. The resource name of the `BackupPlan`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`",
          "readOnly": true,
          "type": "string"
        },
        "description": {
          "description": "Optional. The description of the `BackupPlan` resource. The description allows for additional details about `BackupPlan` and its use cases to be provided. An example description is the following: \"This is a backup plan that performs a daily backup at 6pm and retains data for 3 months\". The description must be at most 2048 characters.",
          "type": "string"
        },
        "revisionId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc."
        },
        "computeInstanceBackupPlanProperties": {
          "description": "Optional. Defines optional properties specific to backups of compute instance-based resources, such as Compute Engine. This includes settings like whether to perform a guest flush.",
          "$ref": "ComputeInstanceBackupPlanProperties"
        },
        "state": {
          "enumDescriptions": [
            "State not set.",
            "The resource is being created.",
            "The resource has been created and is fully usable.",
            "The resource is being deleted.",
            "The resource has been created but is not usable.",
            "The resource is being updated."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE",
            "UPDATING"
          ],
          "description": "Output only. The `State` for the `BackupPlan`.",
          "readOnly": true,
          "type": "string"
        },
        "etag": {
          "description": "Optional. `etag` is returned from the service in the response. As a user of the service, you may provide an etag value in this field to prevent stale resources.",
          "type": "string"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. When the `BackupPlan` was created.",
          "format": "google-datetime"
        },
        "diskBackupPlanProperties": {
          "description": "Optional. Defines optional properties specific to backups of disk-based resources, such as Compute Engine Persistent Disks. This includes settings like whether to perform a guest flush.",
          "$ref": "DiskBackupPlanProperties"
        },
        "logRetentionDays": {
          "description": "Optional. Applicable only for Cloud SQL resource_type. Configures how long logs will be stored. It is defined in “days”. This value should be greater than or equal to minimum enforced log retention duration of the backup vault.",
          "format": "int64",
          "type": "string"
        },
        "updateTime": {
          "description": "Output only. When the `BackupPlan` was last updated.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "backupRules": {
          "type": "array",
          "items": {
            "$ref": "BackupRule"
          },
          "description": "Optional. The backup rules for this `BackupPlan`."
        },
        "labels": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. This collection of key/value pairs allows for custom labels to be supplied by the user. Example, {\"tag\": \"Weekly\"}."
        },
        "resourceType": {
          "description": "Required. The resource type to which the `BackupPlan` will be applied. Examples include, \"compute.googleapis.com/Instance\", \"sqladmin.googleapis.com/Instance\", \"alloydb.googleapis.com/Cluster\", \"compute.googleapis.com/Disk\".",
          "type": "string"
        },
        "maxCustomOnDemandRetentionDays": {
          "type": "integer",
          "description": "Optional. Optional field to configure the maximum number of days for which a backup can be retained. This field is only applicable for on-demand backups taken with custom retention value.",
          "format": "int32"
        },
        "supportedResourceTypes": {
          "readOnly": true,
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Output only. All resource types to which backupPlan can be applied."
        },
        "revisionName": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The resource id of the `BackupPlanRevision`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}/revisions/{revision_id}`"
        },
        "backupVaultServiceAccount": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The Google Cloud service account to be used by the BackupVault for taking backups. Specify the email address of the Backup Vault Service Account."
        }
      },
      "id": "BackupPlan",
      "type": "object"
    },
    "StandardSchedule": {
      "id": "StandardSchedule",
      "type": "object",
      "description": "`StandardSchedule` defines a schedule that run within the confines of a defined window of days. We can define recurrence type for schedule as HOURLY, DAILY, WEEKLY, MONTHLY or YEARLY.",
      "properties": {
        "daysOfWeek": {
          "description": "Optional. Specifies days of week like, MONDAY or TUESDAY, on which jobs will run. This is required for `recurrence_type`, `WEEKLY` and is not applicable otherwise. A validation error will occur if a value is supplied and `recurrence_type` is not `WEEKLY`.",
          "type": "array",
          "items": {
            "type": "string",
            "enumDescriptions": [
              "The day of the week is unspecified.",
              "Monday",
              "Tuesday",
              "Wednesday",
              "Thursday",
              "Friday",
              "Saturday",
              "Sunday"
            ],
            "enum": [
              "DAY_OF_WEEK_UNSPECIFIED",
              "MONDAY",
              "TUESDAY",
              "WEDNESDAY",
              "THURSDAY",
              "FRIDAY",
              "SATURDAY",
              "SUNDAY"
            ]
          }
        },
        "hourlyFrequency": {
          "description": "Optional. Specifies frequency for hourly backups. A hourly frequency of 1 means jobs will run every 1 hour from start time till end time defined. This is required for `recurrence_type`, `HOURLY` and is not applicable otherwise. A validation error will occur if a value is supplied and `recurrence_type` is not `HOURLY`. The supported values for each resource type are as follows: * `compute.googleapis.com/Instance`: 4-23 * `compute.googleapis.com/Disk`: 1-23 * `sqladmin.googleapis.com/Instance`: 6-23 * `alloydb.googleapis.com/Cluster`: 1-23 * `file.googleapis.com/Instance`: 1-23 Refer to link https://cloud.google.com/backup-disaster-recovery/docs/concepts/cloud_best_practices for more details.",
          "format": "int32",
          "type": "integer"
        },
        "timeZone": {
          "description": "Required. The time zone to be used when interpreting the schedule. The value of this field must be a time zone name from the IANA tz database. See https://en.wikipedia.org/wiki/List_of_tz_database_time_zones for the list of valid timezone names. For example, Europe/Paris.",
          "type": "string"
        },
        "recurrenceType": {
          "type": "string",
          "enumDescriptions": [
            "recurrence type not set",
            "The `BackupRule` is to be applied hourly.",
            "The `BackupRule` is to be applied daily.",
            "The `BackupRule` is to be applied weekly.",
            "The `BackupRule` is to be applied monthly.",
            "The `BackupRule` is to be applied yearly."
          ],
          "enum": [
            "RECURRENCE_TYPE_UNSPECIFIED",
            "HOURLY",
            "DAILY",
            "WEEKLY",
            "MONTHLY",
            "YEARLY"
          ],
          "description": "Required. Specifies the `RecurrenceType` for the schedule."
        },
        "months": {
          "description": "Optional. Specifies the months of year, like `FEBRUARY` and/or `MAY`, on which jobs will run. This field is only applicable when `recurrence_type` is `YEARLY`. A validation error will occur if other values are supplied.",
          "type": "array",
          "items": {
            "type": "string",
            "enumDescriptions": [
              "The unspecified month.",
              "The month of January.",
              "The month of February.",
              "The month of March.",
              "The month of April.",
              "The month of May.",
              "The month of June.",
              "The month of July.",
              "The month of August.",
              "The month of September.",
              "The month of October.",
              "The month of November.",
              "The month of December."
            ],
            "enum": [
              "MONTH_UNSPECIFIED",
              "JANUARY",
              "FEBRUARY",
              "MARCH",
              "APRIL",
              "MAY",
              "JUNE",
              "JULY",
              "AUGUST",
              "SEPTEMBER",
              "OCTOBER",
              "NOVEMBER",
              "DECEMBER"
            ]
          }
        },
        "backupWindow": {
          "description": "Required. A BackupWindow defines the window of day during which backup jobs will run. Jobs are queued at the beginning of the window and will be marked as `NOT_RUN` if they do not start by the end of the window. Note: running jobs will not be cancelled at the end of the window.",
          "$ref": "BackupWindow"
        },
        "weekDayOfMonth": {
          "description": "Optional. Specifies a week day of the month like, FIRST SUNDAY or LAST MONDAY, on which jobs will run. This will be specified by two fields in `WeekDayOfMonth`, one for the day, e.g. `MONDAY`, and one for the week, e.g. `LAST`. This field is only applicable for `recurrence_type`, `MONTHLY` and `YEARLY`. A validation error will occur if other values are supplied.",
          "$ref": "WeekDayOfMonth"
        },
        "daysOfMonth": {
          "type": "array",
          "items": {
            "type": "integer",
            "format": "int32"
          },
          "description": "Optional. Specifies days of months like 1, 5, or 14 on which jobs will run. Values for `days_of_month` are only applicable for `recurrence_type`, `MONTHLY` and `YEARLY`. A validation error will occur if other values are supplied."
        }
      }
    },
    "DataSourceBackupApplianceApplication": {
      "id": "DataSourceBackupApplianceApplication",
      "type": "object",
      "properties": {
        "backupAppliance": {
          "description": "Appliance name.",
          "type": "string"
        },
        "hostId": {
          "type": "string",
          "description": "Hostid of the application host.",
          "format": "int64"
        },
        "applicationId": {
          "type": "string",
          "description": "The appid field of the application within the Backup Appliance.",
          "format": "int64"
        },
        "applicationName": {
          "description": "The name of the Application as known to the Backup Appliance.",
          "type": "string"
        },
        "hostname": {
          "description": "Hostname of the host where the application is running.",
          "type": "string"
        },
        "type": {
          "description": "The type of the application. e.g. VMBackup",
          "type": "string"
        },
        "applianceId": {
          "description": "Appliance Id of the Backup Appliance.",
          "format": "int64",
          "type": "string"
        }
      },
      "description": "BackupApplianceApplication describes a Source Resource when it is an application backed up by a BackupAppliance."
    },
    "FetchAccessTokenResponse": {
      "id": "FetchAccessTokenResponse",
      "type": "object",
      "properties": {
        "readLocation": {
          "description": "The location in bucket that can be used for reading.",
          "type": "string"
        },
        "writeLocation": {
          "description": "The location in bucket that can be used for writing.",
          "type": "string"
        },
        "token": {
          "description": "The downscoped token that was created.",
          "type": "string"
        },
        "expireTime": {
          "description": "The token is valid until this time.",
          "format": "google-datetime",
          "type": "string"
        }
      },
      "description": "Response message for FetchAccessToken."
    },
    "RestoreBackupResponse": {
      "id": "RestoreBackupResponse",
      "type": "object",
      "description": "Response message for restoring from a Backup.",
      "properties": {
        "targetResource": {
          "description": "Details of the target resource created/modified as part of restore.",
          "$ref": "TargetResource"
        }
      }
    },
    "BackupRule": {
      "description": "`BackupRule` binds the backup schedule to a retention policy.",
      "properties": {
        "ruleId": {
          "description": "Required. Immutable. The unique id of this `BackupRule`. The `rule_id` is unique per `BackupPlan`.The `rule_id` must start with a lowercase letter followed by up to 62 lowercase letters, numbers, or hyphens. Pattern, /a-z{,62}/.",
          "type": "string"
        },
        "backupRetentionDays": {
          "type": "integer",
          "description": "Required. Configures the duration for which backup data will be kept. It is defined in “days”. The value should be greater than or equal to minimum enforced retention of the backup vault. Minimum value is 1 and maximum value is 36159 for custom retention on-demand backup. Minimum and maximum values are workload specific for all other rules. Note: Longer retention can lead to higher storage costs post introductory trial. We recommend starting with a short duration of 3 days or less.",
          "format": "int32"
        },
        "standardSchedule": {
          "description": "Optional. Defines a schedule that runs within the confines of a defined window of time.",
          "$ref": "StandardSchedule"
        }
      },
      "id": "BackupRule",
      "type": "object"
    },
    "OperationMetadata": {
      "properties": {
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time the operation was created.",
          "format": "google-datetime"
        },
        "statusMessage": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Human-readable status of the operation, if any."
        },
        "requestedCancellation": {
          "description": "Output only. Identifies whether the user has requested cancellation of the operation. Operations that have successfully been cancelled have google.longrunning.Operation.error value with a google.rpc.Status.code of 1, corresponding to 'Code.CANCELLED'.",
          "readOnly": true,
          "type": "boolean"
        },
        "endTime": {
          "description": "Output only. The time the operation finished running.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "target": {
          "description": "Output only. Server-defined resource path for the target of the operation.",
          "readOnly": true,
          "type": "string"
        },
        "additionalInfo": {
          "description": "Output only. AdditionalInfo contains additional Info related to backup plan association resource.",
          "additionalProperties": {
            "type": "string"
          },
          "readOnly": true,
          "type": "object"
        },
        "apiVersion": {
          "description": "Output only. API version used to start the operation.",
          "readOnly": true,
          "type": "string"
        },
        "verb": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the verb executed by the operation."
        }
      },
      "description": "Represents the metadata of the long-running operation.",
      "id": "OperationMetadata",
      "type": "object"
    },
    "Operation": {
      "properties": {
        "name": {
          "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.",
          "type": "string"
        },
        "metadata": {
          "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "type": "object"
        },
        "response": {
          "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "done": {
          "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.",
          "type": "boolean"
        },
        "error": {
          "description": "The error result of the operation in case of failure or cancellation.",
          "$ref": "Status"
        }
      },
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "id": "Operation",
      "type": "object"
    },
    "ListResourceBackupConfigsResponse": {
      "id": "ListResourceBackupConfigsResponse",
      "type": "object",
      "properties": {
        "resourceBackupConfigs": {
          "type": "array",
          "items": {
            "$ref": "ResourceBackupConfig"
          },
          "description": "The list of ResourceBackupConfigs for the specified scope."
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "description": "Response for ListResourceBackupConfigs."
    },
    "NetworkPerformanceConfig": {
      "id": "NetworkPerformanceConfig",
      "type": "object",
      "properties": {
        "totalEgressBandwidthTier": {
          "type": "string",
          "enumDescriptions": [
            "This value is unused.",
            "Default network performance config.",
            "Tier 1 network performance config."
          ],
          "enum": [
            "TIER_UNSPECIFIED",
            "DEFAULT",
            "TIER_1"
          ],
          "description": "Optional. The tier of the total egress bandwidth."
        }
      },
      "description": "Network performance configuration."
    },
    "DataSourceBackupConfigInfo": {
      "id": "DataSourceBackupConfigInfo",
      "type": "object",
      "properties": {
        "lastBackupState": {
          "enumDescriptions": [
            "Status not set.",
            "The first backup has not yet completed",
            "The most recent backup was successful",
            "The most recent backup failed",
            "The most recent backup could not be run/failed because of the lack of permissions"
          ],
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "SUCCEEDED",
            "FAILED",
            "PERMISSION_DENIED"
          ],
          "description": "Output only. The status of the last backup in this DataSource",
          "readOnly": true,
          "type": "string"
        },
        "lastSuccessfulBackupConsistencyTime": {
          "description": "Output only. Timestamp of the last successful backup to this DataSource.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "Information of backup configuration on the DataSource."
    },
    "WorkforceIdentityBasedOAuth2ClientID": {
      "properties": {
        "thirdPartyOauth2ClientId": {
          "description": "Output only. Third party OAuth Client ID for External Identity Providers.",
          "readOnly": true,
          "type": "string"
        },
        "firstPartyOauth2ClientId": {
          "description": "Output only. First party OAuth Client ID for Google Identities.",
          "readOnly": true,
          "type": "string"
        }
      },
      "description": "OAuth Client ID depending on the Workforce Identity i.e. either 1p or 3p,",
      "id": "WorkforceIdentityBasedOAuth2ClientID",
      "type": "object"
    },
    "DiskBackupPlanProperties": {
      "description": "Properties for a disk backup plan.",
      "properties": {
        "guestFlush": {
          "description": "Optional. Indicates whether to perform a guest flush operation before taking a disk backup. When set to false, the system will create crash-consistent backups. Default value is false.",
          "type": "boolean"
        }
      },
      "id": "DiskBackupPlanProperties",
      "type": "object"
    },
    "InitiateBackupResponse": {
      "properties": {
        "baseBackupGenerationId": {
          "type": "integer",
          "description": "The generation id of the base backup. It is needed for the incremental backups.",
          "format": "int32"
        },
        "backup": {
          "description": "The name of the backup that was created.",
          "type": "string"
        },
        "newBackupGenerationId": {
          "description": "The generation id of the new backup.",
          "format": "int32",
          "type": "integer"
        }
      },
      "description": "Response message for InitiateBackup.",
      "id": "InitiateBackupResponse",
      "type": "object"
    },
    "DisplayDevice": {
      "description": "A set of Display Device options",
      "properties": {
        "enableDisplay": {
          "description": "Optional. Enables display for the Compute Engine VM",
          "type": "boolean"
        }
      },
      "id": "DisplayDevice",
      "type": "object"
    },
    "SchedulingDuration": {
      "properties": {
        "seconds": {
          "description": "Optional. Span of time at a resolution of a second.",
          "format": "int64",
          "type": "string"
        },
        "nanos": {
          "description": "Optional. Span of time that's a fraction of a second at nanosecond resolution.",
          "format": "int32",
          "type": "integer"
        }
      },
      "description": "A SchedulingDuration represents a fixed-length span of time represented as a count of seconds and fractions of seconds at nanosecond resolution. It is independent of any calendar and concepts like \"day\" or \"month\". Range is approximately 10,000 years.",
      "id": "SchedulingDuration",
      "type": "object"
    },
    "BackupDrPlanRule": {
      "id": "BackupDrPlanRule",
      "type": "object",
      "properties": {
        "ruleId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Unique Id of the backup rule."
        },
        "lastSuccessfulBackupTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Timestamp of the latest successful backup created via this backup rule.",
          "format": "google-datetime"
        }
      },
      "description": "BackupDrPlanRule has rule specific information of the backup plan resource."
    },
    "EncryptionConfig": {
      "properties": {
        "kmsKeyName": {
          "description": "Optional. The Cloud KMS key name to encrypt backups in this backup vault. Must be in the same region as the vault. Some workload backups like compute disk backups may use their inherited source key instead. Format: projects/{project}/locations/{location}/keyRings/{ring}/cryptoKeys/{key}",
          "type": "string"
        }
      },
      "description": "Message describing the EncryptionConfig of backup vault. This determines how data within the vault is encrypted at rest.",
      "id": "EncryptionConfig",
      "type": "object"
    },
    "RestoreBackupRequest": {
      "id": "RestoreBackupRequest",
      "type": "object",
      "description": "Request message for restoring from a Backup.",
      "properties": {
        "requestId": {
          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. The server will guarantee that for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
          "type": "string"
        },
        "computeInstanceTargetEnvironment": {
          "description": "Compute Engine target environment to be used during restore.",
          "$ref": "ComputeInstanceTargetEnvironment"
        },
        "clearOverridesFieldMask": {
          "description": "Optional. A field mask used to clear server-side default values for fields within the `instance_properties` oneof. When a field in this mask is cleared, the server will not apply its default logic (like inheriting a value from the source) for that field. The most common current use case is clearing default encryption keys. Examples of field mask paths: - Compute Instance Disks: `compute_instance_restore_properties.disks.*.disk_encryption_key` - Single Disk: `disk_restore_properties.disk_encryption_key`",
          "format": "google-fieldmask",
          "type": "string"
        },
        "computeInstanceRestoreProperties": {
          "description": "Compute Engine instance properties to be overridden during restore.",
          "$ref": "ComputeInstanceRestoreProperties"
        },
        "diskRestoreProperties": {
          "description": "Disk properties to be overridden during restore.",
          "$ref": "DiskRestoreProperties"
        },
        "diskTargetEnvironment": {
          "description": "Disk target environment to be used during restore.",
          "$ref": "DiskTargetEnvironment"
        },
        "regionDiskTargetEnvironment": {
          "description": "Region disk target environment to be used during restore.",
          "$ref": "RegionDiskTargetEnvironment"
        }
      }
    },
    "WeekDayOfMonth": {
      "properties": {
        "weekOfMonth": {
          "description": "Required. Specifies the week of the month.",
          "type": "string",
          "enumDescriptions": [
            "The zero value. Do not use.",
            "The first week of the month.",
            "The second week of the month.",
            "The third week of the month.",
            "The fourth week of the month.",
            "The last week of the month."
          ],
          "enum": [
            "WEEK_OF_MONTH_UNSPECIFIED",
            "FIRST",
            "SECOND",
            "THIRD",
            "FOURTH",
            "LAST"
          ]
        },
        "dayOfWeek": {
          "description": "Required. Specifies the day of the week.",
          "type": "string",
          "enumDescriptions": [
            "The day of the week is unspecified.",
            "Monday",
            "Tuesday",
            "Wednesday",
            "Thursday",
            "Friday",
            "Saturday",
            "Sunday"
          ],
          "enum": [
            "DAY_OF_WEEK_UNSPECIFIED",
            "MONDAY",
            "TUESDAY",
            "WEDNESDAY",
            "THURSDAY",
            "FRIDAY",
            "SATURDAY",
            "SUNDAY"
          ]
        }
      },
      "description": "`WeekDayOfMonth` defines the week day of the month on which the backups will run. The message combines a `WeekOfMonth` and `DayOfWeek` to produce values like `FIRST`/`MONDAY` or `LAST`/`FRIDAY`.",
      "id": "WeekDayOfMonth",
      "type": "object"
    },
    "BackupConfigDetails": {
      "id": "BackupConfigDetails",
      "type": "object",
      "description": "BackupConfigDetails has information about how the resource is configured for backups and about the most recent backup taken for this configuration.",
      "properties": {
        "backupLocations": {
          "type": "array",
          "items": {
            "$ref": "BackupLocation"
          },
          "description": "The locations where the backups are to be stored."
        },
        "state": {
          "readOnly": true,
          "type": "string",
          "enumDescriptions": [
            "Backup config state not set.",
            "The config is in an active state protecting the resource",
            "The config is currently not protecting the resource. Either because it is disabled or the owning project has been deleted without cleanup of the actual resource.",
            "The config still exists but because of some error state it is not protecting the resource. Like the source project is deleted. For eg. PlanAssociation, BackupPlan is deleted."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "ACTIVE",
            "INACTIVE",
            "ERROR"
          ],
          "description": "Output only. The state of the backup config resource."
        },
        "backupDrTemplateConfig": {
          "description": "Google Cloud Backup and DR's Template specific data.",
          "$ref": "BackupDrTemplateConfig"
        },
        "type": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The type of the backup config resource.",
          "enumDescriptions": [
            "Backup config type is unspecified.",
            "Backup config is Cloud SQL instance's automated backup config.",
            "Backup config is Compute Engine Resource Policy.",
            "Backup config is Google Cloud Backup and DR's Backup Plan.",
            "Backup config is Google Cloud Backup and DR's Template."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "CLOUD_SQL_INSTANCE_BACKUP_CONFIG",
            "COMPUTE_ENGINE_RESOURCE_POLICY",
            "BACKUPDR_BACKUP_PLAN",
            "BACKUPDR_TEMPLATE"
          ]
        },
        "latestSuccessfulBackupTime": {
          "description": "Output only. Timestamp of the latest successful backup created via this backup configuration.",
          "format": "google-datetime",
          "readOnly": true,
          "type": "string"
        },
        "pitrSettings": {
          "readOnly": true,
          "$ref": "PitrSettings",
          "description": "Output only. Point in time recovery settings of the backup configuration resource."
        },
        "backupVault": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format) of the backup vault that will store the backups generated through this backup configuration. Example: \"//backupdr.googleapis.com/v1/projects/{project}/locations/{region}/backupVaults/{backupvaultId}\""
        },
        "backupDrPlanConfig": {
          "description": "Google Cloud Backup and DR's Backup Plan specific data.",
          "$ref": "BackupDrPlanConfig"
        },
        "applicableResource": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format) of the resource that is applicable for the backup configuration. Example: \"//compute.googleapis.com/projects/{project}/zones/{zone}/instances/{instance}\""
        },
        "backupConfigSource": {
          "description": "Output only. The full resource name of the backup config source resource. For example, \"//backupdr.googleapis.com/v1/projects/{project}/locations/{region}/backupPlans/{backupplanId}\" or \"//compute.googleapis.com/projects/{project}/locations/{region}/resourcePolicies/{resourcePolicyId}\".",
          "readOnly": true,
          "type": "string"
        },
        "backupConfigSourceDisplayName": {
          "description": "Output only. The display name of the backup config source resource.",
          "readOnly": true,
          "type": "string"
        }
      }
    }
  },
  "documentationLink": "https://cloud.google.com/backup-disaster-recovery",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/cloud-platform": {
          "description": "See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account."
        }
      }
    }
  }
}
