|  | <html><body> | 
|  | <style> | 
|  |  | 
|  | body, h1, h2, h3, div, span, p, pre, a { | 
|  | margin: 0; | 
|  | padding: 0; | 
|  | border: 0; | 
|  | font-weight: inherit; | 
|  | font-style: inherit; | 
|  | font-size: 100%; | 
|  | font-family: inherit; | 
|  | vertical-align: baseline; | 
|  | } | 
|  |  | 
|  | body { | 
|  | font-size: 13px; | 
|  | padding: 1em; | 
|  | } | 
|  |  | 
|  | h1 { | 
|  | font-size: 26px; | 
|  | margin-bottom: 1em; | 
|  | } | 
|  |  | 
|  | h2 { | 
|  | font-size: 24px; | 
|  | margin-bottom: 1em; | 
|  | } | 
|  |  | 
|  | h3 { | 
|  | font-size: 20px; | 
|  | margin-bottom: 1em; | 
|  | margin-top: 1em; | 
|  | } | 
|  |  | 
|  | pre, code { | 
|  | line-height: 1.5; | 
|  | font-family: Monaco, 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Lucida Console', monospace; | 
|  | } | 
|  |  | 
|  | pre { | 
|  | margin-top: 0.5em; | 
|  | } | 
|  |  | 
|  | h1, h2, h3, p { | 
|  | font-family: Arial, sans serif; | 
|  | } | 
|  |  | 
|  | h1, h2, h3 { | 
|  | border-bottom: solid #CCC 1px; | 
|  | } | 
|  |  | 
|  | .toc_element { | 
|  | margin-top: 0.5em; | 
|  | } | 
|  |  | 
|  | .firstline { | 
|  | margin-left: 2 em; | 
|  | } | 
|  |  | 
|  | .method  { | 
|  | margin-top: 1em; | 
|  | border: solid 1px #CCC; | 
|  | padding: 1em; | 
|  | background: #EEE; | 
|  | } | 
|  |  | 
|  | .details { | 
|  | font-weight: bold; | 
|  | font-size: 14px; | 
|  | } | 
|  |  | 
|  | </style> | 
|  |  | 
|  | <h1><a href="cloudiot_v1.html">Cloud IoT API</a> . <a href="cloudiot_v1.projects.html">projects</a> . <a href="cloudiot_v1.projects.locations.html">locations</a> . <a href="cloudiot_v1.projects.locations.registries.html">registries</a> . <a href="cloudiot_v1.projects.locations.registries.groups.html">groups</a></h1> | 
|  | <h2>Instance Methods</h2> | 
|  | <p class="toc_element"> | 
|  | <code><a href="cloudiot_v1.projects.locations.registries.groups.devices.html">devices()</a></code> | 
|  | </p> | 
|  | <p class="firstline">Returns the devices Resource.</p> | 
|  |  | 
|  | <p class="toc_element"> | 
|  | <code><a href="#getIamPolicy">getIamPolicy(resource, body=None, x__xgafv=None)</a></code></p> | 
|  | <p class="firstline">Gets the access control policy for a resource.</p> | 
|  | <p class="toc_element"> | 
|  | <code><a href="#setIamPolicy">setIamPolicy(resource, body=None, x__xgafv=None)</a></code></p> | 
|  | <p class="firstline">Sets the access control policy on the specified resource. Replaces any</p> | 
|  | <p class="toc_element"> | 
|  | <code><a href="#testIamPermissions">testIamPermissions(resource, body=None, x__xgafv=None)</a></code></p> | 
|  | <p class="firstline">Returns permissions that a caller has on the specified resource.</p> | 
|  | <h3>Method Details</h3> | 
|  | <div class="method"> | 
|  | <code class="details" id="getIamPolicy">getIamPolicy(resource, body=None, x__xgafv=None)</code> | 
|  | <pre>Gets the access control policy for a resource. | 
|  | Returns an empty policy if the resource exists and does not have a policy | 
|  | set. | 
|  |  | 
|  | Args: | 
|  | resource: string, REQUIRED: The resource for which the policy is being requested. | 
|  | See the operation documentation for the appropriate value for this field. (required) | 
|  | body: object, The request body. | 
|  | The object takes the form of: | 
|  |  | 
|  | { # Request message for `GetIamPolicy` method. | 
|  | "options": { # Encapsulates settings provided to GetIamPolicy. # OPTIONAL: A `GetPolicyOptions` object for specifying options to | 
|  | # `GetIamPolicy`. | 
|  | "requestedPolicyVersion": 42, # Optional. The policy format version to be returned. | 
|  | # | 
|  | # Valid values are 0, 1, and 3. Requests specifying an invalid value will be | 
|  | # rejected. | 
|  | # | 
|  | # Requests for policies with any conditional bindings must specify version 3. | 
|  | # Policies without any conditional bindings may specify any valid value or | 
|  | # leave the field unset. | 
|  | }, | 
|  | } | 
|  |  | 
|  | x__xgafv: string, V1 error format. | 
|  | Allowed values | 
|  | 1 - v1 error format | 
|  | 2 - v2 error format | 
|  |  | 
|  | Returns: | 
|  | An object of the form: | 
|  |  | 
|  | { # 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` to a single `role`. Members 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. | 
|  | # | 
|  | # Optionally, a `binding` can 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. | 
|  | # | 
|  | # **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 < 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 < 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/). | 
|  | "etag": "A String", # `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. | 
|  | "version": 42, # 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. | 
|  | "bindings": [ # Associates a list of `members` to 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 member. | 
|  | { # Associates `members` with a `role`. | 
|  | "members": [ # Specifies the identities requesting access for a Cloud Platform 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. | 
|  | # | 
|  | # * `user:{emailid}`: An email address that represents a specific Google | 
|  | #    account. For example, `alice@example.com` . | 
|  | # | 
|  | # | 
|  | # * `serviceAccount:{emailid}`: An email address that represents a service | 
|  | #    account. For example, `my-other-app@appspot.gserviceaccount.com`. | 
|  | # | 
|  | # * `group:{emailid}`: An email address that represents a Google group. | 
|  | #    For example, `admins@example.com`. | 
|  | # | 
|  | # * `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. | 
|  | # | 
|  | # | 
|  | # * `domain:{domain}`: The G Suite domain (primary) that represents all the | 
|  | #    users of that domain. For example, `google.com` or `example.com`. | 
|  | # | 
|  | "A String", | 
|  | ], | 
|  | "role": "A String", # Role that is assigned to `members`. | 
|  | # For example, `roles/viewer`, `roles/editor`, or `roles/owner`. | 
|  | "condition": { # Represents a textual expression in the Common Expression Language (CEL) # The condition that is associated with this binding. | 
|  | # NOTE: An unsatisfied condition will not allow user access via current | 
|  | # binding. Different bindings, including their conditions, are examined | 
|  | # independently. | 
|  | # 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() < 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. | 
|  | "title": "A String", # 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. | 
|  | "location": "A String", # Optional. String indicating the location of the expression for error | 
|  | # reporting, e.g. a file name and a position in the file. | 
|  | "description": "A String", # Optional. Description of the expression. This is a longer text which | 
|  | # describes the expression, e.g. when hovered over it in a UI. | 
|  | "expression": "A String", # Textual representation of an expression in Common Expression Language | 
|  | # syntax. | 
|  | }, | 
|  | }, | 
|  | ], | 
|  | }</pre> | 
|  | </div> | 
|  |  | 
|  | <div class="method"> | 
|  | <code class="details" id="setIamPolicy">setIamPolicy(resource, body=None, x__xgafv=None)</code> | 
|  | <pre>Sets the access control policy on the specified resource. Replaces any | 
|  | existing policy. | 
|  |  | 
|  | Args: | 
|  | resource: string, REQUIRED: The resource for which the policy is being specified. | 
|  | See the operation documentation for the appropriate value for this field. (required) | 
|  | body: object, The request body. | 
|  | The object takes the form of: | 
|  |  | 
|  | { # Request message for `SetIamPolicy` method. | 
|  | "policy": { # An Identity and Access Management (IAM) policy, which specifies access # 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 Cloud Platform services (such as Projects) | 
|  | # might reject them. | 
|  | # controls for Google Cloud resources. | 
|  | # | 
|  | # | 
|  | # A `Policy` is a collection of `bindings`. A `binding` binds one or more | 
|  | # `members` to a single `role`. Members 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. | 
|  | # | 
|  | # Optionally, a `binding` can 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. | 
|  | # | 
|  | # **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 < 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 < 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/). | 
|  | "etag": "A String", # `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. | 
|  | "version": 42, # 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. | 
|  | "bindings": [ # Associates a list of `members` to 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 member. | 
|  | { # Associates `members` with a `role`. | 
|  | "members": [ # Specifies the identities requesting access for a Cloud Platform 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. | 
|  | # | 
|  | # * `user:{emailid}`: An email address that represents a specific Google | 
|  | #    account. For example, `alice@example.com` . | 
|  | # | 
|  | # | 
|  | # * `serviceAccount:{emailid}`: An email address that represents a service | 
|  | #    account. For example, `my-other-app@appspot.gserviceaccount.com`. | 
|  | # | 
|  | # * `group:{emailid}`: An email address that represents a Google group. | 
|  | #    For example, `admins@example.com`. | 
|  | # | 
|  | # * `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. | 
|  | # | 
|  | # | 
|  | # * `domain:{domain}`: The G Suite domain (primary) that represents all the | 
|  | #    users of that domain. For example, `google.com` or `example.com`. | 
|  | # | 
|  | "A String", | 
|  | ], | 
|  | "role": "A String", # Role that is assigned to `members`. | 
|  | # For example, `roles/viewer`, `roles/editor`, or `roles/owner`. | 
|  | "condition": { # Represents a textual expression in the Common Expression Language (CEL) # The condition that is associated with this binding. | 
|  | # NOTE: An unsatisfied condition will not allow user access via current | 
|  | # binding. Different bindings, including their conditions, are examined | 
|  | # independently. | 
|  | # 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() < 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. | 
|  | "title": "A String", # 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. | 
|  | "location": "A String", # Optional. String indicating the location of the expression for error | 
|  | # reporting, e.g. a file name and a position in the file. | 
|  | "description": "A String", # Optional. Description of the expression. This is a longer text which | 
|  | # describes the expression, e.g. when hovered over it in a UI. | 
|  | "expression": "A String", # Textual representation of an expression in Common Expression Language | 
|  | # syntax. | 
|  | }, | 
|  | }, | 
|  | ], | 
|  | }, | 
|  | } | 
|  |  | 
|  | x__xgafv: string, V1 error format. | 
|  | Allowed values | 
|  | 1 - v1 error format | 
|  | 2 - v2 error format | 
|  |  | 
|  | Returns: | 
|  | An object of the form: | 
|  |  | 
|  | { # 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` to a single `role`. Members 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. | 
|  | # | 
|  | # Optionally, a `binding` can 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. | 
|  | # | 
|  | # **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 < 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 < 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/). | 
|  | "etag": "A String", # `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. | 
|  | "version": 42, # 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. | 
|  | "bindings": [ # Associates a list of `members` to 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 member. | 
|  | { # Associates `members` with a `role`. | 
|  | "members": [ # Specifies the identities requesting access for a Cloud Platform 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. | 
|  | # | 
|  | # * `user:{emailid}`: An email address that represents a specific Google | 
|  | #    account. For example, `alice@example.com` . | 
|  | # | 
|  | # | 
|  | # * `serviceAccount:{emailid}`: An email address that represents a service | 
|  | #    account. For example, `my-other-app@appspot.gserviceaccount.com`. | 
|  | # | 
|  | # * `group:{emailid}`: An email address that represents a Google group. | 
|  | #    For example, `admins@example.com`. | 
|  | # | 
|  | # * `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. | 
|  | # | 
|  | # | 
|  | # * `domain:{domain}`: The G Suite domain (primary) that represents all the | 
|  | #    users of that domain. For example, `google.com` or `example.com`. | 
|  | # | 
|  | "A String", | 
|  | ], | 
|  | "role": "A String", # Role that is assigned to `members`. | 
|  | # For example, `roles/viewer`, `roles/editor`, or `roles/owner`. | 
|  | "condition": { # Represents a textual expression in the Common Expression Language (CEL) # The condition that is associated with this binding. | 
|  | # NOTE: An unsatisfied condition will not allow user access via current | 
|  | # binding. Different bindings, including their conditions, are examined | 
|  | # independently. | 
|  | # 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() < 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. | 
|  | "title": "A String", # 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. | 
|  | "location": "A String", # Optional. String indicating the location of the expression for error | 
|  | # reporting, e.g. a file name and a position in the file. | 
|  | "description": "A String", # Optional. Description of the expression. This is a longer text which | 
|  | # describes the expression, e.g. when hovered over it in a UI. | 
|  | "expression": "A String", # Textual representation of an expression in Common Expression Language | 
|  | # syntax. | 
|  | }, | 
|  | }, | 
|  | ], | 
|  | }</pre> | 
|  | </div> | 
|  |  | 
|  | <div class="method"> | 
|  | <code class="details" id="testIamPermissions">testIamPermissions(resource, body=None, x__xgafv=None)</code> | 
|  | <pre>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. | 
|  |  | 
|  | Args: | 
|  | resource: string, REQUIRED: The resource for which the policy detail is being requested. | 
|  | See the operation documentation for the appropriate value for this field. (required) | 
|  | body: object, The request body. | 
|  | The object takes the form of: | 
|  |  | 
|  | { # Request message for `TestIamPermissions` method. | 
|  | "permissions": [ # 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). | 
|  | "A String", | 
|  | ], | 
|  | } | 
|  |  | 
|  | x__xgafv: string, V1 error format. | 
|  | Allowed values | 
|  | 1 - v1 error format | 
|  | 2 - v2 error format | 
|  |  | 
|  | Returns: | 
|  | An object of the form: | 
|  |  | 
|  | { # Response message for `TestIamPermissions` method. | 
|  | "permissions": [ # A subset of `TestPermissionsRequest.permissions` that the caller is | 
|  | # allowed. | 
|  | "A String", | 
|  | ], | 
|  | }</pre> | 
|  | </div> | 
|  |  | 
|  | </body></html> |