{
  "id": "backupdr:v1",
  "documentationLink": "https://cloud.google.com/backup-disaster-recovery",
  "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"
    },
    {
      "location": "asia-east2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-east2.rep.googleapis.com/"
    },
    {
      "location": "asia-northeast1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-northeast1.rep.googleapis.com/"
    },
    {
      "location": "asia-northeast2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-northeast2.rep.googleapis.com/"
    },
    {
      "location": "asia-northeast3",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-northeast3.rep.googleapis.com/"
    },
    {
      "location": "asia-south1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.asia-south1.rep.googleapis.com/"
    },
    {
      "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",
      "description": "Regional Endpoint"
    },
    {
      "location": "australia-southeast1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.australia-southeast1.rep.googleapis.com/"
    },
    {
      "location": "australia-southeast2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.australia-southeast2.rep.googleapis.com/"
    },
    {
      "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"
    },
    {
      "location": "europe-north2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.europe-north2.rep.googleapis.com/"
    },
    {
      "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"
    },
    {
      "location": "europe-west2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.europe-west2.rep.googleapis.com/"
    },
    {
      "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"
    },
    {
      "endpointUrl": "https://backupdr.europe-west6.rep.googleapis.com/",
      "location": "europe-west6",
      "description": "Regional Endpoint"
    },
    {
      "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"
    },
    {
      "location": "europe-west10",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.europe-west10.rep.googleapis.com/"
    },
    {
      "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"
    },
    {
      "location": "me-central2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.me-central2.rep.googleapis.com/"
    },
    {
      "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",
      "description": "Regional Endpoint"
    },
    {
      "location": "northamerica-northeast2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.northamerica-northeast2.rep.googleapis.com/"
    },
    {
      "location": "northamerica-south1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.northamerica-south1.rep.googleapis.com/"
    },
    {
      "location": "southamerica-east1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.southamerica-east1.rep.googleapis.com/"
    },
    {
      "location": "southamerica-west1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.southamerica-west1.rep.googleapis.com/"
    },
    {
      "endpointUrl": "https://backupdr.us-central1.rep.googleapis.com/",
      "location": "us-central1",
      "description": "Regional Endpoint"
    },
    {
      "location": "us-central2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-central2.rep.googleapis.com/"
    },
    {
      "location": "us-east1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east1.rep.googleapis.com/"
    },
    {
      "location": "us-east4",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east4.rep.googleapis.com/"
    },
    {
      "location": "us-east5",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east5.rep.googleapis.com/"
    },
    {
      "location": "us-east7",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-east7.rep.googleapis.com/"
    },
    {
      "endpointUrl": "https://backupdr.us-south1.rep.googleapis.com/",
      "location": "us-south1",
      "description": "Regional Endpoint"
    },
    {
      "location": "us-west1",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-west1.rep.googleapis.com/"
    },
    {
      "location": "us-west2",
      "description": "Regional Endpoint",
      "endpointUrl": "https://backupdr.us-west2.rep.googleapis.com/"
    },
    {
      "endpointUrl": "https://backupdr.us-west3.rep.googleapis.com/",
      "location": "us-west3",
      "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",
      "description": "Regional Endpoint"
    }
  ],
  "description": "",
  "resources": {
    "projects": {
      "resources": {
        "locations": {
          "methods": {
            "list": {
              "parameters": {
                "name": {
                  "description": "The resource that owns the locations collection, if applicable.",
                  "pattern": "^projects/[^/]+$",
                  "location": "path",
                  "required": true,
                  "type": "string"
                },
                "filter": {
                  "type": "string",
                  "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).",
                  "location": "query"
                },
                "pageSize": {
                  "description": "The maximum number of results to return. If not set, the service selects a default.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                },
                "pageToken": {
                  "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.",
                  "location": "query",
                  "type": "string"
                },
                "extraLocationTypes": {
                  "repeated": true,
                  "type": "string",
                  "description": "Optional. Do not use this field. It is unsupported and is ignored unless explicitly documented otherwise. This is primarily for internal usage.",
                  "location": "query"
                }
              },
              "response": {
                "$ref": "ListLocationsResponse"
              },
              "httpMethod": "GET",
              "path": "v1/{+name}/locations",
              "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.",
              "flatPath": "v1/projects/{projectsId}/locations",
              "id": "backupdr.projects.locations.list",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ]
            },
            "get": {
              "parameters": {
                "name": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Resource name for the location.",
                  "pattern": "^projects/[^/]+/locations/[^/]+$"
                }
              },
              "response": {
                "$ref": "Location"
              },
              "httpMethod": "GET",
              "path": "v1/{+name}",
              "parameterOrder": [
                "name"
              ],
              "description": "Gets information about a location.",
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}",
              "id": "backupdr.projects.locations.get",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ]
            },
            "getTrial": {
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial",
              "id": "backupdr.projects.locations.getTrial",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "parameters": {
                "name": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "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$"
                }
              },
              "response": {
                "$ref": "Trial"
              },
              "httpMethod": "GET",
              "path": "v1/{+name}",
              "parameterOrder": [
                "name"
              ],
              "description": "Gets the Trial state for a given project"
            }
          },
          "resources": {
            "managementServers": {
              "methods": {
                "get": {
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single ManagementServer.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ManagementServer"
                  },
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. Name of the management server resource name, in the format 'projects/{project_id}/locations/{location}/managementServers/{resource_name}'",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$"
                    }
                  },
                  "id": "backupdr.projects.locations.managementServers.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}"
                },
                "delete": {
                  "id": "backupdr.projects.locations.managementServers.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}",
                  "httpMethod": "DELETE",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a single ManagementServer.",
                  "parameters": {
                    "name": {
                      "description": "Required. Name of the resource",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$",
                      "location": "path",
                      "required": 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. 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",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "testIamPermissions": {
                  "id": "backupdr.projects.locations.managementServers.testIamPermissions",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "request": {
                    "$ref": "TestIamPermissionsRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:testIamPermissions",
                  "path": "v1/{+resource}:testIamPermissions",
                  "parameterOrder": [
                    "resource"
                  ],
                  "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.",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "TestIamPermissionsResponse"
                  },
                  "parameters": {
                    "resource": {
                      "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/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  }
                },
                "create": {
                  "path": "v1/{+parent}/managementServers",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Creates a new ManagementServer in a given project and location.",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "managementServerId": {
                      "description": "Required. The name of the management server to create. The name must be unique for the specified project and location.",
                      "location": "query",
                      "type": "string"
                    },
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "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**.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "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"
                    }
                  },
                  "id": "backupdr.projects.locations.managementServers.create",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers",
                  "request": {
                    "$ref": "ManagementServer"
                  }
                },
                "msComplianceMetadata": {
                  "httpMethod": "POST",
                  "path": "v1/{+parent}:msComplianceMetadata",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Returns the Assured Workloads compliance metadata for a given project.",
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "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**.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers$"
                    }
                  },
                  "response": {
                    "$ref": "FetchMsComplianceMetadataResponse"
                  },
                  "id": "backupdr.projects.locations.managementServers.msComplianceMetadata",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers:msComplianceMetadata",
                  "request": {
                    "$ref": "FetchMsComplianceMetadataRequest"
                  }
                },
                "setIamPolicy": {
                  "parameters": {
                    "resource": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "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.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/managementServers/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "Policy"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+resource}:setIamPolicy",
                  "parameterOrder": [
                    "resource"
                  ],
                  "description": "Sets the access control policy on the specified resource. Replaces any existing policy. Can return `NOT_FOUND`, `INVALID_ARGUMENT`, and `PERMISSION_DENIED` errors.",
                  "request": {
                    "$ref": "SetIamPolicyRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:setIamPolicy",
                  "id": "backupdr.projects.locations.managementServers.setIamPolicy",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "getIamPolicy": {
                  "id": "backupdr.projects.locations.managementServers.getIamPolicy",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers/{managementServersId}:getIamPolicy",
                  "httpMethod": "GET",
                  "path": "v1/{+resource}: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.",
                  "parameters": {
                    "resource": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "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/[^/]+$"
                    },
                    "options.requestedPolicyVersion": {
                      "format": "int32",
                      "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).",
                      "location": "query",
                      "type": "integer"
                    }
                  },
                  "response": {
                    "$ref": "Policy"
                  }
                },
                "list": {
                  "path": "v1/{+parent}/managementServers",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists ManagementServers in a given project and location.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListManagementServersResponse"
                  },
                  "parameters": {
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query"
                    },
                    "filter": {
                      "description": "Optional. Filtering results.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "format": "int32",
                      "type": "integer",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "location": "query"
                    },
                    "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 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.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "id": "backupdr.projects.locations.managementServers.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/managementServers"
                }
              }
            },
            "resourceBackupConfigs": {
              "methods": {
                "list": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/resourceBackupConfigs",
                  "id": "backupdr.projects.locations.resourceBackupConfigs.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "ListResourceBackupConfigsResponse"
                  },
                  "parameters": {
                    "filter": {
                      "type": "string",
                      "description": "Optional. Filtering results.",
                      "location": "query"
                    },
                    "pageSize": {
                      "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.",
                      "location": "query",
                      "type": "integer",
                      "format": "int32"
                    },
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query"
                    },
                    "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/[^/]+$"
                    },
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    }
                  },
                  "path": "v1/{+parent}/resourceBackupConfigs",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists ResourceBackupConfigs.",
                  "httpMethod": "GET"
                }
              }
            },
            "backupPlans": {
              "methods": {
                "get": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "id": "backupdr.projects.locations.backupPlans.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "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/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "BackupPlan"
                  },
                  "httpMethod": "GET",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single BackupPlan."
                },
                "delete": {
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. The resource name of the `BackupPlan` to delete. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlans/[^/]+$"
                    },
                    "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).",
                      "location": "query",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  },
                  "httpMethod": "DELETE",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a single BackupPlan.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "id": "backupdr.projects.locations.backupPlans.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "create": {
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "backupPlanId": {
                      "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",
                      "type": "string"
                    },
                    "parent": {
                      "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/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "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"
                    }
                  },
                  "path": "v1/{+parent}/backupPlans",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Create a BackupPlan",
                  "httpMethod": "POST",
                  "request": {
                    "$ref": "BackupPlan"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans",
                  "id": "backupdr.projects.locations.backupPlans.create",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "patch": {
                  "id": "backupdr.projects.locations.backupPlans.patch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "request": {
                    "$ref": "BackupPlan"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Update a BackupPlan.",
                  "httpMethod": "PATCH",
                  "response": {
                    "$ref": "Operation"
                  },
                  "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"
                    },
                    "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"
                    },
                    "updateMask": {
                      "format": "google-fieldmask",
                      "type": "string",
                      "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.",
                      "location": "query"
                    }
                  }
                },
                "list": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans",
                  "id": "backupdr.projects.locations.backupPlans.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "pageToken": {
                      "type": "string",
                      "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"
                    },
                    "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/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "orderBy": {
                      "description": "Optional. Field by which to sort the results.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "format": "int32",
                      "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.",
                      "location": "query",
                      "type": "integer"
                    },
                    "filter": {
                      "type": "string",
                      "description": "Optional. Field match expression used to filter the results.",
                      "location": "query"
                    }
                  },
                  "response": {
                    "$ref": "ListBackupPlansResponse"
                  },
                  "httpMethod": "GET",
                  "path": "v1/{+parent}/backupPlans",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists BackupPlans in a given project and location."
                }
              },
              "resources": {
                "revisions": {
                  "methods": {
                    "list": {
                      "id": "backupdr.projects.locations.backupPlans.revisions.list",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}/revisions",
                      "httpMethod": "GET",
                      "path": "v1/{+parent}/revisions",
                      "parameterOrder": [
                        "parent"
                      ],
                      "description": "Lists BackupPlanRevisions in a given project and location.",
                      "parameters": {
                        "pageToken": {
                          "type": "string",
                          "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"
                        },
                        "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/[^/]+$"
                        },
                        "pageSize": {
                          "format": "int32",
                          "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.",
                          "location": "query"
                        }
                      },
                      "response": {
                        "$ref": "ListBackupPlanRevisionsResponse"
                      }
                    },
                    "get": {
                      "response": {
                        "$ref": "BackupPlanRevision"
                      },
                      "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/[^/]+$"
                        }
                      },
                      "path": "v1/{+name}",
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Gets details of a single BackupPlanRevision.",
                      "httpMethod": "GET",
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlans/{backupPlansId}/revisions/{revisionsId}",
                      "id": "backupdr.projects.locations.backupPlans.revisions.get",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    }
                  }
                }
              }
            },
            "serviceConfig": {
              "methods": {
                "initialize": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/serviceConfig:initialize",
                  "request": {
                    "$ref": "InitializeServiceRequest"
                  },
                  "id": "backupdr.projects.locations.serviceConfig.initialize",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "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`.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/serviceConfig$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+name}:initialize",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Initializes the service related config for a project."
                }
              }
            },
            "trial": {
              "methods": {
                "end": {
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The parent resource where the trial has been created. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "Trial"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+parent}/trial:end",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Ends the trial for a project",
                  "request": {
                    "$ref": "EndTrialRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial:end",
                  "id": "backupdr.projects.locations.trial.end",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "subscribe": {
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. The project where this trial will be created. Format: projects/{project}/locations/{location} Supported Locations are - us, eu and asia.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "Trial"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+parent}/trial:subscribe",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Subscribes to a trial for a project",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/trial:subscribe",
                  "request": {
                    "$ref": "SubscribeTrialRequest"
                  },
                  "id": "backupdr.projects.locations.trial.subscribe",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            },
            "operations": {
              "methods": {
                "list": {
                  "id": "backupdr.projects.locations.operations.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations",
                  "path": "v1/{+name}/operations",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListOperationsResponse"
                  },
                  "parameters": {
                    "pageSize": {
                      "type": "integer",
                      "description": "The standard list page size.",
                      "location": "query",
                      "format": "int32"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "The name of the operation's parent resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "filter": {
                      "description": "The standard list filter.",
                      "location": "query",
                      "type": "string"
                    },
                    "returnPartialSuccess": {
                      "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.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "pageToken": {
                      "description": "The standard list page token.",
                      "location": "query",
                      "type": "string"
                    }
                  }
                },
                "cancel": {
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource to be cancelled.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "Empty"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+name}:cancel",
                  "parameterOrder": [
                    "name"
                  ],
                  "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`.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}:cancel",
                  "request": {
                    "$ref": "CancelOperationRequest"
                  },
                  "id": "backupdr.projects.locations.operations.cancel",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "get": {
                  "path": "v1/{+name}",
                  "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.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "id": "backupdr.projects.locations.operations.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}"
                },
                "delete": {
                  "id": "backupdr.projects.locations.operations.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "httpMethod": "DELETE",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "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`.",
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource to be deleted.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "Empty"
                  }
                }
              }
            },
            "dataSourceReferences": {
              "methods": {
                "get": {
                  "httpMethod": "GET",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single DataSourceReference.",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The name of the DataSourceReference to retrieve. Format: projects/{project}/locations/{location}/dataSourceReferences/{data_source_reference}",
                      "pattern": "^projects/[^/]+/locations/[^/]+/dataSourceReferences/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "DataSourceReference"
                  },
                  "id": "backupdr.projects.locations.dataSourceReferences.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences/{dataSourceReferencesId}"
                },
                "fetchForResourceType": {
                  "parameters": {
                    "parent": {
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "resourceType": {
                      "type": "string",
                      "description": "Required. The type of the Google Cloud resource. Ex: sql.googleapis.com/Instance",
                      "location": "query"
                    },
                    "pageToken": {
                      "type": "string",
                      "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.",
                      "location": "query"
                    },
                    "pageSize": {
                      "format": "int32",
                      "type": "integer",
                      "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.",
                      "location": "query"
                    },
                    "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: * 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",
                      "location": "query",
                      "type": "string"
                    },
                    "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"
                    }
                  },
                  "response": {
                    "$ref": "FetchDataSourceReferencesForResourceTypeResponse"
                  },
                  "httpMethod": "GET",
                  "path": "v1/{+parent}/dataSourceReferences:fetchForResourceType",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Fetch DataSourceReferences for a given project, location and resource type.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences:fetchForResourceType",
                  "id": "backupdr.projects.locations.dataSourceReferences.fetchForResourceType",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "list": {
                  "path": "v1/{+parent}/dataSourceReferences",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists DataSourceReferences for a given project and location.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "ListDataSourceReferencesResponse"
                  },
                  "parameters": {
                    "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: * data_source * data_source_gcp_resource_info.gcp_resourcename",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "format": "int32",
                      "type": "integer",
                      "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.",
                      "location": "query"
                    },
                    "filter": {
                      "type": "string",
                      "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"
                    },
                    "pageToken": {
                      "type": "string",
                      "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"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    }
                  },
                  "id": "backupdr.projects.locations.dataSourceReferences.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/dataSourceReferences"
                }
              }
            },
            "backupVaults": {
              "methods": {
                "list": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults",
                  "id": "backupdr.projects.locations.backupVaults.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "ListBackupVaultsResponse"
                  },
                  "parameters": {
                    "filter": {
                      "type": "string",
                      "description": "Optional. Filtering results.",
                      "location": "query"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "location": "query",
                      "type": "integer",
                      "format": "int32"
                    },
                    "view": {
                      "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup Vault.",
                      "enum": [
                        "BACKUP_VAULT_VIEW_UNSPECIFIED",
                        "BACKUP_VAULT_VIEW_BASIC",
                        "BACKUP_VAULT_VIEW_FULL"
                      ],
                      "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)."
                      ],
                      "type": "string",
                      "location": "query"
                    },
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query"
                    },
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "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.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "type": "string",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query"
                    }
                  },
                  "path": "v1/{+parent}/backupVaults",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists BackupVaults in a given project and location.",
                  "httpMethod": "GET"
                },
                "fetchUsable": {
                  "id": "backupdr.projects.locations.backupVaults.fetchUsable",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults:fetchUsable",
                  "path": "v1/{+parent}/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.",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "FetchUsableBackupVaultsResponse"
                  },
                  "parameters": {
                    "filter": {
                      "description": "Optional. Filtering results.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "location": "query",
                      "type": "integer",
                      "format": "int32"
                    },
                    "orderBy": {
                      "type": "string",
                      "description": "Optional. Hint for how to order the results.",
                      "location": "query"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "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.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query",
                      "type": "string"
                    }
                  }
                },
                "create": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults",
                  "request": {
                    "$ref": "BackupVault"
                  },
                  "id": "backupdr.projects.locations.backupVaults.create",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "backupVaultId": {
                      "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",
                      "location": "query",
                      "type": "string"
                    },
                    "validateOnly": {
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "parent": {
                      "description": "Required. Value for parent.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": 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 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",
                      "type": "string"
                    }
                  },
                  "path": "v1/{+parent}/backupVaults",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Creates a new BackupVault in a given project and location.",
                  "httpMethod": "POST"
                },
                "patch": {
                  "httpMethod": "PATCH",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Updates the settings of a BackupVault.",
                  "parameters": {
                    "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.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "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"
                    },
                    "validateOnly": {
                      "type": "boolean",
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "location": "query"
                    },
                    "force": {
                      "description": "Optional. If set to true, will not check plan duration against backup vault enforcement duration.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "forceUpdateAccessRestriction": {
                      "type": "boolean",
                      "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'.",
                      "location": "query"
                    },
                    "updateMask": {
                      "format": "google-fieldmask",
                      "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.",
                      "location": "query"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "backupdr.projects.locations.backupVaults.patch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "request": {
                    "$ref": "BackupVault"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}"
                },
                "testIamPermissions": {
                  "request": {
                    "$ref": "TestIamPermissionsRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}:testIamPermissions",
                  "id": "backupdr.projects.locations.backupVaults.testIamPermissions",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "TestIamPermissionsResponse"
                  },
                  "parameters": {
                    "resource": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "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/[^/]+/backupVaults/[^/]+$"
                    }
                  },
                  "path": "v1/{+resource}:testIamPermissions",
                  "parameterOrder": [
                    "resource"
                  ],
                  "description": "Returns the caller's permissions on a BackupVault resource. A caller is not required to have Google IAM permission to make this request.",
                  "httpMethod": "POST"
                },
                "get": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}",
                  "id": "backupdr.projects.locations.backupVaults.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. Name of the backupvault store resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{resource_name}'",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$"
                    },
                    "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)."
                      ],
                      "location": "query",
                      "type": "string",
                      "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup Vault",
                      "enum": [
                        "BACKUP_VAULT_VIEW_UNSPECIFIED",
                        "BACKUP_VAULT_VIEW_BASIC",
                        "BACKUP_VAULT_VIEW_FULL"
                      ]
                    }
                  },
                  "response": {
                    "$ref": "BackupVault"
                  },
                  "httpMethod": "GET",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a BackupVault."
                },
                "delete": {
                  "httpMethod": "DELETE",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a BackupVault.",
                  "parameters": {
                    "allowMissing": {
                      "description": "Optional. If true and the BackupVault is not found, the request will succeed but no action will be taken.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "force": {
                      "description": "Optional. If set to true, any data source from this backup vault will also be deleted.",
                      "location": "query",
                      "type": "boolean"
                    },
                    "etag": {
                      "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.",
                      "location": "query",
                      "type": "string"
                    },
                    "validateOnly": {
                      "type": "boolean",
                      "description": "Optional. Only validate the request, but do not perform mutations. The default is 'false'.",
                      "location": "query"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. Name of the resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+$"
                    },
                    "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 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).",
                      "location": "query"
                    },
                    "ignoreBackupPlanReferences": {
                      "description": "Optional. If set to true, backupvault deletion will proceed even if there are backup plans referencing the backupvault. The default is 'false'.",
                      "location": "query",
                      "type": "boolean"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "backupdr.projects.locations.backupVaults.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}"
                }
              },
              "resources": {
                "dataSources": {
                  "methods": {
                    "get": {
                      "id": "backupdr.projects.locations.backupVaults.dataSources.get",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}",
                      "httpMethod": "GET",
                      "path": "v1/{+name}",
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Gets details of a DataSource.",
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the data source resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{resource_name}/dataSource/{resource_name}'",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        }
                      },
                      "response": {
                        "$ref": "DataSource"
                      }
                    },
                    "list": {
                      "httpMethod": "GET",
                      "path": "v1/{+parent}/dataSources",
                      "parameterOrder": [
                        "parent"
                      ],
                      "description": "Lists DataSources in a given project and location.",
                      "parameters": {
                        "pageToken": {
                          "type": "string",
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "location": "query"
                        },
                        "parent": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "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/[^/]+$"
                        },
                        "orderBy": {
                          "description": "Optional. Hint for how to order the results.",
                          "location": "query",
                          "type": "string"
                        },
                        "pageSize": {
                          "type": "integer",
                          "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                          "location": "query",
                          "format": "int32"
                        },
                        "filter": {
                          "description": "Optional. Filtering results.",
                          "location": "query",
                          "type": "string"
                        }
                      },
                      "response": {
                        "$ref": "ListDataSourcesResponse"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.list",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources"
                    },
                    "patch": {
                      "request": {
                        "$ref": "DataSource"
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}",
                      "id": "backupdr.projects.locations.backupVaults.dataSources.patch",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "updateMask": {
                          "format": "google-fieldmask",
                          "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.",
                          "location": "query",
                          "type": "string"
                        },
                        "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/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "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).",
                          "location": "query",
                          "type": "string"
                        },
                        "allowMissing": {
                          "type": "boolean",
                          "description": "Optional. Enable upsert.",
                          "location": "query"
                        }
                      },
                      "path": "v1/{+name}",
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Updates the settings of a DataSource.",
                      "httpMethod": "PATCH"
                    },
                    "fetchAccessToken": {
                      "response": {
                        "$ref": "FetchAccessTokenResponse"
                      },
                      "parameters": {
                        "name": {
                          "description": "Required. The resource name for the location for which static IPs should be returned. Must be in the format 'projects/*/locations/*/backupVaults/*/dataSources'.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "path": "v1/{+name}:fetchAccessToken",
                      "parameterOrder": [
                        "name"
                      ],
                      "description": "Internal only. Fetch access token for a given data source.",
                      "httpMethod": "POST",
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:fetchAccessToken",
                      "request": {
                        "$ref": "FetchAccessTokenRequest"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.fetchAccessToken",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    },
                    "remove": {
                      "id": "backupdr.projects.locations.backupVaults.dataSources.remove",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:remove",
                      "request": {
                        "$ref": "RemoveDataSourceRequest"
                      },
                      "path": "v1/{+name}:remove",
                      "parameterOrder": [
                        "name"
                      ],
                      "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.",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the resource.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      }
                    },
                    "abandonBackup": {
                      "httpMethod": "POST",
                      "path": "v1/{+dataSource}:abandonBackup",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Internal only. Abandons a backup.",
                      "parameters": {
                        "dataSource": {
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "response": {
                        "$ref": "Operation"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.abandonBackup",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "request": {
                        "$ref": "AbandonBackupRequest"
                      },
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:abandonBackup"
                    },
                    "setInternalStatus": {
                      "httpMethod": "POST",
                      "path": "v1/{+dataSource}:setInternalStatus",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Sets the internal status of a DataSource.",
                      "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/[^/]+$"
                        }
                      },
                      "response": {
                        "$ref": "Operation"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.setInternalStatus",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:setInternalStatus",
                      "request": {
                        "$ref": "SetInternalStatusRequest"
                      }
                    },
                    "initiateBackup": {
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:initiateBackup",
                      "request": {
                        "$ref": "InitiateBackupRequest"
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.initiateBackup",
                      "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/[^/]+$"
                        }
                      },
                      "response": {
                        "$ref": "InitiateBackupResponse"
                      },
                      "httpMethod": "POST",
                      "path": "v1/{+dataSource}:initiateBackup",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Internal only. Initiates a backup."
                    },
                    "finalizeBackup": {
                      "path": "v1/{+dataSource}:finalizeBackup",
                      "parameterOrder": [
                        "dataSource"
                      ],
                      "description": "Internal only. Finalize a backup that was started by a call to InitiateBackup.",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "dataSource": {
                          "description": "Required. The resource name of the instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/'.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "backupdr.projects.locations.backupVaults.dataSources.finalizeBackup",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}:finalizeBackup",
                      "request": {
                        "$ref": "FinalizeBackupRequest"
                      }
                    }
                  },
                  "resources": {
                    "backups": {
                      "methods": {
                        "list": {
                          "response": {
                            "$ref": "ListBackupsResponse"
                          },
                          "parameters": {
                            "view": {
                              "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup resource.",
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ],
                              "location": "query",
                              "type": "string",
                              "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)."
                              ]
                            },
                            "orderBy": {
                              "type": "string",
                              "description": "Optional. Hint for how to order the results.",
                              "location": "query"
                            },
                            "filter": {
                              "description": "Optional. Filtering results.",
                              "location": "query",
                              "type": "string"
                            },
                            "pageSize": {
                              "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                              "location": "query",
                              "type": "integer",
                              "format": "int32"
                            },
                            "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 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/[^/]+/dataSources/[^/]+$",
                              "location": "path",
                              "required": true,
                              "type": "string"
                            }
                          },
                          "path": "v1/{+parent}/backups",
                          "parameterOrder": [
                            "parent"
                          ],
                          "description": "Lists Backups in a given project and location.",
                          "httpMethod": "GET",
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups",
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.list",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ]
                        },
                        "fetchForResourceType": {
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.fetchForResourceType",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups:fetchForResourceType",
                          "path": "v1/{+parent}/backups:fetchForResourceType",
                          "parameterOrder": [
                            "parent"
                          ],
                          "description": "Fetch Backups for a given resource type.",
                          "httpMethod": "GET",
                          "response": {
                            "$ref": "FetchBackupsForResourceTypeResponse"
                          },
                          "parameters": {
                            "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: * 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"
                            },
                            "pageSize": {
                              "format": "int32",
                              "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.",
                              "location": "query",
                              "type": "integer"
                            },
                            "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)."
                              ],
                              "type": "string",
                              "location": "query",
                              "description": "Optional. This parameter is used to specify the view of the backup. If not specified, the default view is BASIC.",
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ]
                            },
                            "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"
                            },
                            "parent": {
                              "location": "path",
                              "required": true,
                              "type": "string",
                              "description": "Required. Datasources are the parent resource for the backups. Format: projects/{project}/locations/{location}/backupVaults/{backupVaultId}/dataSources/{datasourceId}",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+$"
                            },
                            "pageToken": {
                              "type": "string",
                              "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.",
                              "location": "query"
                            },
                            "resourceType": {
                              "description": "Required. The type of the Google Cloud resource. Ex: sqladmin.googleapis.com/Instance",
                              "location": "query",
                              "type": "string"
                            }
                          }
                        },
                        "get": {
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.get",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "path": "v1/{+name}",
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Gets details of a Backup.",
                          "httpMethod": "GET",
                          "response": {
                            "$ref": "Backup"
                          },
                          "parameters": {
                            "name": {
                              "location": "path",
                              "required": true,
                              "type": "string",
                              "description": "Required. Name of the data source resource name, in the format 'projects/{project_id}/locations/{location}/backupVaults/{backupVault}/dataSources/{datasource}/backups/{backup}'",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$"
                            },
                            "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)."
                              ],
                              "type": "string",
                              "location": "query",
                              "description": "Optional. Reserved for future use to provide a BASIC & FULL view of Backup resource.",
                              "enum": [
                                "BACKUP_VIEW_UNSPECIFIED",
                                "BACKUP_VIEW_BASIC",
                                "BACKUP_VIEW_FULL"
                              ]
                            }
                          }
                        },
                        "delete": {
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.delete",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "parameters": {
                            "name": {
                              "description": "Required. Name of the resource.",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$",
                              "type": "string",
                              "location": "path",
                              "required": true
                            },
                            "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).",
                              "location": "query",
                              "type": "string"
                            }
                          },
                          "response": {
                            "$ref": "Operation"
                          },
                          "httpMethod": "DELETE",
                          "path": "v1/{+name}",
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Deletes a Backup."
                        },
                        "patch": {
                          "parameters": {
                            "updateMask": {
                              "format": "google-fieldmask",
                              "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.",
                              "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"
                            },
                            "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"
                            }
                          },
                          "response": {
                            "$ref": "Operation"
                          },
                          "httpMethod": "PATCH",
                          "path": "v1/{+name}",
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Updates the settings of a Backup.",
                          "request": {
                            "$ref": "Backup"
                          },
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}",
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.patch",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ]
                        },
                        "restore": {
                          "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupVaults/{backupVaultsId}/dataSources/{dataSourcesId}/backups/{backupsId}:restore",
                          "request": {
                            "$ref": "RestoreBackupRequest"
                          },
                          "id": "backupdr.projects.locations.backupVaults.dataSources.backups.restore",
                          "scopes": [
                            "https://www.googleapis.com/auth/cloud-platform"
                          ],
                          "parameters": {
                            "name": {
                              "location": "path",
                              "required": true,
                              "type": "string",
                              "description": "Required. The resource name of the Backup instance, in the format 'projects/*/locations/*/backupVaults/*/dataSources/*/backups/'.",
                              "pattern": "^projects/[^/]+/locations/[^/]+/backupVaults/[^/]+/dataSources/[^/]+/backups/[^/]+$"
                            }
                          },
                          "response": {
                            "$ref": "Operation"
                          },
                          "httpMethod": "POST",
                          "path": "v1/{+name}:restore",
                          "parameterOrder": [
                            "name"
                          ],
                          "description": "Restore from a Backup"
                        }
                      }
                    }
                  }
                }
              }
            },
            "backupPlanAssociations": {
              "methods": {
                "triggerBackup": {
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$"
                    }
                  },
                  "path": "v1/{+name}:triggerBackup",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Triggers a new Backup.",
                  "httpMethod": "POST",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}:triggerBackup",
                  "request": {
                    "$ref": "TriggerBackupRequest"
                  },
                  "id": "backupdr.projects.locations.backupPlanAssociations.triggerBackup",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "list": {
                  "response": {
                    "$ref": "ListBackupPlanAssociationsResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "type": "integer",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, server will pick an appropriate default.",
                      "location": "query",
                      "format": "int32"
                    },
                    "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": {
                      "description": "Optional. Filtering results",
                      "location": "query",
                      "type": "string"
                    }
                  },
                  "path": "v1/{+parent}/backupPlanAssociations",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists BackupPlanAssociations in a given project and location.",
                  "httpMethod": "GET",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations",
                  "id": "backupdr.projects.locations.backupPlanAssociations.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "get": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "id": "backupdr.projects.locations.backupPlanAssociations.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "BackupPlanAssociation"
                  },
                  "httpMethod": "GET",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Gets details of a single BackupPlanAssociation."
                },
                "fetchForResourceType": {
                  "httpMethod": "GET",
                  "path": "v1/{+parent}/backupPlanAssociations:fetchForResourceType",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "List BackupPlanAssociations for a given resource type.",
                  "parameters": {
                    "parent": {
                      "description": "Required. The parent resource name. Format: projects/{project}/locations/{location}",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "pageToken": {
                      "type": "string",
                      "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.",
                      "location": "query"
                    },
                    "resourceType": {
                      "type": "string",
                      "description": "Required. The type of the Google Cloud resource. Ex: sql.googleapis.com/Instance",
                      "location": "query"
                    },
                    "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: * resource * backup_plan * state * data_source * cloud_sql_instance_backup_plan_association_properties.instance_create_time",
                      "location": "query",
                      "type": "string"
                    },
                    "pageSize": {
                      "format": "int32",
                      "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.",
                      "location": "query",
                      "type": "integer"
                    },
                    "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"
                    }
                  },
                  "response": {
                    "$ref": "FetchBackupPlanAssociationsForResourceTypeResponse"
                  },
                  "id": "backupdr.projects.locations.backupPlanAssociations.fetchForResourceType",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations:fetchForResourceType"
                },
                "delete": {
                  "id": "backupdr.projects.locations.backupPlanAssociations.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "httpMethod": "DELETE",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a single BackupPlanAssociation.",
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Required. Name of the backup plan association resource, in the format `projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$"
                    },
                    "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).",
                      "location": "query",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "create": {
                  "parameters": {
                    "parent": {
                      "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**.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "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"
                    },
                    "backupPlanAssociationId": {
                      "type": "string",
                      "description": "Required. The name of the backup plan association to create. The name must be unique for the specified project and location.",
                      "location": "query"
                    }
                  },
                  "response": {
                    "$ref": "Operation"
                  },
                  "httpMethod": "POST",
                  "path": "v1/{+parent}/backupPlanAssociations",
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Create a BackupPlanAssociation",
                  "request": {
                    "$ref": "BackupPlanAssociation"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations",
                  "id": "backupdr.projects.locations.backupPlanAssociations.create",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "patch": {
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "updateMask": {
                      "format": "google-fieldmask",
                      "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.",
                      "location": "query"
                    },
                    "name": {
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "description": "Output only. Identifier. The resource name of BackupPlanAssociation in below format Format : projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}",
                      "pattern": "^projects/[^/]+/locations/[^/]+/backupPlanAssociations/[^/]+$"
                    },
                    "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"
                    }
                  },
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Update a BackupPlanAssociation.",
                  "httpMethod": "PATCH",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/backupPlanAssociations/{backupPlanAssociationsId}",
                  "request": {
                    "$ref": "BackupPlanAssociation"
                  },
                  "id": "backupdr.projects.locations.backupPlanAssociations.patch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            }
          }
        }
      }
    }
  },
  "parameters": {
    "quotaUser": {
      "type": "string",
      "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.",
      "location": "query"
    },
    "$.xgafv": {
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "location": "query",
      "type": "string"
    },
    "alt": {
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "type": "string",
      "default": "json",
      "location": "query",
      "description": "Data format for response.",
      "enum": [
        "json",
        "media",
        "proto"
      ]
    },
    "upload_protocol": {
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "location": "query"
    },
    "fields": {
      "type": "string",
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query"
    },
    "access_token": {
      "description": "OAuth access token.",
      "location": "query",
      "type": "string"
    },
    "prettyPrint": {
      "description": "Returns response with indentations and line breaks.",
      "default": "true",
      "location": "query",
      "type": "boolean"
    },
    "callback": {
      "type": "string",
      "description": "JSONP",
      "location": "query"
    },
    "oauth_token": {
      "type": "string",
      "description": "OAuth 2.0 token for the current user.",
      "location": "query"
    },
    "uploadType": {
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "location": "query"
    },
    "key": {
      "type": "string",
      "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.",
      "location": "query"
    }
  },
  "basePath": "",
  "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."
        }
      }
    }
  },
  "discoveryVersion": "v1",
  "schemas": {
    "Trial": {
      "description": "Represents a Trial for a project.",
      "type": "object",
      "id": "Trial",
      "properties": {
        "state": {
          "description": "Output only. The state of the trial.",
          "enum": [
            "STATE_UNSPECIFIED",
            "SUBSCRIBED",
            "UNSUBSCRIBED",
            "EXPIRED",
            "ELIGIBLE",
            "NOT_ELIGIBLE"
          ],
          "readOnly": true,
          "type": "string",
          "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."
          ]
        },
        "startTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the trial was subscribed.",
          "readOnly": true,
          "type": "string"
        },
        "endTime": {
          "description": "Output only. The time when the trial will expire.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "name": {
          "type": "string",
          "description": "Identifier. The resource name of the trial. Format: projects/{project}/locations/{location}/trial"
        },
        "endReason": {
          "enumDescriptions": [
            "End reason not set.",
            "Trial is deliberately ended by the user to transition to paid usage.",
            "Trial is discontinued before expiration."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The reason for ending the trial.",
          "enum": [
            "END_REASON_UNSPECIFIED",
            "MOVE_TO_PAID",
            "DISCONTINUED"
          ]
        }
      }
    },
    "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.",
      "type": "object",
      "id": "AuditConfig",
      "properties": {
        "auditLogConfigs": {
          "items": {
            "$ref": "AuditLogConfig"
          },
          "type": "array",
          "description": "The configuration for logging of each type of permission."
        },
        "service": {
          "type": "string",
          "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."
        }
      }
    },
    "AlloyDbClusterBackupProperties": {
      "type": "object",
      "description": "AlloyDbClusterBackupProperties represents AlloyDB cluster backup properties. .",
      "id": "AlloyDbClusterBackupProperties",
      "properties": {
        "description": {
          "type": "string",
          "description": "An optional text description for the backup."
        },
        "storedBytes": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Storage usage of this particular backup",
          "format": "int64"
        },
        "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."
        }
      }
    },
    "FilestoreInstanceBackupPlanAssociationProperties": {
      "type": "object",
      "description": "Filestore instance's BPA properties.",
      "id": "FilestoreInstanceBackupPlanAssociationProperties",
      "properties": {
        "instanceCreateTime": {
          "description": "Output only. The time when the instance was created.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        }
      }
    },
    "AbandonBackupRequest": {
      "id": "AbandonBackupRequest",
      "properties": {
        "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)."
        }
      },
      "description": "request message for AbandonBackup.",
      "type": "object"
    },
    "DisplayDevice": {
      "id": "DisplayDevice",
      "properties": {
        "enableDisplay": {
          "description": "Optional. Enables display for the Compute Engine VM",
          "type": "boolean"
        }
      },
      "description": "A set of Display Device options",
      "type": "object"
    },
    "BackupRule": {
      "description": "`BackupRule` binds the backup schedule to a retention policy.",
      "type": "object",
      "id": "BackupRule",
      "properties": {
        "ruleId": {
          "type": "string",
          "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}/."
        },
        "backupRetentionDays": {
          "format": "int32",
          "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.",
          "type": "integer"
        },
        "standardSchedule": {
          "description": "Optional. Defines a schedule that runs within the confines of a defined window of time.",
          "$ref": "StandardSchedule"
        }
      }
    },
    "SetInternalStatusRequest": {
      "description": "Request message for SetStatusInternal method.",
      "type": "object",
      "id": "SetInternalStatusRequest",
      "properties": {
        "value": {
          "format": "byte",
          "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."
        },
        "backupConfigState": {
          "readOnly": true,
          "type": "string",
          "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)"
          ],
          "description": "Required. Output only. The new BackupConfigState to set for the DataSource.",
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ]
        },
        "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"
        }
      }
    },
    "ComputeInstanceBackupPlanProperties": {
      "type": "object",
      "description": "--- ComputeInstanceBackupPlanProperties Message ---",
      "id": "ComputeInstanceBackupPlanProperties",
      "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"
        }
      }
    },
    "CloudSqlInstanceInitializationConfig": {
      "description": "CloudSqlInstanceInitializationConfig contains the configuration for initializing a Cloud SQL instance.",
      "type": "object",
      "id": "CloudSqlInstanceInitializationConfig",
      "properties": {
        "edition": {
          "description": "Required. The edition of the Cloud SQL instance.",
          "enum": [
            "EDITION_UNSPECIFIED",
            "ENTERPRISE",
            "ENTERPRISE_PLUS"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified edition.",
            "Enterprise edition.",
            "Enterprise Plus edition."
          ]
        }
      }
    },
    "FetchMsComplianceMetadataResponse": {
      "description": "Response message for GetMsComplianceMetadata",
      "type": "object",
      "id": "FetchMsComplianceMetadataResponse",
      "properties": {
        "isAssuredWorkload": {
          "type": "boolean",
          "description": "The ms compliance metadata of the target project, if the project is an Assured Workloads project, values will be true, otherwise false."
        }
      }
    },
    "ListResourceBackupConfigsResponse": {
      "id": "ListResourceBackupConfigsResponse",
      "properties": {
        "resourceBackupConfigs": {
          "items": {
            "$ref": "ResourceBackupConfig"
          },
          "type": "array",
          "description": "The list of ResourceBackupConfigs for the specified scope."
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Response for ListResourceBackupConfigs."
    },
    "TestIamPermissionsRequest": {
      "type": "object",
      "description": "Request message for `TestIamPermissions` method.",
      "id": "TestIamPermissionsRequest",
      "properties": {
        "permissions": {
          "type": "array",
          "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).",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "FetchAccessTokenResponse": {
      "id": "FetchAccessTokenResponse",
      "properties": {
        "writeLocation": {
          "description": "The location in bucket that can be used for writing.",
          "type": "string"
        },
        "token": {
          "type": "string",
          "description": "The downscoped token that was created."
        },
        "expireTime": {
          "description": "The token is valid until this time.",
          "type": "string",
          "format": "google-datetime"
        },
        "readLocation": {
          "description": "The location in bucket that can be used for reading.",
          "type": "string"
        }
      },
      "description": "Response message for FetchAccessToken.",
      "type": "object"
    },
    "ComputeInstanceBackupProperties": {
      "description": "ComputeInstanceBackupProperties represents Compute Engine instance backup properties.",
      "type": "object",
      "id": "ComputeInstanceBackupProperties",
      "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"
        },
        "description": {
          "description": "An optional text description for the instances that are created from these properties.",
          "type": "string"
        },
        "canIpForward": {
          "type": "boolean",
          "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."
        },
        "scheduling": {
          "description": "Specifies the scheduling options for the instances that are created from these properties.",
          "$ref": "Scheduling"
        },
        "disk": {
          "type": "array",
          "description": "An array of disks that are associated with the instances that are created from these properties.",
          "items": {
            "$ref": "AttachedDisk"
          }
        },
        "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"
        },
        "machineType": {
          "description": "The machine type to use for instances that are created from these properties.",
          "type": "string"
        },
        "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.",
          "type": "array",
          "items": {
            "$ref": "ServiceAccount"
          }
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Labels to apply to instances that are created from these properties.",
          "type": "object"
        },
        "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"
        },
        "guestAccelerator": {
          "items": {
            "$ref": "AcceleratorConfig"
          },
          "type": "array",
          "description": "A list of guest accelerator cards' type and count to use for instances created from these properties."
        },
        "keyRevocationActionType": {
          "description": "KeyRevocationActionType of the instance. Supported options are \"STOP\" and \"NONE\". The default value is \"NONE\" if it is not specified.",
          "enum": [
            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
            "NONE",
            "STOP"
          ],
          "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."
          ]
        },
        "minCpuPlatform": {
          "type": "string",
          "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."
        },
        "networkInterface": {
          "items": {
            "$ref": "NetworkInterface"
          },
          "description": "An array of network access configurations for this interface.",
          "type": "array"
        },
        "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"
        }
      }
    },
    "BackupConfigInfo": {
      "id": "BackupConfigInfo",
      "properties": {
        "lastBackupError": {
          "readOnly": true,
          "description": "Output only. If the last backup failed, this field has the error message.",
          "$ref": "Status"
        },
        "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"
        },
        "gcpBackupConfig": {
          "description": "Configuration for a Google Cloud resource.",
          "$ref": "GcpBackupConfig"
        },
        "lastBackupState": {
          "description": "Output only. The status of the last backup to this BackupVault",
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "SUCCEEDED",
            "FAILED",
            "PERMISSION_DENIED"
          ],
          "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"
          ]
        }
      },
      "description": "BackupConfigInfo has information about how the resource is configured for Backup and about the most recent backup to this vault.",
      "type": "object"
    },
    "BackupApplianceBackupConfig": {
      "id": "BackupApplianceBackupConfig",
      "properties": {
        "backupApplianceId": {
          "format": "int64",
          "description": "The ID of the backup appliance.",
          "type": "string"
        },
        "hostName": {
          "type": "string",
          "description": "The name of the host where the application is running."
        },
        "backupApplianceName": {
          "description": "The name of the backup appliance.",
          "type": "string"
        },
        "sltName": {
          "description": "The name of the SLT associated with the application.",
          "type": "string"
        },
        "slaId": {
          "format": "int64",
          "type": "string",
          "description": "The ID of the SLA of this application."
        },
        "applicationName": {
          "type": "string",
          "description": "The name of the application."
        },
        "slpName": {
          "type": "string",
          "description": "The name of the SLP associated with the application."
        }
      },
      "type": "object",
      "description": "BackupApplianceBackupConfig captures the backup configuration for applications that are protected by Backup Appliances."
    },
    "InitializeParams": {
      "type": "object",
      "description": "Specifies the parameters to initialize this disk.",
      "id": "InitializeParams",
      "properties": {
        "diskName": {
          "description": "Optional. Specifies the disk name. If not specified, the default is to use the name of the instance.",
          "type": "string"
        },
        "replicaZones": {
          "items": {
            "type": "string"
          },
          "description": "Optional. URL of the zone where the disk should be created. Required for each regional disk associated with the instance.",
          "type": "array"
        }
      }
    },
    "Policy": {
      "id": "Policy",
      "properties": {
        "etag": {
          "format": "byte",
          "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."
        },
        "bindings": {
          "type": "array",
          "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`.",
          "items": {
            "$ref": "Binding"
          }
        },
        "auditConfigs": {
          "description": "Specifies cloud audit logging configuration for this policy.",
          "type": "array",
          "items": {
            "$ref": "AuditConfig"
          }
        },
        "version": {
          "format": "int32",
          "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).",
          "type": "integer"
        }
      },
      "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/)."
    },
    "FetchBackupsForResourceTypeResponse": {
      "id": "FetchBackupsForResourceTypeResponse",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "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."
        },
        "backups": {
          "type": "array",
          "description": "The Backups from the specified parent.",
          "items": {
            "$ref": "Backup"
          }
        }
      },
      "type": "object",
      "description": "Response for the FetchBackupsForResourceType method."
    },
    "FilestoreInstanceDataSourceProperties": {
      "id": "FilestoreInstanceDataSourceProperties",
      "properties": {
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the Filestore instance backed up by the datasource."
        },
        "instanceCreateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "type": "string",
          "description": "Output only. The instance creation timestamp."
        }
      },
      "description": "FilestoreInstanceDataSourceProperties represents the properties of a Filestore resource that are stored in the DataSource. .",
      "type": "object"
    },
    "Tags": {
      "id": "Tags",
      "properties": {
        "items": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Optional. An array of tags. Each tag must be 1-63 characters long, and comply with RFC1035."
        }
      },
      "type": "object",
      "description": "A set of instance tags."
    },
    "DiskRestoreProperties": {
      "description": "DiskRestoreProperties represents the properties of a Disk restore.",
      "type": "object",
      "id": "DiskRestoreProperties",
      "properties": {
        "name": {
          "type": "string",
          "description": "Required. Name of the disk."
        },
        "resourceManagerTags": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Resource manager tags to be bound to the disk."
        },
        "physicalBlockSizeBytes": {
          "format": "int64",
          "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.",
          "type": "string"
        },
        "description": {
          "type": "string",
          "description": "Optional. An optional description of this resource. Provide this property when you create the resource."
        },
        "guestOsFeature": {
          "description": "Optional. A list of features to enable in the guest operating system. This is applicable only for bootable images.",
          "type": "array",
          "items": {
            "$ref": "GuestOsFeature"
          }
        },
        "architecture": {
          "description": "Optional. The architecture of the source disk. Valid values are ARM64 or X86_64.",
          "enum": [
            "ARCHITECTURE_UNSPECIFIED",
            "X86_64",
            "ARM64"
          ],
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Disks with architecture X86_64",
            "Disks with architecture ARM64"
          ]
        },
        "enableConfidentialCompute": {
          "type": "boolean",
          "description": "Optional. Indicates whether this disk is using confidential compute mode. Encryption with a Cloud KMS key is required to enable this option."
        },
        "sizeGb": {
          "format": "int64",
          "type": "string",
          "description": "Required. The size of the disk in GB."
        },
        "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.",
          "type": "string",
          "format": "int64"
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Labels to apply to this disk. These can be modified later using setLabels method. Label values can be empty.",
          "type": "object"
        },
        "licenses": {
          "type": "array",
          "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",
          "items": {
            "type": "string"
          }
        },
        "diskEncryptionKey": {
          "description": "Optional. Encrypts the disk using a customer-supplied encryption key or a customer-managed encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "accessMode": {
          "type": "string",
          "description": "Optional. The access mode of the disk.",
          "enum": [
            "READ_WRITE_SINGLE",
            "READ_WRITE_MANY",
            "READ_ONLY_MANY"
          ],
          "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."
          ]
        },
        "provisionedThroughput": {
          "format": "int64",
          "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.",
          "type": "string"
        },
        "type": {
          "type": "string",
          "description": "Required. URL of the disk type resource describing which disk type to use to create the disk."
        },
        "resourcePolicy": {
          "description": "Optional. Resource policies applied to this disk.",
          "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"
        }
      }
    },
    "ListBackupPlanRevisionsResponse": {
      "description": "The response message for getting a list of `BackupPlanRevision`.",
      "type": "object",
      "id": "ListBackupPlanRevisionsResponse",
      "properties": {
        "backupPlanRevisions": {
          "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.",
          "type": "array"
        },
        "nextPageToken": {
          "type": "string",
          "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."
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        }
      }
    },
    "TriggerBackupRequest": {
      "id": "TriggerBackupRequest",
      "properties": {
        "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": {
          "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 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)."
        },
        "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"
        },
        "labels": {
          "type": "object",
          "description": "Optional. Labels to be applied on the backup.",
          "additionalProperties": {
            "type": "string"
          }
        }
      },
      "type": "object",
      "description": "Request message for triggering a backup."
    },
    "GuestOsFeature": {
      "id": "GuestOsFeature",
      "properties": {
        "type": {
          "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."
          ],
          "description": "The ID of a supported feature.",
          "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"
          ],
          "type": "string"
        }
      },
      "description": "Feature type of the Guest OS.",
      "type": "object"
    },
    "StandardSchedule": {
      "id": "StandardSchedule",
      "properties": {
        "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",
            "enum": [
              "MONTH_UNSPECIFIED",
              "JANUARY",
              "FEBRUARY",
              "MARCH",
              "APRIL",
              "MAY",
              "JUNE",
              "JULY",
              "AUGUST",
              "SEPTEMBER",
              "OCTOBER",
              "NOVEMBER",
              "DECEMBER"
            ],
            "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."
            ]
          }
        },
        "hourlyFrequency": {
          "format": "int32",
          "type": "integer",
          "description": "Optional. Specifies frequency for hourly backups. A hourly frequency of 2 means jobs will run every 2 hours 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`. Value of hourly frequency should be between 4 and 23. Reason for limit : We found that there is bandwidth limitation of 3GB/S for GMI while taking a backup and 5GB/S while doing a restore. Given the amount of parallel backups and restore we are targeting, this will potentially take the backup time to mins and hours (in worst case scenario)."
        },
        "daysOfWeek": {
          "items": {
            "type": "string",
            "enum": [
              "DAY_OF_WEEK_UNSPECIFIED",
              "MONDAY",
              "TUESDAY",
              "WEDNESDAY",
              "THURSDAY",
              "FRIDAY",
              "SATURDAY",
              "SUNDAY"
            ],
            "enumDescriptions": [
              "The day of the week is unspecified.",
              "Monday",
              "Tuesday",
              "Wednesday",
              "Thursday",
              "Friday",
              "Saturday",
              "Sunday"
            ]
          },
          "type": "array",
          "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`."
        },
        "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"
        },
        "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"
        },
        "recurrenceType": {
          "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."
          ],
          "description": "Required. Specifies the `RecurrenceType` for the schedule.",
          "enum": [
            "RECURRENCE_TYPE_UNSPECIFIED",
            "HOURLY",
            "DAILY",
            "WEEKLY",
            "MONTHLY",
            "YEARLY"
          ],
          "type": "string"
        },
        "daysOfMonth": {
          "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.",
          "type": "array",
          "items": {
            "type": "integer",
            "format": "int32"
          }
        }
      },
      "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.",
      "type": "object"
    },
    "Location": {
      "type": "object",
      "description": "A resource that represents a Google Cloud location.",
      "id": "Location",
      "properties": {
        "name": {
          "type": "string",
          "description": "Resource name for the location, which may vary between implementations. For example: `\"projects/example-project/locations/us-east1\"`"
        },
        "locationId": {
          "description": "The canonical id for this location. For example: `\"us-east1\"`.",
          "type": "string"
        },
        "displayName": {
          "type": "string",
          "description": "The friendly name for this location, typically a nearby city name. For example, \"Tokyo\"."
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Cross-service attributes for the location. For example {\"cloud.googleapis.com/region\": \"us-east1\"}",
          "type": "object"
        },
        "metadata": {
          "type": "object",
          "description": "Service-specific metadata. For example the available capacity at the given location.",
          "additionalProperties": {
            "description": "Properties of the object. Contains field @type with type URL.",
            "type": "any"
          }
        }
      }
    },
    "ManagementServer": {
      "id": "ManagementServer",
      "properties": {
        "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.",
          "$ref": "WorkforceIdentityBasedManagementURI",
          "readOnly": true
        },
        "createTime": {
          "format": "google-datetime",
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created."
        },
        "networks": {
          "items": {
            "$ref": "NetworkConfig"
          },
          "type": "array",
          "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"
        },
        "etag": {
          "type": "string",
          "description": "Optional. Server specified ETag for the ManagementServer resource to prevent simultaneous updates from overwiting each other."
        },
        "satisfiesPzi": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Reserved for future use."
        },
        "updateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime"
        },
        "oauth2ClientId": {
          "readOnly": true,
          "type": "string",
          "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)."
        },
        "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"
          }
        },
        "state": {
          "readOnly": true,
          "type": "string",
          "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."
          ],
          "description": "Output only. The ManagementServer state.",
          "enum": [
            "INSTANCE_STATE_UNSPECIFIED",
            "CREATING",
            "READY",
            "UPDATING",
            "DELETING",
            "REPAIRING",
            "MAINTENANCE",
            "ERROR"
          ]
        },
        "type": {
          "enumDescriptions": [
            "Instance type is not mentioned.",
            "Instance for backup and restore management (i.e., AGM)."
          ],
          "description": "Optional. The type of the ManagementServer resource.",
          "enum": [
            "INSTANCE_TYPE_UNSPECIFIED",
            "BACKUP_RESTORE"
          ],
          "type": "string"
        },
        "satisfiesPzs": {
          "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"
        },
        "workforceIdentityBasedOauth2ClientId": {
          "readOnly": true,
          "description": "Output only. The OAuth client IDs for both types of user i.e. 1p and 3p.",
          "$ref": "WorkforceIdentityBasedOAuth2ClientID"
        },
        "baProxyUri": {
          "items": {
            "type": "string"
          },
          "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"
        },
        "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.",
          "$ref": "ManagementURI",
          "readOnly": true
        }
      },
      "description": "ManagementServer describes a single BackupDR ManagementServer instance.",
      "type": "object"
    },
    "FetchBackupPlanAssociationsForResourceTypeResponse": {
      "id": "FetchBackupPlanAssociationsForResourceTypeResponse",
      "properties": {
        "nextPageToken": {
          "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.",
          "readOnly": true,
          "type": "string"
        },
        "backupPlanAssociations": {
          "items": {
            "$ref": "BackupPlanAssociation"
          },
          "description": "Output only. The BackupPlanAssociations from the specified parent.",
          "readOnly": true,
          "type": "array"
        }
      },
      "description": "Response for the FetchBackupPlanAssociationsForResourceType method.",
      "type": "object"
    },
    "AccessConfig": {
      "id": "AccessConfig",
      "properties": {
        "setPublicPtr": {
          "type": "boolean",
          "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."
        },
        "name": {
          "description": "Optional. The name of this access configuration.",
          "type": "string"
        },
        "natIP": {
          "type": "string",
          "description": "Optional. The external IP address of this access configuration."
        },
        "type": {
          "enumDescriptions": [
            "Default value. This value is unused.",
            "ONE_TO_ONE_NAT",
            "Direct IPv6 access."
          ],
          "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.",
          "enum": [
            "ACCESS_TYPE_UNSPECIFIED",
            "ONE_TO_ONE_NAT",
            "DIRECT_IPV6"
          ],
          "type": "string"
        },
        "externalIpv6": {
          "description": "Optional. The external IPv6 address of this access configuration.",
          "type": "string"
        },
        "publicPtrDomainName": {
          "type": "string",
          "description": "Optional. The DNS domain name for the public PTR record."
        },
        "externalIpv6PrefixLength": {
          "format": "int32",
          "description": "Optional. The prefix length of the external IPv6 range.",
          "type": "integer"
        },
        "networkTier": {
          "type": "string",
          "description": "Optional. This signifies the networking tier used for configuring this access",
          "enum": [
            "NETWORK_TIER_UNSPECIFIED",
            "PREMIUM",
            "STANDARD"
          ],
          "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."
          ]
        }
      },
      "description": "An access configuration attached to an instance's network interface. Only one access config per instance is supported.",
      "type": "object"
    },
    "InstanceParams": {
      "type": "object",
      "description": "Additional instance params.",
      "id": "InstanceParams",
      "properties": {
        "resourceManagerTags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Resource manager tags to be bound to the instance.",
          "type": "object"
        }
      }
    },
    "CloudSqlInstanceBackupPlanAssociationProperties": {
      "id": "CloudSqlInstanceBackupPlanAssociationProperties",
      "properties": {
        "instanceCreateTime": {
          "description": "Output only. The time when the instance was created.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        }
      },
      "type": "object",
      "description": "Cloud SQL instance's BPA properties."
    },
    "BackupPlanRevision": {
      "description": "`BackupPlanRevision` represents a snapshot of a `BackupPlan` at a point in time.",
      "type": "object",
      "id": "BackupPlanRevision",
      "properties": {
        "backupPlanSnapshot": {
          "description": "The Backup Plan being encompassed by this revision.",
          "$ref": "BackupPlan"
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Identifier. The resource name of the `BackupPlanRevision`. Format: `projects/{project}/locations/{location}/backupPlans/{backup_plan}/revisions/{revision}`"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The timestamp that the revision was created.",
          "format": "google-datetime"
        },
        "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."
          ],
          "description": "Output only. Resource State",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE"
          ]
        },
        "revisionId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc."
        }
      }
    },
    "SetInternalStatusResponse": {
      "description": "Response message from SetStatusInternal method.",
      "type": "object",
      "id": "SetInternalStatusResponse",
      "properties": {}
    },
    "Expr": {
      "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.",
      "type": "object",
      "id": "Expr",
      "properties": {
        "expression": {
          "description": "Textual representation of an expression in Common Expression Language syntax.",
          "type": "string"
        },
        "title": {
          "type": "string",
          "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."
        },
        "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"
        }
      }
    },
    "NetworkConfig": {
      "type": "object",
      "description": "Network configuration for ManagementServer instance.",
      "id": "NetworkConfig",
      "properties": {
        "network": {
          "type": "string",
          "description": "Optional. The resource name of the Google Compute Engine VPC network to which the ManagementServer instance is connected."
        },
        "peeringMode": {
          "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."
          ],
          "description": "Optional. The network connect mode of the ManagementServer instance. For this version, only PRIVATE_SERVICE_ACCESS is supported.",
          "enum": [
            "PEERING_MODE_UNSPECIFIED",
            "PRIVATE_SERVICE_ACCESS"
          ],
          "type": "string"
        }
      }
    },
    "ResourceBackupConfig": {
      "id": "ResourceBackupConfig",
      "properties": {
        "uid": {
          "description": "Output only. The unique identifier of the resource backup config.",
          "readOnly": true,
          "type": "string"
        },
        "targetResourceDisplayName": {
          "description": "Output only. The human friendly name of the target resource.",
          "readOnly": true,
          "type": "string"
        },
        "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."
        },
        "name": {
          "type": "string",
          "description": "Identifier. The resource name of the ResourceBackupConfig. Format: projects/{project}/locations/{location}/resourceBackupConfigs/{uid}"
        },
        "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."
        },
        "targetResourceType": {
          "enumDescriptions": [
            "Resource type not set.",
            "Cloud SQL instance.",
            "Compute Engine VM.",
            "Compute Engine Disk.",
            "Compute Engine Regional Disk.",
            "Filestore Instance."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The type of the target resource.",
          "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"
        },
        "targetResourceLabels": {
          "description": "Labels associated with the target resource.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "backupConfigsDetails": {
          "items": {
            "$ref": "BackupConfigDetails"
          },
          "type": "array",
          "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."
        }
      },
      "description": "ResourceBackupConfig represents a resource along with its backup configurations.",
      "type": "object"
    },
    "DiskTargetEnvironment": {
      "description": "DiskTargetEnvironment represents the target environment for the disk.",
      "type": "object",
      "id": "DiskTargetEnvironment",
      "properties": {
        "project": {
          "type": "string",
          "description": "Required. Target project for the disk."
        },
        "zone": {
          "type": "string",
          "description": "Required. Target zone for the disk."
        }
      }
    },
    "WeekDayOfMonth": {
      "type": "object",
      "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",
      "properties": {
        "weekOfMonth": {
          "description": "Required. Specifies the week of the month.",
          "enum": [
            "WEEK_OF_MONTH_UNSPECIFIED",
            "FIRST",
            "SECOND",
            "THIRD",
            "FOURTH",
            "LAST"
          ],
          "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."
          ]
        },
        "dayOfWeek": {
          "type": "string",
          "description": "Required. Specifies the day of the week.",
          "enum": [
            "DAY_OF_WEEK_UNSPECIFIED",
            "MONDAY",
            "TUESDAY",
            "WEDNESDAY",
            "THURSDAY",
            "FRIDAY",
            "SATURDAY",
            "SUNDAY"
          ],
          "enumDescriptions": [
            "The day of the week is unspecified.",
            "Monday",
            "Tuesday",
            "Wednesday",
            "Thursday",
            "Friday",
            "Saturday",
            "Sunday"
          ]
        }
      }
    },
    "Operation": {
      "id": "Operation",
      "properties": {
        "name": {
          "type": "string",
          "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}`."
        },
        "error": {
          "description": "The error result of the operation in case of failure or cancellation.",
          "$ref": "Status"
        },
        "response": {
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "type": "object",
          "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`."
        },
        "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.",
          "type": "object",
          "additionalProperties": {
            "description": "Properties of the object. Contains field @type with type URL.",
            "type": "any"
          }
        },
        "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"
        }
      },
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "type": "object"
    },
    "AlloyDBClusterDataSourceReferenceProperties": {
      "type": "object",
      "description": "AlloyDBClusterDataSourceReferenceProperties represents the properties of an AlloyDB cluster that are stored in the DataSourceReference.",
      "id": "AlloyDBClusterDataSourceReferenceProperties",
      "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"
        }
      }
    },
    "ListManagementServersResponse": {
      "id": "ListManagementServersResponse",
      "properties": {
        "managementServers": {
          "type": "array",
          "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.",
          "items": {
            "$ref": "ManagementServer"
          }
        },
        "nextPageToken": {
          "type": "string",
          "description": "A token identifying a page of results the server should return."
        },
        "unreachable": {
          "type": "array",
          "description": "Locations that could not be reached.",
          "items": {
            "type": "string"
          }
        }
      },
      "description": "Response message for listing management servers.",
      "type": "object"
    },
    "ListLocationsResponse": {
      "type": "object",
      "description": "The response message for Locations.ListLocations.",
      "id": "ListLocationsResponse",
      "properties": {
        "locations": {
          "description": "A list of locations that matches the specified filter in the request.",
          "type": "array",
          "items": {
            "$ref": "Location"
          }
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        }
      }
    },
    "DataSourceGcpResourceInfo": {
      "description": "The Google Cloud resource that the DataSource is associated with.",
      "type": "object",
      "id": "DataSourceGcpResourceInfo",
      "properties": {
        "cloudSqlInstanceProperties": {
          "readOnly": true,
          "description": "Output only. The properties of the Cloud SQL instance.",
          "$ref": "CloudSqlInstanceDataSourceReferenceProperties"
        },
        "type": {
          "description": "Output only. The type of the Google Cloud resource. Ex: compute.googleapis.com/Instance",
          "readOnly": true,
          "type": "string"
        },
        "alloyDbClusterProperties": {
          "readOnly": true,
          "description": "Output only. The properties of the AlloyDB cluster.",
          "$ref": "AlloyDBClusterDataSourceReferenceProperties"
        },
        "location": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The location of the Google Cloud resource. Ex: //\"global\"/\"unspecified\""
        },
        "filestoreInstanceProperties": {
          "readOnly": true,
          "description": "Output only. The properties of the Filestore instance.",
          "$ref": "FilestoreInstanceDataSourceReferenceProperties"
        },
        "gcpResourcename": {
          "description": "Output only. The resource name of the Google Cloud resource. Ex: projects/{project}/zones/{zone}/instances/{instance}",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "NetworkPerformanceConfig": {
      "description": "Network performance configuration.",
      "type": "object",
      "id": "NetworkPerformanceConfig",
      "properties": {
        "totalEgressBandwidthTier": {
          "enumDescriptions": [
            "This value is unused.",
            "Default network performance config.",
            "Tier 1 network performance config."
          ],
          "description": "Optional. The tier of the total egress bandwidth.",
          "enum": [
            "TIER_UNSPECIFIED",
            "DEFAULT",
            "TIER_1"
          ],
          "type": "string"
        }
      }
    },
    "PitrSettings": {
      "id": "PitrSettings",
      "properties": {
        "retentionDays": {
          "readOnly": true,
          "type": "integer",
          "description": "Output only. Number of days to retain the backup.",
          "format": "int32"
        }
      },
      "description": "Point in time recovery settings of the backup configuration resource.",
      "type": "object"
    },
    "EncryptionConfig": {
      "type": "object",
      "description": "Message describing the EncryptionConfig of backup vault. This determines how data within the vault is encrypted at rest.",
      "id": "EncryptionConfig",
      "properties": {
        "kmsKeyName": {
          "type": "string",
          "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}"
        }
      }
    },
    "RemoveDataSourceRequest": {
      "type": "object",
      "description": "Message for deleting a DataSource.",
      "id": "RemoveDataSourceRequest",
      "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"
        }
      }
    },
    "FilestoreInstanceDataSourceReferenceProperties": {
      "id": "FilestoreInstanceDataSourceReferenceProperties",
      "properties": {
        "instanceCreateTime": {
          "description": "Output only. The instance creation timestamp.",
          "readOnly": true,
          "type": "string",
          "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"
        }
      },
      "description": "FilestoreInstanceDataSourceReferenceProperties represents the properties of a Filestore resource that are stored in the DataSourceReference. .",
      "type": "object"
    },
    "GcpResource": {
      "type": "object",
      "description": "Minimum details to identify a Google Cloud resource",
      "id": "GcpResource",
      "properties": {
        "location": {
          "description": "Location of the resource: //\"global\"/\"unspecified\".",
          "type": "string"
        },
        "type": {
          "type": "string",
          "description": "Type of the resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance."
        },
        "gcpResourcename": {
          "description": "Name of the Google Cloud resource.",
          "type": "string"
        }
      }
    },
    "ServiceLockInfo": {
      "id": "ServiceLockInfo",
      "properties": {
        "operation": {
          "description": "Output only. The name of the operation that created this lock. The lock will automatically be released when the operation completes.",
          "readOnly": true,
          "type": "string"
        }
      },
      "type": "object",
      "description": "ServiceLockInfo represents the details of a lock taken by the service on a Backup resource."
    },
    "EndTrialRequest": {
      "type": "object",
      "description": "Request message for ending a trial.",
      "id": "EndTrialRequest",
      "properties": {
        "endReason": {
          "type": "string",
          "description": "Required. The reason for ending the trial.",
          "enum": [
            "END_REASON_UNSPECIFIED",
            "MOVE_TO_PAID",
            "DISCONTINUED"
          ],
          "enumDescriptions": [
            "End reason not set.",
            "Trial is deliberately ended by the user to transition to paid usage.",
            "Trial is discontinued before expiration."
          ]
        }
      }
    },
    "InitializeServiceRequest": {
      "id": "InitializeServiceRequest",
      "properties": {
        "validateOnly": {
          "description": "Optional. If set, validates the request and returns the result, but does not actually run it.",
          "type": "boolean"
        },
        "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)."
        },
        "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"
        },
        "resourceType": {
          "type": "string",
          "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\"."
        },
        "cloudSqlInstanceInitializationConfig": {
          "description": "Optional. The configuration for initializing a Cloud SQL instance.",
          "$ref": "CloudSqlInstanceInitializationConfig"
        }
      },
      "type": "object",
      "description": "Request message for initializing the service."
    },
    "CloudSqlInstanceDataSourceReferenceProperties": {
      "type": "object",
      "description": "CloudSqlInstanceDataSourceReferenceProperties represents the properties of a Cloud SQL resource that are stored in the DataSourceReference.",
      "id": "CloudSqlInstanceDataSourceReferenceProperties",
      "properties": {
        "instanceCreateTime": {
          "format": "google-datetime",
          "description": "Output only. The instance creation timestamp.",
          "readOnly": true,
          "type": "string"
        },
        "instanceTier": {
          "description": "Output only. The tier (or machine type) for this instance. Example: `db-custom-1-3840`",
          "readOnly": true,
          "type": "string"
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the Cloud SQL instance backed up by the datasource. Format: projects/{project}/instances/{instance}"
        },
        "databaseInstalledVersion": {
          "description": "Output only. The installed database version of the Cloud SQL instance.",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "LocationMetadata": {
      "type": "object",
      "id": "LocationMetadata",
      "properties": {
        "unsupportedFeatures": {
          "items": {
            "enumDescriptions": [
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "",
              "Remove once parity achieved between BV_AF and BV_CUSTOM_PROBERS.",
              ""
            ],
            "type": "string",
            "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.",
          "type": "array"
        }
      }
    },
    "Metadata": {
      "description": "A metadata key/value entry.",
      "type": "object",
      "id": "Metadata",
      "properties": {
        "items": {
          "items": {
            "$ref": "Entry"
          },
          "type": "array",
          "description": "Optional. Array of key/value pairs. The total size of all keys and values must be less than 512 KB."
        }
      }
    },
    "WorkforceIdentityBasedOAuth2ClientID": {
      "id": "WorkforceIdentityBasedOAuth2ClientID",
      "properties": {
        "thirdPartyOauth2ClientId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Third party OAuth Client ID for External Identity Providers."
        },
        "firstPartyOauth2ClientId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. First party OAuth Client ID for Google Identities."
        }
      },
      "description": "OAuth Client ID depending on the Workforce Identity i.e. either 1p or 3p,",
      "type": "object"
    },
    "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.",
      "id": "BackupConfigDetails",
      "properties": {
        "type": {
          "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."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The type of the backup config resource.",
          "enum": [
            "TYPE_UNSPECIFIED",
            "CLOUD_SQL_INSTANCE_BACKUP_CONFIG",
            "COMPUTE_ENGINE_RESOURCE_POLICY",
            "BACKUPDR_BACKUP_PLAN",
            "BACKUPDR_TEMPLATE"
          ]
        },
        "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"
        },
        "backupDrPlanConfig": {
          "description": "Google Cloud Backup and DR's Backup Plan specific data.",
          "$ref": "BackupDrPlanConfig"
        },
        "backupLocations": {
          "description": "The locations where the backups are to be stored.",
          "type": "array",
          "items": {
            "$ref": "BackupLocation"
          }
        },
        "backupVault": {
          "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}\"",
          "readOnly": true,
          "type": "string"
        },
        "latestSuccessfulBackupTime": {
          "format": "google-datetime",
          "description": "Output only. Timestamp of the latest successful backup created via this backup configuration.",
          "readOnly": true,
          "type": "string"
        },
        "backupConfigSourceDisplayName": {
          "description": "Output only. The display name of the backup config source resource.",
          "readOnly": true,
          "type": "string"
        },
        "state": {
          "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."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The state of the backup config resource.",
          "enum": [
            "STATE_UNSPECIFIED",
            "ACTIVE",
            "INACTIVE",
            "ERROR"
          ]
        },
        "pitrSettings": {
          "readOnly": true,
          "description": "Output only. Point in time recovery settings of the backup configuration resource.",
          "$ref": "PitrSettings"
        },
        "backupDrTemplateConfig": {
          "description": "Google Cloud Backup and DR's Template specific data.",
          "$ref": "BackupDrTemplateConfig"
        },
        "applicableResource": {
          "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}\"",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "FetchUsableBackupVaultsResponse": {
      "description": "Response message for fetching usable BackupVaults.",
      "type": "object",
      "id": "FetchUsableBackupVaultsResponse",
      "properties": {
        "backupVaults": {
          "type": "array",
          "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.",
          "items": {
            "$ref": "BackupVault"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Locations that could not be reached."
        }
      }
    },
    "BackupLocation": {
      "description": "BackupLocation represents a cloud location where a backup can be stored.",
      "type": "object",
      "id": "BackupLocation",
      "properties": {
        "locationId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The id of the cloud location. Example: \"us-central1\""
        },
        "type": {
          "description": "Output only. The type of the location.",
          "enum": [
            "TYPE_UNSPECIFIED",
            "ZONAL",
            "REGIONAL",
            "MULTI_REGIONAL"
          ],
          "enumDescriptions": [
            "Location type is unspecified.",
            "Location type is zonal.",
            "Location type is regional.",
            "Location type is multi regional."
          ],
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "GoogleCloudBackupdrV1OperationMetadata": {
      "type": "object",
      "description": "Represents the metadata of the long-running operation.",
      "id": "GoogleCloudBackupdrV1OperationMetadata",
      "properties": {
        "endTime": {
          "format": "google-datetime",
          "description": "Output only. The time the operation finished running.",
          "readOnly": true,
          "type": "string"
        },
        "additionalInfo": {
          "description": "Output only. AdditionalInfo contains additional Info related to backup plan association resource.",
          "readOnly": true,
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "verb": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the verb executed by the operation."
        },
        "apiVersion": {
          "description": "Output only. API version used to start the operation.",
          "readOnly": true,
          "type": "string"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time the operation was created.",
          "format": "google-datetime"
        },
        "target": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Server-defined resource path for the target of the operation."
        },
        "statusMessage": {
          "description": "Output only. Human-readable status of the operation, if any.",
          "readOnly": true,
          "type": "string"
        },
        "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"
        }
      }
    },
    "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).",
      "id": "Status",
      "properties": {
        "details": {
          "type": "array",
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "items": {
            "type": "object",
            "additionalProperties": {
              "description": "Properties of the object. Contains field @type with type URL.",
              "type": "any"
            }
          }
        },
        "code": {
          "format": "int32",
          "type": "integer",
          "description": "The status code, which should be an enum value of google.rpc.Code."
        },
        "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"
        }
      }
    },
    "CancelOperationRequest": {
      "id": "CancelOperationRequest",
      "properties": {},
      "description": "The request message for Operations.CancelOperation.",
      "type": "object"
    },
    "BackupVault": {
      "type": "object",
      "description": "Message describing a BackupVault object.",
      "id": "BackupVault",
      "properties": {
        "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": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Immutable after resource creation until resource deletion."
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "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."
        },
        "encryptionConfig": {
          "description": "Optional. The encryption config of the backup vault.",
          "$ref": "EncryptionConfig"
        },
        "description": {
          "description": "Optional. The description of the BackupVault instance (2048 characters or less).",
          "type": "string"
        },
        "backupRetentionInheritance": {
          "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."
          ],
          "description": "Optional. Setting for how a backup's enforced retention end time is inherited.",
          "enum": [
            "BACKUP_RETENTION_INHERITANCE_UNSPECIFIED",
            "INHERIT_VAULT_RETENTION",
            "MATCH_BACKUP_EXPIRE_TIME"
          ],
          "type": "string"
        },
        "deletable": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Set to true when there are no backups nested under this resource."
        },
        "effectiveTime": {
          "description": "Optional. Time after which the BackupVault resource is locked.",
          "type": "string",
          "format": "google-datetime"
        },
        "totalStoredBytes": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Total size of the storage used by all backup resources.",
          "format": "int64"
        },
        "annotations": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. User annotations. See https://google.aip.dev/128#annotations Stores small amounts of arbitrary data.",
          "type": "object"
        },
        "backupMinimumEnforcedRetentionDuration": {
          "type": "string",
          "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"
        },
        "createTime": {
          "description": "Output only. The time when the instance was created.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "etag": {
          "description": "Optional. Server specified ETag for the backup vault resource to prevent simultaneous updates from overwiting each other.",
          "type": "string"
        },
        "accessRestriction": {
          "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."
          ],
          "type": "string",
          "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.",
          "enum": [
            "ACCESS_RESTRICTION_UNSPECIFIED",
            "WITHIN_PROJECT",
            "WITHIN_ORGANIZATION",
            "UNRESTRICTED",
            "WITHIN_ORG_BUT_UNRESTRICTED_FOR_BA"
          ]
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined:",
          "type": "object"
        },
        "state": {
          "description": "Output only. The BackupVault resource instance state.",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR",
            "UPDATING"
          ],
          "readOnly": true,
          "type": "string",
          "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."
          ]
        },
        "backupCount": {
          "format": "int64",
          "readOnly": true,
          "type": "string",
          "description": "Output only. The number of backups in this backup vault."
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        }
      }
    },
    "NetworkInterface": {
      "type": "object",
      "description": "A network interface resource attached to an instance. s",
      "id": "NetworkInterface",
      "properties": {
        "stackType": {
          "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."
          ],
          "type": "string",
          "description": "The stack type for this network interface.",
          "enum": [
            "STACK_TYPE_UNSPECIFIED",
            "IPV4_ONLY",
            "IPV4_IPV6"
          ]
        },
        "aliasIpRanges": {
          "items": {
            "$ref": "AliasIpRange"
          },
          "type": "array",
          "description": "Optional. An array of alias IP ranges for this network interface. You can only specify this field for network interfaces in VPC networks."
        },
        "ipv6AccessType": {
          "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.",
          "enum": [
            "UNSPECIFIED_IPV6_ACCESS_TYPE",
            "INTERNAL",
            "EXTERNAL"
          ],
          "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."
          ]
        },
        "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"
        },
        "subnetwork": {
          "type": "string",
          "description": "Optional. The URL of the Subnetwork resource for this instance."
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. [Output Only] The name of the network interface, which is generated by the server."
        },
        "networkIP": {
          "type": "string",
          "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."
        },
        "internalIpv6PrefixLength": {
          "type": "integer",
          "description": "Optional. The prefix length of the primary internal IPv6 range.",
          "format": "int32"
        },
        "nicType": {
          "description": "Optional. The type of vNIC to be used on this interface. This may be gVNIC or VirtioNet.",
          "enum": [
            "NIC_TYPE_UNSPECIFIED",
            "VIRTIO_NET",
            "GVNIC"
          ],
          "type": "string",
          "enumDescriptions": [
            "Default should be NIC_TYPE_UNSPECIFIED.",
            "VIRTIO",
            "GVNIC"
          ]
        },
        "network": {
          "description": "Optional. URL of the VPC network resource for this instance.",
          "type": "string"
        },
        "accessConfigs": {
          "items": {
            "$ref": "AccessConfig"
          },
          "type": "array",
          "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."
        },
        "ipv6AccessConfigs": {
          "items": {
            "$ref": "AccessConfig"
          },
          "type": "array",
          "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."
        },
        "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"
        },
        "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"
        }
      }
    },
    "WorkforceIdentityBasedManagementURI": {
      "id": "WorkforceIdentityBasedManagementURI",
      "properties": {
        "thirdPartyManagementUri": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Third party Management URI for External Identity Providers."
        },
        "firstPartyManagementUri": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. First party Management URI for Google Identities."
        }
      },
      "type": "object",
      "description": "ManagementURI depending on the Workforce Identity i.e. either 1p or 3p."
    },
    "GcpBackupConfig": {
      "id": "GcpBackupConfig",
      "properties": {
        "backupPlan": {
          "type": "string",
          "description": "The name of the backup plan."
        },
        "backupPlanAssociation": {
          "description": "The name of the backup plan association.",
          "type": "string"
        },
        "backupPlanRevisionName": {
          "type": "string",
          "description": "The name of the backup plan revision."
        },
        "backupPlanRevisionId": {
          "description": "The user friendly id of the backup plan revision. E.g. v0, v1 etc.",
          "type": "string"
        },
        "backupPlanDescription": {
          "type": "string",
          "description": "The description of the backup plan."
        },
        "backupPlanRules": {
          "description": "The names of the backup plan rules which point to this backupvault",
          "type": "array",
          "items": {
            "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.",
      "type": "object"
    },
    "BackupDrPlanConfig": {
      "id": "BackupDrPlanConfig",
      "properties": {
        "backupDrPlanRules": {
          "items": {
            "$ref": "BackupDrPlanRule"
          },
          "type": "array",
          "description": "Backup rules of the backup plan resource."
        }
      },
      "description": "BackupDrPlanConfig has additional information about Google Cloud Backup and DR's Plan backup configuration.",
      "type": "object"
    },
    "AlloyDBClusterBackupPlanAssociationProperties": {
      "description": "Properties for an AlloyDB cluster backup plan association.",
      "type": "object",
      "id": "AlloyDBClusterBackupPlanAssociationProperties",
      "properties": {
        "clusterUid": {
          "description": "Output only. The cluster UID of the AlloyDB cluster.",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "BackupApplianceBackupProperties": {
      "id": "BackupApplianceBackupProperties",
      "properties": {
        "finalizeTime": {
          "description": "Output only. The time when this backup object was finalized (if none, backup is not finalized).",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "recoveryRangeEndTime": {
          "format": "google-datetime",
          "type": "string",
          "description": "Optional. The latest timestamp of data available in this Backup."
        },
        "generationId": {
          "readOnly": true,
          "type": "integer",
          "description": "Output only. The numeric generation ID of the backup (monotonically increasing).",
          "format": "int32"
        },
        "recoveryRangeStartTime": {
          "type": "string",
          "description": "Optional. The earliest timestamp of data available in this Backup.",
          "format": "google-datetime"
        }
      },
      "description": "BackupApplianceBackupProperties represents BackupDR backup appliance's properties.",
      "type": "object"
    },
    "FetchMsComplianceMetadataRequest": {
      "type": "object",
      "description": "Request message for GetMsComplianceMetadata",
      "id": "FetchMsComplianceMetadataRequest",
      "properties": {
        "projectId": {
          "description": "Required. The project id of the target project",
          "type": "string"
        }
      }
    },
    "NodeAffinity": {
      "id": "NodeAffinity",
      "properties": {
        "key": {
          "description": "Optional. Corresponds to the label key of Node resource.",
          "type": "string"
        },
        "values": {
          "type": "array",
          "description": "Optional. Corresponds to the label values of Node resource.",
          "items": {
            "type": "string"
          }
        },
        "operator": {
          "description": "Optional. Defines the operation of node selection.",
          "enum": [
            "OPERATOR_UNSPECIFIED",
            "IN",
            "NOT_IN"
          ],
          "type": "string",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Requires Compute Engine to seek for matched nodes.",
            "Requires Compute Engine to avoid certain nodes."
          ]
        }
      },
      "description": "Node Affinity: the configuration of desired nodes onto which this Instance could be scheduled.",
      "type": "object"
    },
    "Binding": {
      "type": "object",
      "description": "Associates `members`, or principals, with a `role`.",
      "id": "Binding",
      "properties": {
        "members": {
          "type": "array",
          "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`.",
          "items": {
            "type": "string"
          }
        },
        "role": {
          "type": "string",
          "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)."
        },
        "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"
        }
      }
    },
    "Scheduling": {
      "description": "Sets the scheduling options for an Instance.",
      "type": "object",
      "id": "Scheduling",
      "properties": {
        "nodeAffinities": {
          "description": "Optional. A set of node affinity and anti-affinity configurations. Overrides reservationAffinity.",
          "type": "array",
          "items": {
            "$ref": "NodeAffinity"
          }
        },
        "onHostMaintenance": {
          "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."
          ],
          "description": "Optional. Defines the maintenance behavior for this instance.",
          "enum": [
            "ON_HOST_MAINTENANCE_UNSPECIFIED",
            "TERMINATE",
            "MIGRATE"
          ],
          "type": "string"
        },
        "minNodeCpus": {
          "format": "int32",
          "description": "Optional. The minimum number of virtual CPUs this instance will consume when running on a sole-tenant node.",
          "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": {
          "type": "boolean",
          "description": "Optional. Defines whether the instance is preemptible."
        },
        "instanceTerminationAction": {
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Delete the VM.",
            "Stop the VM without storing in-memory content. default action."
          ],
          "type": "string",
          "description": "Optional. Specifies the termination action for the instance.",
          "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"
        },
        "provisioningModel": {
          "type": "string",
          "description": "Optional. Specifies the provisioning model of the instance.",
          "enum": [
            "PROVISIONING_MODEL_UNSPECIFIED",
            "STANDARD",
            "SPOT"
          ],
          "enumDescriptions": [
            "Default value. This value is not used.",
            "Standard provisioning with user controlled runtime, no discounts.",
            "Heavily discounted, no guaranteed runtime."
          ]
        }
      }
    },
    "AliasIpRange": {
      "description": "An alias IP range attached to an instance's network interface.",
      "type": "object",
      "id": "AliasIpRange",
      "properties": {
        "ipCidrRange": {
          "type": "string",
          "description": "Optional. The IP alias ranges to allocate for this interface."
        },
        "subnetworkRangeName": {
          "type": "string",
          "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."
        }
      }
    },
    "AllocationAffinity": {
      "id": "AllocationAffinity",
      "properties": {
        "key": {
          "type": "string",
          "description": "Optional. Corresponds to the label key of a reservation resource."
        },
        "values": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Optional. Corresponds to the label values of a reservation resource."
        },
        "consumeReservationType": {
          "description": "Optional. Specifies the type of reservation from which this instance can consume",
          "enum": [
            "TYPE_UNSPECIFIED",
            "NO_RESERVATION",
            "ANY_RESERVATION",
            "SPECIFIC_RESERVATION"
          ],
          "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."
          ]
        }
      },
      "description": "Specifies the reservations that this instance can consume from.",
      "type": "object"
    },
    "FilestoreInstanceBackupProperties": {
      "type": "object",
      "description": "FilestoreInstanceBackupProperties represents the properties of a Filestore instance that are backed up by the datasource. .",
      "id": "FilestoreInstanceBackupProperties",
      "properties": {
        "sourceInstance": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The source instance of the backup."
        }
      }
    },
    "Empty": {
      "id": "Empty",
      "properties": {},
      "type": "object",
      "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); }"
    },
    "ListBackupsResponse": {
      "description": "Response message for listing Backups.",
      "type": "object",
      "id": "ListBackupsResponse",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "A token identifying a page of results the server should return."
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        },
        "backups": {
          "items": {
            "$ref": "Backup"
          },
          "type": "array",
          "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."
        }
      }
    },
    "RuleConfigInfo": {
      "type": "object",
      "description": "Message for rules config info.",
      "id": "RuleConfigInfo",
      "properties": {
        "lastBackupError": {
          "description": "Output only. google.rpc.Status object to store the last backup error.",
          "$ref": "Status",
          "readOnly": true
        },
        "lastSuccessfulBackupConsistencyTime": {
          "description": "Output only. The point in time when the last successful backup was captured from the source.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "ruleId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Backup Rule id fetched from backup plan."
        },
        "lastBackupState": {
          "description": "Output only. The last backup state for rule.",
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "PERMISSION_DENIED",
            "SUCCEEDED",
            "FAILED"
          ],
          "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."
          ],
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "BackupDrTemplateConfig": {
      "description": "Provides additional information about Google Cloud Backup and DR's Template backup configuration.",
      "type": "object",
      "id": "BackupDrTemplateConfig",
      "properties": {
        "firstPartyManagementUri": {
          "description": "Output only. The URI of the BackupDr template resource for the first party identity users.",
          "readOnly": true,
          "type": "string"
        },
        "thirdPartyManagementUri": {
          "description": "Output only. The URI of the BackupDr template resource for the third party identity users.",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "DiskBackupPlanProperties": {
      "id": "DiskBackupPlanProperties",
      "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"
        }
      },
      "type": "object",
      "description": "--- DiskBackupPlanProperties Message ---"
    },
    "CloudSqlInstanceBackupProperties": {
      "id": "CloudSqlInstanceBackupProperties",
      "properties": {
        "databaseInstalledVersion": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The installed database version of the Cloud SQL instance when the backup was taken."
        },
        "instanceDeleteTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The instance delete timestamp.",
          "format": "google-datetime"
        },
        "sourceInstance": {
          "description": "Output only. The source instance of the backup. Format: projects/{project}/instances/{instance}",
          "readOnly": true,
          "type": "string"
        },
        "instanceCreateTime": {
          "format": "google-datetime",
          "description": "Output only. The instance creation timestamp.",
          "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`"
        },
        "finalBackup": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. Whether the backup is a final backup."
        }
      },
      "description": "CloudSqlInstanceBackupProperties represents Cloud SQL Instance Backup properties.",
      "type": "object"
    },
    "ListDataSourceReferencesResponse": {
      "description": "Response for the ListDataSourceReferences method.",
      "type": "object",
      "id": "ListDataSourceReferencesResponse",
      "properties": {
        "dataSourceReferences": {
          "items": {
            "$ref": "DataSourceReference"
          },
          "type": "array",
          "description": "The DataSourceReferences from the specified parent."
        },
        "nextPageToken": {
          "type": "string",
          "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."
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        }
      }
    },
    "CustomerEncryptionKey": {
      "id": "CustomerEncryptionKey",
      "properties": {
        "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": {
          "type": "string",
          "description": "Optional. RSA-wrapped 2048-bit customer-supplied encryption key to either encrypt or decrypt this resource."
        },
        "rawKey": {
          "description": "Optional. Specifies a 256-bit customer-supplied encryption key.",
          "type": "string"
        },
        "kmsKeyName": {
          "type": "string",
          "description": "Optional. The name of the encryption key that is stored in Google Cloud KMS."
        }
      },
      "type": "object",
      "description": "A customer-supplied encryption key."
    },
    "Entry": {
      "id": "Entry",
      "properties": {
        "key": {
          "type": "string",
          "description": "Optional. Key for the metadata entry."
        },
        "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"
        }
      },
      "type": "object",
      "description": "A key/value pair to be used for storing metadata."
    },
    "TargetResource": {
      "id": "TargetResource",
      "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.",
      "type": "object"
    },
    "ComputeInstanceTargetEnvironment": {
      "type": "object",
      "description": "ComputeInstanceTargetEnvironment represents Compute Engine target environment to be used during restore.",
      "id": "ComputeInstanceTargetEnvironment",
      "properties": {
        "zone": {
          "type": "string",
          "description": "Required. The zone of the Compute Engine instance."
        },
        "project": {
          "type": "string",
          "description": "Required. Target project for the Compute Engine instance."
        }
      }
    },
    "GCPBackupPlanInfo": {
      "type": "object",
      "description": "GCPBackupPlanInfo captures the plan configuration details of Google Cloud resources at the time of backup.",
      "id": "GCPBackupPlanInfo",
      "properties": {
        "backupPlanRuleId": {
          "type": "string",
          "description": "The rule id of the backup plan which triggered this backup in case of scheduled backup or used for"
        },
        "backupPlan": {
          "type": "string",
          "description": "Resource name of backup plan by which workload is protected at the time of the backup. Format: projects/{project}/locations/{location}/backupPlans/{backupPlanId}"
        },
        "backupPlanRevisionName": {
          "type": "string",
          "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}"
        },
        "backupPlanRevisionId": {
          "type": "string",
          "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."
        }
      }
    },
    "BackupGcpResource": {
      "id": "BackupGcpResource",
      "properties": {
        "type": {
          "description": "Type of the resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance.",
          "type": "string"
        },
        "location": {
          "description": "Location of the resource: //\"global\"/\"unspecified\".",
          "type": "string"
        },
        "gcpResourcename": {
          "type": "string",
          "description": "Name of the Google Cloud resource."
        }
      },
      "type": "object",
      "description": "Minimum details to identify a Google Cloud resource for a backup."
    },
    "ComputeInstanceDataSourceProperties": {
      "type": "object",
      "description": "ComputeInstanceDataSourceProperties represents the properties of a ComputeEngine resource that are stored in the DataSource.",
      "id": "ComputeInstanceDataSourceProperties",
      "properties": {
        "totalDiskSizeGb": {
          "format": "int64",
          "description": "The sum of all the disk sizes.",
          "type": "string"
        },
        "name": {
          "description": "Name of the compute instance backed up by the datasource.",
          "type": "string"
        },
        "machineType": {
          "description": "The machine type of the instance.",
          "type": "string"
        },
        "totalDiskCount": {
          "format": "int64",
          "description": "The total number of disks attached to the Instance.",
          "type": "string"
        },
        "description": {
          "type": "string",
          "description": "The description of the Compute Engine instance."
        }
      }
    },
    "ListBackupPlanAssociationsResponse": {
      "id": "ListBackupPlanAssociationsResponse",
      "properties": {
        "backupPlanAssociations": {
          "items": {
            "$ref": "BackupPlanAssociation"
          },
          "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"
        },
        "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"
          }
        }
      },
      "description": "Response message for List BackupPlanAssociation",
      "type": "object"
    },
    "DataSourceBackupConfigInfo": {
      "description": "Information of backup configuration on the DataSource.",
      "type": "object",
      "id": "DataSourceBackupConfigInfo",
      "properties": {
        "lastBackupState": {
          "description": "Output only. The status of the last backup in this DataSource",
          "enum": [
            "LAST_BACKUP_STATE_UNSPECIFIED",
            "FIRST_BACKUP_PENDING",
            "SUCCEEDED",
            "FAILED",
            "PERMISSION_DENIED"
          ],
          "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"
          ],
          "readOnly": true,
          "type": "string"
        },
        "lastSuccessfulBackupConsistencyTime": {
          "format": "google-datetime",
          "readOnly": true,
          "type": "string",
          "description": "Output only. Timestamp of the last successful backup to this DataSource."
        }
      }
    },
    "BackupPlanAssociation": {
      "id": "BackupPlanAssociation",
      "properties": {
        "alloydbClusterBackupPlanAssociationProperties": {
          "description": "Output only. AlloyDB cluster's backup plan association properties.",
          "$ref": "AlloyDBClusterBackupPlanAssociationProperties",
          "readOnly": true
        },
        "backupPlan": {
          "type": "string",
          "description": "Required. Resource name of backup plan which needs to be applied on workload. Format: projects/{project}/locations/{location}/backupPlans/{backupPlanId}"
        },
        "filestoreInstanceBackupPlanAssociationProperties": {
          "readOnly": true,
          "description": "Output only. Filestore instance's backup plan association properties.",
          "$ref": "FilestoreInstanceBackupPlanAssociationProperties"
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "state": {
          "description": "Output only. The BackupPlanAssociation resource state.",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE",
            "UPDATING"
          ],
          "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."
          ]
        },
        "createTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the instance was created.",
          "readOnly": true,
          "type": "string"
        },
        "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"
        },
        "resourceType": {
          "type": "string",
          "description": "Required. Immutable. Resource type of workload on which backupplan is applied"
        },
        "dataSource": {
          "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}",
          "readOnly": true,
          "type": "string"
        },
        "rulesConfigInfo": {
          "description": "Output only. The config info related to backup rules.",
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "RuleConfigInfo"
          }
        },
        "backupPlanRevisionId": {
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc.",
          "readOnly": true,
          "type": "string"
        },
        "cloudSqlInstanceBackupPlanAssociationProperties": {
          "readOnly": true,
          "description": "Output only. Cloud SQL instance's backup plan association properties.",
          "$ref": "CloudSqlInstanceBackupPlanAssociationProperties"
        },
        "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"
        },
        "name": {
          "description": "Output only. Identifier. The resource name of BackupPlanAssociation in below format Format : projects/{project}/locations/{location}/backupPlanAssociations/{backupPlanAssociationId}",
          "readOnly": true,
          "type": "string"
        }
      },
      "type": "object",
      "description": "A BackupPlanAssociation represents a single BackupPlanAssociation which contains details like workload, backup plan etc"
    },
    "ManagementURI": {
      "type": "object",
      "description": "ManagementURI for the Management Server resource.",
      "id": "ManagementURI",
      "properties": {
        "webUi": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The ManagementServer AGM/RD WebUI URL."
        },
        "api": {
          "description": "Output only. The ManagementServer AGM/RD API URL.",
          "readOnly": true,
          "type": "string"
        }
      }
    },
    "BackupPlan": {
      "id": "BackupPlan",
      "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"
        },
        "computeInstanceBackupPlanProperties": {
          "description": "Optional. Defines optional properties specific to backups of disk-based resources, such as Compute Engine. This includes settings like whether to perform a guest flush.",
          "$ref": "ComputeInstanceBackupPlanProperties"
        },
        "createTime": {
          "description": "Output only. When the `BackupPlan` was created.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "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"
        },
        "updateTime": {
          "format": "google-datetime",
          "description": "Output only. When the `BackupPlan` was last updated.",
          "readOnly": true,
          "type": "string"
        },
        "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."
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. This collection of key/value pairs allows for custom labels to be supplied by the user. Example, {\"tag\": \"Weekly\"}.",
          "type": "object"
        },
        "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."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The `State` for the `BackupPlan`.",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "INACTIVE",
            "UPDATING"
          ]
        },
        "supportedResourceTypes": {
          "items": {
            "type": "string"
          },
          "readOnly": true,
          "type": "array",
          "description": "Output only. All resource types to which backupPlan can be applied."
        },
        "maxCustomOnDemandRetentionDays": {
          "format": "int32",
          "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."
        },
        "revisionId": {
          "description": "Output only. The user friendly revision ID of the `BackupPlanRevision`. Example: v0, v1, v2, etc.",
          "readOnly": true,
          "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"
        },
        "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.",
          "type": "string",
          "format": "int64"
        },
        "resourceType": {
          "type": "string",
          "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\"."
        },
        "backupRules": {
          "items": {
            "$ref": "BackupRule"
          },
          "description": "Optional. The backup rules for this `BackupPlan`.",
          "type": "array"
        },
        "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"
        },
        "description": {
          "type": "string",
          "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."
        },
        "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}`"
        }
      },
      "type": "object",
      "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."
    },
    "AuditLogConfig": {
      "id": "AuditLogConfig",
      "properties": {
        "exemptedMembers": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members."
        },
        "logType": {
          "enumDescriptions": [
            "Default case. Should never be this.",
            "Admin reads. Example: CloudIAM getIamPolicy",
            "Data writes. Example: CloudSQL Users create",
            "Data reads. Example: CloudSQL Users list"
          ],
          "description": "The log type that this config enables.",
          "enum": [
            "LOG_TYPE_UNSPECIFIED",
            "ADMIN_READ",
            "DATA_WRITE",
            "DATA_READ"
          ],
          "type": "string"
        }
      },
      "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.",
      "type": "object"
    },
    "BackupDrPlanRule": {
      "type": "object",
      "description": "BackupDrPlanRule has rule specific information of the backup plan resource.",
      "id": "BackupDrPlanRule",
      "properties": {
        "ruleId": {
          "description": "Output only. Unique Id of the backup rule.",
          "readOnly": true,
          "type": "string"
        },
        "lastSuccessfulBackupTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Timestamp of the latest successful backup created via this backup rule.",
          "format": "google-datetime"
        }
      }
    },
    "DiskBackupProperties": {
      "description": "DiskBackupProperties represents the properties of a Disk backup.",
      "type": "object",
      "id": "DiskBackupProperties",
      "properties": {
        "provisionedIops": {
          "format": "int64",
          "description": "The number of IOPS provisioned for the source disk.",
          "type": "string"
        },
        "labels": {
          "description": "The labels of the source disk.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "licenses": {
          "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.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "accessMode": {
          "type": "string",
          "description": "The access mode of the source disk."
        },
        "type": {
          "type": "string",
          "description": "The URL of the type of the disk."
        },
        "provisionedThroughput": {
          "format": "int64",
          "description": "The number of throughput provisioned for the source disk.",
          "type": "string"
        },
        "sourceDisk": {
          "description": "The source disk used to create this backup.",
          "type": "string"
        },
        "storagePool": {
          "description": "The storage pool of the source disk.",
          "type": "string"
        },
        "physicalBlockSizeBytes": {
          "type": "string",
          "description": "The physical block size of the source disk.",
          "format": "int64"
        },
        "description": {
          "description": "A description of the source disk.",
          "type": "string"
        },
        "zone": {
          "description": "The URL of the Zone where the source disk.",
          "type": "string"
        },
        "guestOsFeature": {
          "type": "array",
          "description": "A list of guest OS features that are applicable to this backup.",
          "items": {
            "$ref": "GuestOsFeature"
          }
        },
        "region": {
          "description": "Region and zone are mutually exclusive fields. The URL of the region of the source disk.",
          "type": "string"
        },
        "architecture": {
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Disks with architecture X86_64",
            "Disks with architecture ARM64"
          ],
          "description": "The architecture of the source disk. Valid values are ARM64 or X86_64.",
          "enum": [
            "ARCHITECTURE_UNSPECIFIED",
            "X86_64",
            "ARM64"
          ],
          "type": "string"
        },
        "enableConfidentialCompute": {
          "type": "boolean",
          "description": "Indicates whether the source disk is using confidential compute mode."
        },
        "sizeGb": {
          "description": "Size(in GB) of the source disk.",
          "type": "string",
          "format": "int64"
        },
        "replicaZones": {
          "type": "array",
          "description": "The URL of the Zones where the source disk should be replicated.",
          "items": {
            "type": "string"
          }
        },
        "guestFlush": {
          "description": "Optional. Defines if the guest flush is enabled for the source disk. Default value is false.",
          "type": "boolean"
        }
      }
    },
    "DataSourceBackupApplianceApplication": {
      "description": "BackupApplianceApplication describes a Source Resource when it is an application backed up by a BackupAppliance.",
      "type": "object",
      "id": "DataSourceBackupApplianceApplication",
      "properties": {
        "applicationId": {
          "format": "int64",
          "description": "The appid field of the application within the Backup Appliance.",
          "type": "string"
        },
        "hostname": {
          "description": "Hostname of the host where the application is running.",
          "type": "string"
        },
        "hostId": {
          "type": "string",
          "description": "Hostid of the application host.",
          "format": "int64"
        },
        "applicationName": {
          "description": "The name of the Application as known to the Backup Appliance.",
          "type": "string"
        },
        "backupAppliance": {
          "type": "string",
          "description": "Appliance name."
        },
        "applianceId": {
          "description": "Appliance Id of the Backup Appliance.",
          "type": "string",
          "format": "int64"
        },
        "type": {
          "type": "string",
          "description": "The type of the application. e.g. VMBackup"
        }
      }
    },
    "BackupLock": {
      "id": "BackupLock",
      "properties": {
        "backupApplianceLockInfo": {
          "description": "If the client is a backup and recovery appliance, this contains metadata about why the lock exists.",
          "$ref": "BackupApplianceLockInfo"
        },
        "lockUntilTime": {
          "type": "string",
          "description": "Required. The time after which this lock is not considered valid and will no longer protect the Backup from deletion.",
          "format": "google-datetime"
        },
        "serviceLockInfo": {
          "readOnly": true,
          "description": "Output only. Contains metadata about the lock exist for Google Cloud native backups.",
          "$ref": "ServiceLockInfo"
        }
      },
      "type": "object",
      "description": "BackupLock represents a single lock on a Backup resource. An unexpired lock on a Backup prevents the Backup from being deleted."
    },
    "ListDataSourcesResponse": {
      "type": "object",
      "description": "Response message for listing DataSources.",
      "id": "ListDataSourcesResponse",
      "properties": {
        "dataSources": {
          "type": "array",
          "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.",
          "items": {
            "$ref": "DataSource"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        },
        "unreachable": {
          "type": "array",
          "description": "Locations that could not be reached.",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ListOperationsResponse": {
      "description": "The response message for Operations.ListOperations.",
      "type": "object",
      "id": "ListOperationsResponse",
      "properties": {
        "operations": {
          "items": {
            "$ref": "Operation"
          },
          "description": "A list of operations that matches the specified filter in the request.",
          "type": "array"
        },
        "nextPageToken": {
          "type": "string",
          "description": "The standard List next-page token."
        },
        "unreachable": {
          "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.",
          "type": "array"
        }
      }
    },
    "ComputeInstanceRestoreProperties": {
      "id": "ComputeInstanceRestoreProperties",
      "properties": {
        "reservationAffinity": {
          "description": "Optional. Specifies the reservations that this instance can consume from.",
          "$ref": "AllocationAffinity"
        },
        "scheduling": {
          "description": "Optional. Sets the scheduling options for this instance.",
          "$ref": "Scheduling"
        },
        "description": {
          "type": "string",
          "description": "Optional. An optional description of this resource. Provide this property when you create the resource."
        },
        "displayDevice": {
          "description": "Optional. Enables display device for the instance.",
          "$ref": "DisplayDevice"
        },
        "confidentialInstanceConfig": {
          "description": "Optional. Controls Confidential compute options on the instance",
          "$ref": "ConfidentialInstanceConfig"
        },
        "networkPerformanceConfig": {
          "description": "Optional. Configure network performance such as egress bandwidth tier.",
          "$ref": "NetworkPerformanceConfig"
        },
        "minCpuPlatform": {
          "type": "string",
          "description": "Optional. Minimum CPU platform to use for this instance."
        },
        "guestAccelerators": {
          "items": {
            "$ref": "AcceleratorConfig"
          },
          "type": "array",
          "description": "Optional. A list of the type and count of accelerator cards attached to the instance."
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Optional. Labels to apply to this instance.",
          "type": "object"
        },
        "advancedMachineFeatures": {
          "description": "Optional. Controls for advanced machine-related behavior features.",
          "$ref": "AdvancedMachineFeatures"
        },
        "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"
        },
        "serviceAccounts": {
          "items": {
            "$ref": "ServiceAccount"
          },
          "type": "array",
          "description": "Optional. A list of service accounts, with their specified scopes, authorized for this instance. Only one service account per VM instance is supported."
        },
        "params": {
          "description": "Input only. Additional params passed with the request, but not persisted as part of resource payload.",
          "$ref": "InstanceParams"
        },
        "name": {
          "description": "Required. Name of the compute instance.",
          "type": "string"
        },
        "canIpForward": {
          "type": "boolean",
          "description": "Optional. Allows this instance to send and receive packets with non-matching destination or source IPs."
        },
        "instanceEncryptionKey": {
          "description": "Optional. Encrypts suspended data for an instance with a customer-managed encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "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"
        },
        "privateIpv6GoogleAccess": {
          "description": "Optional. The private IPv6 google access type for the VM. If not specified, use INHERIT_FROM_SUBNETWORK as default.",
          "enum": [
            "INSTANCE_PRIVATE_IPV6_GOOGLE_ACCESS_UNSPECIFIED",
            "INHERIT_FROM_SUBNETWORK",
            "ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE",
            "ENABLE_BIDIRECTIONAL_ACCESS_TO_GOOGLE"
          ],
          "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."
          ]
        },
        "machineType": {
          "type": "string",
          "description": "Optional. Full or partial URL of the machine type resource to use for this instance."
        },
        "networkInterfaces": {
          "items": {
            "$ref": "NetworkInterface"
          },
          "type": "array",
          "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."
        },
        "keyRevocationActionType": {
          "type": "string",
          "description": "Optional. KeyRevocationActionType of the instance.",
          "enum": [
            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
            "NONE",
            "STOP"
          ],
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Indicates user chose no operation.",
            "Indicates user chose to opt for VM shutdown on key revocation."
          ]
        },
        "resourcePolicies": {
          "description": "Optional. Resource policies applied to this instance. By default, no resource policies will be applied.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "deletionProtection": {
          "description": "Optional. Whether the resource should be protected against deletion.",
          "type": "boolean"
        },
        "disks": {
          "items": {
            "$ref": "AttachedDisk"
          },
          "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"
        },
        "metadata": {
          "description": "Optional. This includes custom metadata and predefined keys.",
          "$ref": "Metadata"
        }
      },
      "type": "object",
      "description": "ComputeInstanceRestoreProperties represents Compute Engine instance properties to be overridden during restore."
    },
    "DataSourceReference": {
      "description": "DataSourceReference is a reference to a DataSource resource.",
      "type": "object",
      "id": "DataSourceReference",
      "properties": {
        "dataSourceBackupConfigInfo": {
          "description": "Output only. Information of backup configuration on the DataSource.",
          "$ref": "DataSourceBackupConfigInfo",
          "readOnly": true
        },
        "totalStoredBytes": {
          "format": "int64",
          "description": "Output only. Total size of the storage used by all backup resources for the referenced datasource.",
          "readOnly": true,
          "type": "string"
        },
        "dataSourceBackupCount": {
          "description": "Output only. Number of backups in the DataSource.",
          "readOnly": true,
          "type": "string",
          "format": "int64"
        },
        "dataSource": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The resource name of the DataSource. Format: projects/{project}/locations/{location}/backupVaults/{backupVault}/dataSources/{dataSource}"
        },
        "name": {
          "description": "Identifier. The resource name of the DataSourceReference. Format: projects/{project}/locations/{location}/dataSourceReferences/{data_source_reference}",
          "type": "string"
        },
        "createTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the DataSourceReference was created.",
          "readOnly": true,
          "type": "string"
        },
        "dataSourceBackupConfigState": {
          "readOnly": true,
          "type": "string",
          "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)"
          ],
          "description": "Output only. The backup configuration state of the DataSource.",
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ]
        },
        "dataSourceGcpResourceInfo": {
          "description": "Output only. The Google Cloud resource that the DataSource is associated with.",
          "$ref": "DataSourceGcpResourceInfo",
          "readOnly": true
        }
      }
    },
    "FetchDataSourceReferencesForResourceTypeResponse": {
      "description": "Response for the FetchDataSourceReferencesForResourceType method.",
      "type": "object",
      "id": "FetchDataSourceReferencesForResourceTypeResponse",
      "properties": {
        "dataSourceReferences": {
          "type": "array",
          "description": "The DataSourceReferences from the specified parent.",
          "items": {
            "$ref": "DataSourceReference"
          }
        },
        "nextPageToken": {
          "type": "string",
          "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."
        }
      }
    },
    "SchedulingDuration": {
      "type": "object",
      "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",
      "properties": {
        "seconds": {
          "description": "Optional. Span of time at a resolution of a second.",
          "type": "string",
          "format": "int64"
        },
        "nanos": {
          "type": "integer",
          "description": "Optional. Span of time that's a fraction of a second at nanosecond resolution.",
          "format": "int32"
        }
      }
    },
    "BackupApplianceLockInfo": {
      "description": "BackupApplianceLockInfo contains metadata about the backupappliance that created the lock.",
      "type": "object",
      "id": "BackupApplianceLockInfo",
      "properties": {
        "backupImage": {
          "type": "string",
          "description": "The image name that depends on this Backup."
        },
        "slaId": {
          "type": "string",
          "description": "The SLA on the backup/recovery appliance that owns the lock.",
          "format": "int64"
        },
        "jobName": {
          "description": "The job name on the backup/recovery appliance that created this lock.",
          "type": "string"
        },
        "backupApplianceName": {
          "description": "Required. The name of 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"
        },
        "backupApplianceId": {
          "format": "int64",
          "description": "Required. The ID of the backup/recovery appliance that created this lock.",
          "type": "string"
        }
      }
    },
    "TestIamPermissionsResponse": {
      "id": "TestIamPermissionsResponse",
      "properties": {
        "permissions": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "A subset of `TestPermissionsRequest.permissions` that the caller is allowed."
        }
      },
      "type": "object",
      "description": "Response message for `TestIamPermissions` method."
    },
    "AlloyDBClusterDataSourceProperties": {
      "id": "AlloyDBClusterDataSourceProperties",
      "properties": {
        "pitrWindows": {
          "readOnly": true,
          "type": "array",
          "description": "Output only. Point in time recovery windows. The order is guaranteed to be ascending by start time.",
          "items": {
            "$ref": "AlloyDbPitrWindow"
          }
        },
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the AlloyDB cluster backed up by the datasource."
        },
        "clusterUid": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The cluster UID of the AlloyDB cluster backed up by the datasource."
        }
      },
      "type": "object",
      "description": "AlloyDBClusterDataSourceProperties represents the properties of a AlloyDB cluster resource that are stored in the DataSource. ."
    },
    "AdvancedMachineFeatures": {
      "description": "Specifies options for controlling advanced machine features.",
      "type": "object",
      "id": "AdvancedMachineFeatures",
      "properties": {
        "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"
        },
        "visibleCoreCount": {
          "format": "int32",
          "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.",
          "type": "integer"
        },
        "enableUefiNetworking": {
          "description": "Optional. Whether to enable UEFI networking for instance creation.",
          "type": "boolean"
        }
      }
    },
    "ListBackupVaultsResponse": {
      "id": "ListBackupVaultsResponse",
      "properties": {
        "backupVaults": {
          "type": "array",
          "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.",
          "items": {
            "$ref": "BackupVault"
          }
        },
        "nextPageToken": {
          "type": "string",
          "description": "A token identifying a page of results the server should return."
        },
        "unreachable": {
          "type": "array",
          "description": "Locations that could not be reached.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object",
      "description": "Response message for listing BackupVaults."
    },
    "BackupWindow": {
      "type": "object",
      "description": "`BackupWindow` defines a window of the day during which backup jobs will run.",
      "id": "BackupWindow",
      "properties": {
        "startHourOfDay": {
          "format": "int32",
          "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."
        },
        "endHourOfDay": {
          "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.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "DataSourceGcpResource": {
      "id": "DataSourceGcpResource",
      "properties": {
        "cloudSqlInstanceDatasourceProperties": {
          "readOnly": true,
          "description": "Output only. CloudSqlInstanceDataSourceProperties has a subset of Cloud SQL Instance properties that are useful at the Datasource level.",
          "$ref": "CloudSqlInstanceDataSourceProperties"
        },
        "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"
        },
        "filestoreInstanceDatasourceProperties": {
          "readOnly": true,
          "description": "Output only. FilestoreInstanceDataSourceProperties has a subset of FileStore instance properties that are useful at the Datasource level.",
          "$ref": "FilestoreInstanceDataSourceProperties"
        },
        "location": {
          "type": "string",
          "description": "Location of the resource: //\"global\"/\"unspecified\"."
        },
        "type": {
          "type": "string",
          "description": "The type of the Google Cloud resource. Use the Unified Resource Type, eg. compute.googleapis.com/Instance."
        },
        "alloyDbClusterDatasourceProperties": {
          "readOnly": true,
          "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.",
          "$ref": "AlloyDBClusterDataSourceProperties"
        },
        "computeInstanceDatasourceProperties": {
          "description": "ComputeInstanceDataSourceProperties has a subset of Compute Instance properties that are useful at the Datasource level.",
          "$ref": "ComputeInstanceDataSourceProperties"
        }
      },
      "description": "DataSourceGcpResource is used for protected resources that are Google Cloud Resources. This name is easeier to understand than GcpResourceDataSource or GcpDataSourceResource",
      "type": "object"
    },
    "ServiceAccount": {
      "description": "A service account.",
      "type": "object",
      "id": "ServiceAccount",
      "properties": {
        "email": {
          "type": "string",
          "description": "Optional. Email address of the service account."
        },
        "scopes": {
          "items": {
            "type": "string"
          },
          "description": "Optional. The list of scopes to be made available for this service account.",
          "type": "array"
        }
      }
    },
    "DataSource": {
      "id": "DataSource",
      "properties": {
        "state": {
          "description": "Output only. The DataSource resource instance state.",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR"
          ],
          "readOnly": true,
          "type": "string",
          "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."
          ]
        },
        "labels": {
          "additionalProperties": {
            "type": "string"
          },
          "type": "object",
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined:"
        },
        "backupCount": {
          "description": "Number of backups in the data source.",
          "type": "string",
          "format": "int64"
        },
        "updateTime": {
          "description": "Output only. The time when the instance was updated.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "createTime": {
          "description": "Output only. The time when the instance was created.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "etag": {
          "description": "Server specified ETag for the ManagementServer resource to prevent simultaneous updates from overwiting each other.",
          "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"
        },
        "totalStoredBytes": {
          "format": "int64",
          "description": "The number of bytes (metadata and data) stored in this datasource.",
          "type": "string"
        },
        "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.",
          "readOnly": true,
          "type": "string"
        },
        "backupBlockedByVaultAccessRestriction": {
          "readOnly": true,
          "type": "boolean",
          "description": "Output only. This field is set to true if the backup is blocked by vault access restriction."
        },
        "configState": {
          "readOnly": true,
          "type": "string",
          "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)"
          ],
          "description": "Output only. The backup configuration state.",
          "enum": [
            "BACKUP_CONFIG_STATE_UNSPECIFIED",
            "ACTIVE",
            "PASSIVE"
          ]
        },
        "backupConfigInfo": {
          "description": "Output only. Details of how the resource is configured for backup.",
          "$ref": "BackupConfigInfo",
          "readOnly": true
        }
      },
      "description": "Message describing a DataSource object. Datasource object used to represent Datasource details for both admin and basic view.",
      "type": "object"
    },
    "RestoreBackupResponse": {
      "id": "RestoreBackupResponse",
      "properties": {
        "targetResource": {
          "description": "Details of the target resource created/modified as part of restore.",
          "$ref": "TargetResource"
        }
      },
      "description": "Response message for restoring from a Backup.",
      "type": "object"
    },
    "SubscribeTrialRequest": {
      "description": "Request message for subscribing to a trial.",
      "type": "object",
      "id": "SubscribeTrialRequest",
      "properties": {}
    },
    "InitiateBackupResponse": {
      "type": "object",
      "description": "Response message for InitiateBackup.",
      "id": "InitiateBackupResponse",
      "properties": {
        "newBackupGenerationId": {
          "type": "integer",
          "description": "The generation id of the new backup.",
          "format": "int32"
        },
        "backup": {
          "description": "The name of the backup that was created.",
          "type": "string"
        },
        "baseBackupGenerationId": {
          "format": "int32",
          "description": "The generation id of the base backup. It is needed for the incremental backups.",
          "type": "integer"
        }
      }
    },
    "Backup": {
      "type": "object",
      "description": "Message describing a Backup object.",
      "id": "Backup",
      "properties": {
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was created.",
          "format": "google-datetime"
        },
        "etag": {
          "description": "Optional. Server specified ETag to prevent updates from overwriting each other.",
          "type": "string"
        },
        "updateTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the instance was updated.",
          "format": "google-datetime"
        },
        "serviceLocks": {
          "readOnly": true,
          "type": "array",
          "description": "Output only. The list of BackupLocks taken by the service to prevent the deletion of the backup.",
          "items": {
            "$ref": "BackupLock"
          }
        },
        "backupApplianceLocks": {
          "description": "Optional. The list of BackupLocks taken by the accessor Backup Appliance.",
          "type": "array",
          "items": {
            "$ref": "BackupLock"
          }
        },
        "consistencyTime": {
          "format": "google-datetime",
          "description": "Output only. The point in time when this backup was captured from the source.",
          "readOnly": true,
          "type": "string"
        },
        "satisfiesPzs": {
          "description": "Optional. Output only. Reserved for future use.",
          "readOnly": true,
          "type": "boolean"
        },
        "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."
        },
        "computeInstanceBackupProperties": {
          "description": "Output only. Compute Engine specific backup properties.",
          "$ref": "ComputeInstanceBackupProperties",
          "readOnly": true
        },
        "gcpResource": {
          "description": "Output only. Unique identifier of the GCP resource that is being backed up.",
          "$ref": "BackupGcpResource",
          "readOnly": true
        },
        "backupType": {
          "description": "Output only. Type of the backup, unspecified, scheduled or ondemand.",
          "enum": [
            "BACKUP_TYPE_UNSPECIFIED",
            "SCHEDULED",
            "ON_DEMAND",
            "ON_DEMAND_OPERATIONAL"
          ],
          "enumDescriptions": [
            "Backup type is unspecified.",
            "Scheduled backup.",
            "On demand backup.",
            "Operational backup."
          ],
          "readOnly": true,
          "type": "string"
        },
        "expireTime": {
          "format": "google-datetime",
          "description": "Optional. When this backup is automatically expired.",
          "type": "string"
        },
        "satisfiesPzi": {
          "readOnly": true,
          "type": "boolean",
          "description": "Optional. Output only. Reserved for future use."
        },
        "kmsKeyVersions": {
          "readOnly": true,
          "type": "array",
          "description": "Optional. Output only. The list of KMS key versions used to encrypt the backup.",
          "items": {
            "type": "string"
          }
        },
        "labels": {
          "description": "Optional. Resource labels to represent user provided metadata. No labels currently defined.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "state": {
          "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."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Output only. The Backup resource instance state.",
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "ACTIVE",
            "DELETING",
            "ERROR",
            "UPLOADING"
          ]
        },
        "filestoreInstanceBackupProperties": {
          "readOnly": true,
          "description": "Output only. Filestore specific backup properties.",
          "$ref": "FilestoreInstanceBackupProperties"
        },
        "diskBackupProperties": {
          "readOnly": true,
          "description": "Output only. Disk specific backup properties.",
          "$ref": "DiskBackupProperties"
        },
        "resourceSizeBytes": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. source resource size in bytes at the time of the backup.",
          "format": "int64"
        },
        "enforcedRetentionEndTime": {
          "description": "Optional. The backup can not be deleted before this time.",
          "type": "string",
          "format": "google-datetime"
        },
        "gcpBackupPlanInfo": {
          "readOnly": true,
          "description": "Output only. Configuration for a Google Cloud resource.",
          "$ref": "GCPBackupPlanInfo"
        },
        "backupApplianceBackupProperties": {
          "description": "Output only. Backup Appliance specific backup properties.",
          "$ref": "BackupApplianceBackupProperties",
          "readOnly": true
        },
        "cloudSqlInstanceBackupProperties": {
          "readOnly": true,
          "description": "Output only. Cloud SQL specific backup properties.",
          "$ref": "CloudSqlInstanceBackupProperties"
        },
        "backupRetentionInheritance": {
          "description": "Output only. Setting for how the enforced retention end time is inherited. This value is copied from this backup's BackupVault.",
          "enum": [
            "BACKUP_RETENTION_INHERITANCE_UNSPECIFIED",
            "INHERIT_VAULT_RETENTION",
            "MATCH_BACKUP_EXPIRE_TIME"
          ],
          "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."
          ],
          "readOnly": true,
          "type": "string"
        },
        "description": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The description of the Backup instance (2048 characters or less)."
        },
        "alloyDbBackupProperties": {
          "readOnly": true,
          "description": "Output only. AlloyDB specific backup properties.",
          "$ref": "AlloyDbClusterBackupProperties"
        }
      }
    },
    "DiskDataSourceProperties": {
      "id": "DiskDataSourceProperties",
      "properties": {
        "name": {
          "type": "string",
          "description": "Name of the disk backed up by the datasource."
        },
        "description": {
          "description": "The description of the disk.",
          "type": "string"
        },
        "type": {
          "description": "The type of the disk.",
          "type": "string"
        },
        "sizeGb": {
          "type": "string",
          "description": "The size of the disk in GB.",
          "format": "int64"
        }
      },
      "type": "object",
      "description": "DiskDataSourceProperties represents the properties of a Disk resource that are stored in the DataSource. ."
    },
    "ConfidentialInstanceConfig": {
      "id": "ConfidentialInstanceConfig",
      "properties": {
        "enableConfidentialCompute": {
          "description": "Optional. Defines whether the instance should have confidential compute enabled.",
          "type": "boolean"
        }
      },
      "type": "object",
      "description": "A set of Confidential Instance options."
    },
    "ListBackupPlansResponse": {
      "description": "The response message for getting a list of `BackupPlan`.",
      "type": "object",
      "id": "ListBackupPlansResponse",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "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."
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        },
        "backupPlans": {
          "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",
          "type": "array",
          "items": {
            "$ref": "BackupPlan"
          }
        }
      }
    },
    "AcceleratorConfig": {
      "id": "AcceleratorConfig",
      "properties": {
        "acceleratorType": {
          "type": "string",
          "description": "Optional. Full or partial URL of the accelerator type resource to attach to this instance."
        },
        "acceleratorCount": {
          "type": "integer",
          "description": "Optional. The number of the guest accelerator cards exposed to this instance.",
          "format": "int32"
        }
      },
      "description": "A specification of the type and number of accelerator cards attached to the instance.",
      "type": "object"
    },
    "RestoreBackupRequest": {
      "description": "Request message for restoring from a Backup.",
      "type": "object",
      "id": "RestoreBackupRequest",
      "properties": {
        "diskTargetEnvironment": {
          "description": "Disk target environment to be used during restore.",
          "$ref": "DiskTargetEnvironment"
        },
        "computeInstanceRestoreProperties": {
          "description": "Compute Engine instance properties to be overridden during restore.",
          "$ref": "ComputeInstanceRestoreProperties"
        },
        "diskRestoreProperties": {
          "description": "Disk properties to be overridden during restore.",
          "$ref": "DiskRestoreProperties"
        },
        "computeInstanceTargetEnvironment": {
          "description": "Compute Engine target environment to be used during restore.",
          "$ref": "ComputeInstanceTargetEnvironment"
        },
        "regionDiskTargetEnvironment": {
          "description": "Region disk target environment to be used during restore.",
          "$ref": "RegionDiskTargetEnvironment"
        },
        "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`",
          "type": "string",
          "format": "google-fieldmask"
        },
        "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"
        }
      }
    },
    "CloudSqlInstanceDataSourceProperties": {
      "id": "CloudSqlInstanceDataSourceProperties",
      "properties": {
        "name": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Name of the Cloud SQL instance backed up by the datasource. Format: projects/{project}/instances/{instance}"
        },
        "instanceCreateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "type": "string",
          "description": "Output only. The instance creation timestamp."
        },
        "instanceTier": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The tier (or machine type) for this instance. Example: `db-custom-1-3840`"
        },
        "databaseInstalledVersion": {
          "description": "Output only. The installed database version of the Cloud SQL instance.",
          "readOnly": true,
          "type": "string"
        }
      },
      "type": "object",
      "description": "CloudSqlInstanceDataSourceProperties represents the properties of a Cloud SQL resource that are stored in the DataSource."
    },
    "InitiateBackupRequest": {
      "type": "object",
      "description": "request message for InitiateBackup.",
      "id": "InitiateBackupRequest",
      "properties": {
        "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)."
        },
        "backupId": {
          "description": "Required. Resource ID of the Backup resource.",
          "type": "string"
        }
      }
    },
    "RegionDiskTargetEnvironment": {
      "description": "RegionDiskTargetEnvironment represents the target environment for the disk.",
      "type": "object",
      "id": "RegionDiskTargetEnvironment",
      "properties": {
        "replicaZones": {
          "description": "Required. Target URLs of the replica zones for the disk.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "project": {
          "type": "string",
          "description": "Required. Target project for the disk."
        },
        "region": {
          "type": "string",
          "description": "Required. Target region for the disk."
        }
      }
    },
    "AlloyDbPitrWindow": {
      "type": "object",
      "description": "Point in time recovery window for an AlloyDB cluster.",
      "id": "AlloyDbPitrWindow",
      "properties": {
        "startTime": {
          "description": "Output only. The start time of the PITR window.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "logRetentionDays": {
          "format": "int64",
          "readOnly": true,
          "type": "string",
          "description": "Output only. Log retention days for the PITR window."
        },
        "endTime": {
          "format": "google-datetime",
          "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."
        }
      }
    },
    "FinalizeBackupRequest": {
      "id": "FinalizeBackupRequest",
      "properties": {
        "retentionDuration": {
          "format": "google-duration",
          "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."
        },
        "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"
        },
        "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"
        },
        "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"
        },
        "recoveryRangeStartTime": {
          "format": "google-datetime",
          "description": "The earliest timestamp of data available in this Backup. This will set on the newly created Backup.",
          "type": "string"
        },
        "description": {
          "type": "string",
          "description": "This will be assigned to the description field of the newly created Backup."
        },
        "consistencyTime": {
          "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.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "description": "Message for finalizing a Backup.",
      "type": "object"
    },
    "SetIamPolicyRequest": {
      "description": "Request message for `SetIamPolicy` method.",
      "type": "object",
      "id": "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": {
          "format": "google-fieldmask",
          "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\"`"
        }
      }
    },
    "AttachedDisk": {
      "id": "AttachedDisk",
      "properties": {
        "license": {
          "type": "array",
          "description": "Optional. Any valid publicly visible licenses.",
          "items": {
            "type": "string"
          }
        },
        "type": {
          "description": "Optional. Specifies the type of the disk.",
          "enum": [
            "DISK_TYPE_UNSPECIFIED",
            "SCRATCH",
            "PERSISTENT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Default value, which is unused.",
            "A scratch disk type.",
            "A persistent disk type."
          ]
        },
        "index": {
          "type": "string",
          "description": "Optional. A zero-based index to this disk, where 0 is reserved for the boot disk.",
          "format": "int64"
        },
        "diskType": {
          "readOnly": true,
          "type": "string",
          "description": "Optional. Output only. The URI of the disk type resource. For example: projects/project/zones/zone/diskTypes/pd-standard or pd-ssd"
        },
        "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"
        },
        "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"
        },
        "diskEncryptionKey": {
          "description": "Optional. Encrypts or decrypts a disk using a customer-supplied encryption key.",
          "$ref": "CustomerEncryptionKey"
        },
        "diskTypeDeprecated": {
          "description": "Specifies the type of the disk.",
          "enum": [
            "DISK_TYPE_UNSPECIFIED",
            "SCRATCH",
            "PERSISTENT"
          ],
          "type": "string",
          "deprecated": true,
          "enumDescriptions": [
            "Default value, which is unused.",
            "A scratch disk type.",
            "A persistent disk type."
          ]
        },
        "kind": {
          "description": "Optional. Type of the resource.",
          "type": "string"
        },
        "guestOsFeature": {
          "description": "Optional. A list of features to enable on the guest operating system. Applicable only for bootable images.",
          "type": "array",
          "items": {
            "$ref": "GuestOsFeature"
          }
        },
        "savedState": {
          "enumDescriptions": [
            "Default Disk state has not been preserved.",
            "Disk state has been preserved."
          ],
          "readOnly": true,
          "type": "string",
          "description": "Optional. Output only. The state of the disk.",
          "enum": [
            "DISK_SAVED_STATE_UNSPECIFIED",
            "PRESERVED"
          ]
        },
        "diskSizeGb": {
          "description": "Optional. The size of the disk in GB.",
          "type": "string",
          "format": "int64"
        },
        "mode": {
          "type": "string",
          "description": "Optional. The mode in which to attach this disk.",
          "enum": [
            "DISK_MODE_UNSPECIFIED",
            "READ_WRITE",
            "READ_ONLY",
            "LOCKED"
          ],
          "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."
          ]
        },
        "source": {
          "type": "string",
          "description": "Optional. Specifies a valid partial or full URL to an existing Persistent Disk resource."
        },
        "diskInterface": {
          "enumDescriptions": [
            "Default value, which is unused.",
            "SCSI Disk Interface.",
            "NVME Disk Interface.",
            "NVDIMM Disk Interface.",
            "ISCSI Disk Interface."
          ],
          "type": "string",
          "description": "Optional. Specifies the disk interface to use for attaching this disk.",
          "enum": [
            "DISK_INTERFACE_UNSPECIFIED",
            "SCSI",
            "NVME",
            "NVDIMM",
            "ISCSI"
          ]
        },
        "initializeParams": {
          "description": "Optional. Specifies the parameters to initialize this disk.",
          "$ref": "InitializeParams"
        },
        "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": "object",
      "description": "An instance-attached disk resource."
    },
    "FetchAccessTokenRequest": {
      "id": "FetchAccessTokenRequest",
      "properties": {
        "generationId": {
          "format": "int32",
          "type": "integer",
          "description": "Required. The generation of the backup to update."
        }
      },
      "description": "Request message for FetchAccessToken.",
      "type": "object"
    }
  },
  "title": "Backup and DR Service API",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "baseUrl": "https://backupdr.googleapis.com/",
  "kind": "discovery#restDescription",
  "canonicalName": "Backupdr",
  "revision": "20260408",
  "rootUrl": "https://backupdr.googleapis.com/",
  "ownerName": "Google",
  "name": "backupdr",
  "version": "v1",
  "batchPath": "batch",
  "protocol": "rest",
  "servicePath": "",
  "ownerDomain": "google.com",
  "fullyEncodeReservedExpansion": true,
  "mtlsRootUrl": "https://backupdr.mtls.googleapis.com/",
  "version_module": true
}
