Service Consumer Management API . services . tenancyUnits

Instance Methods

addProject(parent, body, x__xgafv=None)

Add a new tenant project to the tenancy unit.

applyProjectConfig(name, body, x__xgafv=None)

Apply a configuration to an existing tenant project.

attachProject(name, body, x__xgafv=None)

Attach an existing project to the tenancy unit as a new tenant

create(parent, body, x__xgafv=None)

Creates a tenancy unit with no tenant resources.

delete(name, x__xgafv=None)

Delete a tenancy unit. Before you delete the tenancy unit, there should be

deleteProject(name, body, x__xgafv=None)

Deletes the specified project resource identified by a tenant resource tag.

list(parent, pageToken=None, x__xgafv=None, pageSize=None, filter=None)

Find the tenancy unit for a managed service and service consumer.

list_next(previous_request, previous_response)

Retrieves the next page of results.

removeProject(name, body, x__xgafv=None)

Removes the specified project resource identified by a tenant resource tag.

undeleteProject(name, body, x__xgafv=None)

Attempts to undelete a previously deleted tenant project. The project must

Method Details

addProject(parent, body, x__xgafv=None)
Add a new tenant project to the tenancy unit.
There can be a maximum of 512 tenant projects in a tenancy unit.
If there are previously failed `AddTenantProject` calls, you might need to
call `RemoveTenantProject` first to resolve them before you can make
another call to `AddTenantProject` with the same tag.
Operation.

Args:
  parent: string, Name of the tenancy unit.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request to add a newly created and configured tenant project to a tenancy
      # unit.
    "projectConfig": { # This structure defines a tenant project to be added to the specified tenancy # Configuration of the new tenant project to be added to tenancy unit
        # resources.
        # unit and its initial configuration and properties. A project lien is created
        # for the tenant project to prevent the tenant project from being deleted
        # accidentally. The lien is deleted as part of tenant project removal.
      "billingConfig": { # Describes the billing configuration for a new tenant project. # Billing account properties. The billing account must be specified.
        "billingAccount": "A String", # Name of the billing account.
            # For example `billingAccounts/012345-567890-ABCDEF`.
      },
      "labels": { # Labels that are applied to this project.
        "a_key": "A String",
      },
      "serviceAccountConfig": { # Describes the service account configuration for the tenant project. # Configuration for the IAM service account on the tenant project.
        "tenantProjectRoles": [ # Roles for the associated service account for the tenant project.
          "A String",
        ],
        "accountId": "A String", # ID of the IAM service account to be created in tenant project.
            # The email format of the service account is
            # "@.iam.gserviceaccount.com".
            # This account ID must be unique within tenant project and service
            # producers have to guarantee it. The ID must be 6-30 characters long, and
            # match the following regular expression: `[a-z]([-a-z0-9]*[a-z0-9])`.
      },
      "services": [ # Google Cloud API names of services that are activated on this project
          # during provisioning.  If any of these services can't be activated,
          # the request fails.
          # For example: 'compute.googleapis.com','cloudfunctions.googleapis.com'
        "A String",
      ],
      "folder": "A String", # Folder where project in this tenancy unit must be located
          # This folder must have been previously created with the required
          # permissions for the caller to create and configure a project in it.
          # Valid folder resource names have the format `folders/{folder_number}`
          # (for example, `folders/123456`).
      "tenantProjectPolicy": { # Describes policy settings that need to be applied to a newly # Describes ownership and policies for the new tenant project. Required.
          # created tenant project.
        "policyBindings": [ # Policy bindings to be applied to the tenant project, in addition to the
            # 'roles/owner' role granted to the Service Consumer Management service
            # account.
            # At least one binding must have the role `roles/owner`. Among the list of
            # members for `roles/owner`, at least one of them must be either the `user`
            # or `group` type.
          { # Translates to IAM Policy bindings (without auditing at this level)
            "role": "A String", # Role. (https://cloud.google.com/iam/docs/understanding-roles)
                # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
            "members": [ # Uses the same format as in IAM policy.
                # `member` must include both a prefix and ID. For example, `user:{emailId}`,
                # `serviceAccount:{emailId}`, `group:{emailId}`.
              "A String",
            ],
          },
        ],
      },
    },
    "tag": "A String", # Tag of the added project. Must be less than 128 characters. Required.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
applyProjectConfig(name, body, x__xgafv=None)
Apply a configuration to an existing tenant project.
This project must exist in an active state and have the original owner
account. The caller must have permission to add a project to the given
tenancy unit. The configuration is applied, but any existing settings on
the project aren't modified.
Specified policy bindings are applied. Existing bindings aren't modified.
Specified services are activated. No service is deactivated.
If specified, new billing configuration is applied.
Omit a billing configuration to keep the existing one.
A service account in the project is created if previously non existed.
Specified labels will be appended to tenant project, note that the value of
existing label key will be updated if the same label key is requested.
The specified folder is ignored, as moving a tenant project to a different
folder isn't supported.
The operation fails if any of the steps fail, but no rollback of already
applied configuration changes is attempted.
Operation.

Args:
  name: string, Name of the tenancy unit.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request to apply configuration to an existing tenant project.
    "projectConfig": { # This structure defines a tenant project to be added to the specified tenancy # Configuration that should be applied to the existing tenant project.
        # unit and its initial configuration and properties. A project lien is created
        # for the tenant project to prevent the tenant project from being deleted
        # accidentally. The lien is deleted as part of tenant project removal.
      "billingConfig": { # Describes the billing configuration for a new tenant project. # Billing account properties. The billing account must be specified.
        "billingAccount": "A String", # Name of the billing account.
            # For example `billingAccounts/012345-567890-ABCDEF`.
      },
      "labels": { # Labels that are applied to this project.
        "a_key": "A String",
      },
      "serviceAccountConfig": { # Describes the service account configuration for the tenant project. # Configuration for the IAM service account on the tenant project.
        "tenantProjectRoles": [ # Roles for the associated service account for the tenant project.
          "A String",
        ],
        "accountId": "A String", # ID of the IAM service account to be created in tenant project.
            # The email format of the service account is
            # "@.iam.gserviceaccount.com".
            # This account ID must be unique within tenant project and service
            # producers have to guarantee it. The ID must be 6-30 characters long, and
            # match the following regular expression: `[a-z]([-a-z0-9]*[a-z0-9])`.
      },
      "services": [ # Google Cloud API names of services that are activated on this project
          # during provisioning.  If any of these services can't be activated,
          # the request fails.
          # For example: 'compute.googleapis.com','cloudfunctions.googleapis.com'
        "A String",
      ],
      "folder": "A String", # Folder where project in this tenancy unit must be located
          # This folder must have been previously created with the required
          # permissions for the caller to create and configure a project in it.
          # Valid folder resource names have the format `folders/{folder_number}`
          # (for example, `folders/123456`).
      "tenantProjectPolicy": { # Describes policy settings that need to be applied to a newly # Describes ownership and policies for the new tenant project. Required.
          # created tenant project.
        "policyBindings": [ # Policy bindings to be applied to the tenant project, in addition to the
            # 'roles/owner' role granted to the Service Consumer Management service
            # account.
            # At least one binding must have the role `roles/owner`. Among the list of
            # members for `roles/owner`, at least one of them must be either the `user`
            # or `group` type.
          { # Translates to IAM Policy bindings (without auditing at this level)
            "role": "A String", # Role. (https://cloud.google.com/iam/docs/understanding-roles)
                # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
            "members": [ # Uses the same format as in IAM policy.
                # `member` must include both a prefix and ID. For example, `user:{emailId}`,
                # `serviceAccount:{emailId}`, `group:{emailId}`.
              "A String",
            ],
          },
        ],
      },
    },
    "tag": "A String", # Tag of the project. Must be less than 128 characters. Required.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
attachProject(name, body, x__xgafv=None)
Attach an existing project to the tenancy unit as a new tenant
resource. The project could either be the tenant project reserved by
calling `AddTenantProject` under a tenancy unit of a service producer's
project of a managed service, or from a separate project.
The caller is checked against a set of permissions as if calling
`AddTenantProject` on the same service consumer.
To trigger the attachment, the targeted tenant project must be in a
folder. Make sure the ServiceConsumerManagement service account is
the owner of that project. These two requirements are already met
if the project is reserved by calling `AddTenantProject`.
Operation.

Args:
  name: string, Name of the tenancy unit that the project will be attached to.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request to attach an existing project to the tenancy unit as a new tenant
      # resource.
    "reservedResource": "A String", # When attaching a reserved project already in tenancy units, this is the
        # tag of a tenant resource under the tenancy unit for the managed service's
        # service producer project. The reserved tenant resource must be in an
        # active state.
    "externalResource": "A String", # When attaching an external project, this is in the format of
        # `projects/{project_number}`.
    "tag": "A String", # Tag of the tenant resource after attachment.
        # Must be less than 128 characters. Required.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
create(parent, body, x__xgafv=None)
Creates a tenancy unit with no tenant resources.

Args:
  parent: string, services/{service}/{collection id}/{resource id}
{collection id} is the cloud resource collection type representing the
service consumer, for example 'projects', or 'organizations'.
{resource id} is the consumer numeric id, such as project number: '123456'.
{service} the name of a managed service, such as 'service.googleapis.com'.
Enables service binding using the new tenancy unit. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request to create a tenancy unit for a service consumer of a managed service.
    "tenancyUnitId": "A String", # Optional service producer-provided identifier of the tenancy unit.
        # Must be no longer than 40 characters and preferably URI friendly.
        # If it isn't provided, a UID for the tenancy unit is automatically
        # generated. The identifier must be unique across a managed service.
        # If the tenancy unit already exists for the managed service and service
        # consumer pair, calling `CreateTenancyUnit` returns the existing tenancy
        # unit if the provided identifier is identical or empty, otherwise the call
        # fails.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Representation of a tenancy unit.
    "tenantResources": [ # Resources constituting the tenancy unit.
        # There can be at most 512 tenant resources in a tenancy unit.
      { # Resource constituting the TenancyUnit.
        "status": "A String", # Status of tenant resource.
        "tag": "A String", # Unique per single tenancy unit.
        "resource": "A String", # @OutputOnly Identifier of the tenant resource.
            # For cloud projects, it is in the form 'projects/{number}'.
            # For example 'projects/123456'.
      },
    ],
    "consumer": "A String", # @OutputOnly Cloud resource name of the consumer of this service.
        # For example 'projects/123456'.
    "createTime": "A String", # @OutputOnly The time this tenancy unit was created.
    "service": "A String", # Output only. Google Cloud API name of the managed service owning this
        # tenancy unit.
        # For example 'serviceconsumermanagement.googleapis.com'.
    "name": "A String", # Globally unique identifier of this tenancy unit
        # "services/{service}/{collection id}/{resource id}/tenancyUnits/{unit}"
  }
delete(name, x__xgafv=None)
Delete a tenancy unit. Before you delete the tenancy unit, there should be
no tenant resources in it that aren't in a DELETED state.
Operation.

Args:
  name: string, Name of the tenancy unit to be deleted. (required)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
deleteProject(name, body, x__xgafv=None)
Deletes the specified project resource identified by a tenant resource tag.
The mothod removes a project lien with a 'TenantManager' origin if that was
added. It will then attempt to delete the project. If that operation fails,
this method also fails.
After the project has been deleted, the tenant resource state is set to
DELETED.  To permanently remove resource metadata, call the
`RemoveTenantProject` method.
New resources with the same tag can't be added if there are existing
resources in a DELETED state.
Operation.

Args:
  name: string, Name of the tenancy unit.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request message to delete tenant project resource from the tenancy unit.
    "tag": "A String", # Tag of the resource within the tenancy unit.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
list(parent, pageToken=None, x__xgafv=None, pageSize=None, filter=None)
Find the tenancy unit for a managed service and service consumer.
This method shouldn't be used in a service producer's runtime path, for
example to find the tenant project number when creating VMs. Service
producers must persist the tenant project's information after the project
is created.

Args:
  parent: string, Managed service and service consumer. Required.
services/{service}/{collection id}/{resource id}
{collection id} is the cloud resource collection type representing the
service consumer, for example 'projects', or 'organizations'.
{resource id} is the consumer numeric id, such as project number: '123456'.
{service} the name of a service, such as 'service.googleapis.com'. (required)
  pageToken: string, The continuation token, which is used to page through large result sets.
To get the next page of results, set this parameter to the value of
`nextPageToken` from the previous response.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format
  pageSize: integer, The maximum number of results returned by this request.
  filter: string, Filter expression over tenancy resources field. Optional.

Returns:
  An object of the form:

    { # Response for the list request.
    "nextPageToken": "A String", # Pagination token for large results.
    "tenancyUnits": [ # Tenancy units matching the request.
      { # Representation of a tenancy unit.
        "tenantResources": [ # Resources constituting the tenancy unit.
            # There can be at most 512 tenant resources in a tenancy unit.
          { # Resource constituting the TenancyUnit.
            "status": "A String", # Status of tenant resource.
            "tag": "A String", # Unique per single tenancy unit.
            "resource": "A String", # @OutputOnly Identifier of the tenant resource.
                # For cloud projects, it is in the form 'projects/{number}'.
                # For example 'projects/123456'.
          },
        ],
        "consumer": "A String", # @OutputOnly Cloud resource name of the consumer of this service.
            # For example 'projects/123456'.
        "createTime": "A String", # @OutputOnly The time this tenancy unit was created.
        "service": "A String", # Output only. Google Cloud API name of the managed service owning this
            # tenancy unit.
            # For example 'serviceconsumermanagement.googleapis.com'.
        "name": "A String", # Globally unique identifier of this tenancy unit
            # "services/{service}/{collection id}/{resource id}/tenancyUnits/{unit}"
      },
    ],
  }
list_next(previous_request, previous_response)
Retrieves the next page of results.

Args:
  previous_request: The request for the previous page. (required)
  previous_response: The response from the request for the previous page. (required)

Returns:
  A request object that you can call 'execute()' on to request the next
  page. Returns None if there are no more items in the collection.
    
removeProject(name, body, x__xgafv=None)
Removes the specified project resource identified by a tenant resource tag.
The method removes the project lien with 'TenantManager' origin if that
was added. It then attempts to delete the project. If that operation
fails, this method also fails.
Calls to remove already removed or non-existent tenant project succeed.
After the project has been deleted, or if was already in a DELETED state,
resource metadata is permanently removed from the tenancy unit.
Operation.

Args:
  name: string, Name of the tenancy unit.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request message to remove a tenant project resource from the tenancy unit.
    "tag": "A String", # Tag of the resource within the tenancy unit.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }
undeleteProject(name, body, x__xgafv=None)
Attempts to undelete a previously deleted tenant project. The project must
be in a DELETED state.
There are no guarantees that an undeleted project will be in
a fully restored and functional state. Call the `ApplyTenantProjectConfig`
method to update its configuration and then validate all managed service
resources.
Operation.

Args:
  name: string, Name of the tenancy unit.
Such as 'services/service.googleapis.com/projects/12345/tenancyUnits/abcd'. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # Request message to undelete tenant project resource previously deleted from
      # the tenancy unit.
    "tag": "A String", # Tag of the resource within the tenancy unit.
  }

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # This resource represents a long-running operation that is the result of a
      # network API call.
    "metadata": { # 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.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "error": { # The `Status` type defines a logical error model that is suitable for # The error result of the operation in case of failure or cancellation.
        # 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).
      "message": "A String", # 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.
      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
      "details": [ # A list of messages that carry the error details.  There is a common set of
          # message types for APIs to use.
        {
          "a_key": "", # Properties of the object. Contains field @type with type URL.
        },
      ],
    },
    "done": True or False, # 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.
    "response": { # The normal response of the operation in case of success.  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`.
      "a_key": "", # Properties of the object. Contains field @type with type URL.
    },
    "name": "A String", # 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}`.
  }