Binary Authorization API . projects . attestors

Instance Methods

create(parent, body, attestorId=None, x__xgafv=None)

Creates an attestor, and returns a copy of the new

delete(name, x__xgafv=None)

Deletes an attestor. Returns NOT_FOUND if the

get(name, x__xgafv=None)

Gets an attestor.

getIamPolicy(resource, x__xgafv=None)

Gets the access control policy for a resource.

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

Lists attestors.

list_next(previous_request, previous_response)

Retrieves the next page of results.

setIamPolicy(resource, body, x__xgafv=None)

Sets the access control policy on the specified resource. Replaces any

testIamPermissions(resource, body, x__xgafv=None)

Returns permissions that a caller has on the specified resource.

update(name, body, x__xgafv=None)

Updates an attestor.

Method Details

create(parent, body, attestorId=None, x__xgafv=None)
Creates an attestor, and returns a copy of the new
attestor. Returns NOT_FOUND if the project does not exist,
INVALID_ARGUMENT if the request is malformed, ALREADY_EXISTS if the
attestor already exists.

Args:
  parent: string, Required. The parent of this attestor. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # An attestor that attests to container image
    # artifacts. An existing attestor cannot be modified except where
    # indicated.
  "updateTime": "A String", # Output only. Time when the attestor was last updated.
  "description": "A String", # Optional. A descriptive comment.  This field may be updated.
      # The field may be displayed in chooser dialogs.
  "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
      # ATTESTATION_AUTHORITY Note created by the user.
    "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
        # that this Attestor will use as the principal when querying Container
        # Analysis. Attestor administrators must grant this service account the
        # IAM role needed to read attestations from the note_reference in
        # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
        #
        # This email address is fixed for the lifetime of the Attestor, but callers
        # should not make any other assumptions about the service account email;
        # future versions may use an email based on a different naming pattern.
    "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
        # created by the user, in the format: `projects/*/notes/*` (or the legacy
        # `providers/*/notes/*`). This field may not be updated.
        #
        # An attestation by this attestor is stored as a Drydock
        # ATTESTATION_AUTHORITY Occurrence that names a container image and that
        # links to this Note. Drydock is an external dependency.
    "publicKeys": [ # Optional. Public keys that verify attestations signed by this
        # attestor.  This field may be updated.
        #
        # If this field is non-empty, one of the specified public keys must
        # verify that an attestation was signed by this attestor for the
        # image specified in the admission request.
        #
        # If this field is empty, this attestor always returns that no
        # valid attestations exist.
      { # An attestor public key that will be used to verify
          # attestations signed by this attestor.
        "comment": "A String", # Optional. A descriptive comment. This field may be updated.
        "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
            # the command `gpg --export --armor foo@example.com` (either LF or CRLF
            # line endings).
            # When using this field, `id` should be left blank.  The BinAuthz API
            # handlers will calculate the ID and fill it in automatically.  BinAuthz
            # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
            # upper-case hex.  If `id` is provided by the caller, it will be
            # overwritten by the API-calculated ID.
        "id": "A String", # The ID of this public key.
            # Signatures verified by BinAuthz must include the ID of the public key that
            # can be used to verify them, and that ID must match the contents of this
            # field exactly.
            # Additional restrictions on this field can be imposed based on which public
            # key type is encapsulated. See the documentation on `public_key` cases below
            # for details.
        "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
            #
            # NOTE: `id` may be explicitly provided by the caller when using this
            # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
            # blank, a default one will be computed based on the digest of the DER
            # encoding of the public key.
            # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
            # Public keys of this type are typically textually encoded using the PEM
            # format.
          "publicKeyPem": "A String", # A PEM-encoded public key, as described in
              # https://tools.ietf.org/html/rfc7468#section-13
          "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
              # this key.
              # These signature algorithm must match the structure and any object
              # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
              # that of the public key).
        },
      },
    ],
  },
  "name": "A String", # Required. The resource name, in the format:
      # `projects/*/attestors/*`. This field may not be updated.
}

  attestorId: string, Required. The attestors ID.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # An attestor that attests to container image
      # artifacts. An existing attestor cannot be modified except where
      # indicated.
    "updateTime": "A String", # Output only. Time when the attestor was last updated.
    "description": "A String", # Optional. A descriptive comment.  This field may be updated.
        # The field may be displayed in chooser dialogs.
    "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
        # ATTESTATION_AUTHORITY Note created by the user.
      "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
          # that this Attestor will use as the principal when querying Container
          # Analysis. Attestor administrators must grant this service account the
          # IAM role needed to read attestations from the note_reference in
          # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
          #
          # This email address is fixed for the lifetime of the Attestor, but callers
          # should not make any other assumptions about the service account email;
          # future versions may use an email based on a different naming pattern.
      "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
          # created by the user, in the format: `projects/*/notes/*` (or the legacy
          # `providers/*/notes/*`). This field may not be updated.
          #
          # An attestation by this attestor is stored as a Drydock
          # ATTESTATION_AUTHORITY Occurrence that names a container image and that
          # links to this Note. Drydock is an external dependency.
      "publicKeys": [ # Optional. Public keys that verify attestations signed by this
          # attestor.  This field may be updated.
          #
          # If this field is non-empty, one of the specified public keys must
          # verify that an attestation was signed by this attestor for the
          # image specified in the admission request.
          #
          # If this field is empty, this attestor always returns that no
          # valid attestations exist.
        { # An attestor public key that will be used to verify
            # attestations signed by this attestor.
          "comment": "A String", # Optional. A descriptive comment. This field may be updated.
          "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
              # the command `gpg --export --armor foo@example.com` (either LF or CRLF
              # line endings).
              # When using this field, `id` should be left blank.  The BinAuthz API
              # handlers will calculate the ID and fill it in automatically.  BinAuthz
              # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
              # upper-case hex.  If `id` is provided by the caller, it will be
              # overwritten by the API-calculated ID.
          "id": "A String", # The ID of this public key.
              # Signatures verified by BinAuthz must include the ID of the public key that
              # can be used to verify them, and that ID must match the contents of this
              # field exactly.
              # Additional restrictions on this field can be imposed based on which public
              # key type is encapsulated. See the documentation on `public_key` cases below
              # for details.
          "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
              #
              # NOTE: `id` may be explicitly provided by the caller when using this
              # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
              # blank, a default one will be computed based on the digest of the DER
              # encoding of the public key.
              # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
              # Public keys of this type are typically textually encoded using the PEM
              # format.
            "publicKeyPem": "A String", # A PEM-encoded public key, as described in
                # https://tools.ietf.org/html/rfc7468#section-13
            "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
                # this key.
                # These signature algorithm must match the structure and any object
                # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
                # that of the public key).
          },
        },
      ],
    },
    "name": "A String", # Required. The resource name, in the format:
        # `projects/*/attestors/*`. This field may not be updated.
  }
delete(name, x__xgafv=None)
Deletes an attestor. Returns NOT_FOUND if the
attestor does not exist.

Args:
  name: string, Required. The name of the attestors to delete, in the format
`projects/*/attestors/*`. (required)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # 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);
      #     }
      #
      # The JSON representation for `Empty` is empty JSON object `{}`.
  }
get(name, x__xgafv=None)
Gets an attestor.
Returns NOT_FOUND if the attestor does not exist.

Args:
  name: string, Required. The name of the attestor to retrieve, in the format
`projects/*/attestors/*`. (required)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # An attestor that attests to container image
      # artifacts. An existing attestor cannot be modified except where
      # indicated.
    "updateTime": "A String", # Output only. Time when the attestor was last updated.
    "description": "A String", # Optional. A descriptive comment.  This field may be updated.
        # The field may be displayed in chooser dialogs.
    "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
        # ATTESTATION_AUTHORITY Note created by the user.
      "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
          # that this Attestor will use as the principal when querying Container
          # Analysis. Attestor administrators must grant this service account the
          # IAM role needed to read attestations from the note_reference in
          # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
          #
          # This email address is fixed for the lifetime of the Attestor, but callers
          # should not make any other assumptions about the service account email;
          # future versions may use an email based on a different naming pattern.
      "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
          # created by the user, in the format: `projects/*/notes/*` (or the legacy
          # `providers/*/notes/*`). This field may not be updated.
          #
          # An attestation by this attestor is stored as a Drydock
          # ATTESTATION_AUTHORITY Occurrence that names a container image and that
          # links to this Note. Drydock is an external dependency.
      "publicKeys": [ # Optional. Public keys that verify attestations signed by this
          # attestor.  This field may be updated.
          #
          # If this field is non-empty, one of the specified public keys must
          # verify that an attestation was signed by this attestor for the
          # image specified in the admission request.
          #
          # If this field is empty, this attestor always returns that no
          # valid attestations exist.
        { # An attestor public key that will be used to verify
            # attestations signed by this attestor.
          "comment": "A String", # Optional. A descriptive comment. This field may be updated.
          "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
              # the command `gpg --export --armor foo@example.com` (either LF or CRLF
              # line endings).
              # When using this field, `id` should be left blank.  The BinAuthz API
              # handlers will calculate the ID and fill it in automatically.  BinAuthz
              # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
              # upper-case hex.  If `id` is provided by the caller, it will be
              # overwritten by the API-calculated ID.
          "id": "A String", # The ID of this public key.
              # Signatures verified by BinAuthz must include the ID of the public key that
              # can be used to verify them, and that ID must match the contents of this
              # field exactly.
              # Additional restrictions on this field can be imposed based on which public
              # key type is encapsulated. See the documentation on `public_key` cases below
              # for details.
          "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
              #
              # NOTE: `id` may be explicitly provided by the caller when using this
              # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
              # blank, a default one will be computed based on the digest of the DER
              # encoding of the public key.
              # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
              # Public keys of this type are typically textually encoded using the PEM
              # format.
            "publicKeyPem": "A String", # A PEM-encoded public key, as described in
                # https://tools.ietf.org/html/rfc7468#section-13
            "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
                # this key.
                # These signature algorithm must match the structure and any object
                # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
                # that of the public key).
          },
        },
      ],
    },
    "name": "A String", # Required. The resource name, in the format:
        # `projects/*/attestors/*`. This field may not be updated.
  }
getIamPolicy(resource, x__xgafv=None)
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)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Defines an Identity and Access Management (IAM) policy. It is used to
      # specify access control policies for Cloud Platform resources.
      #
      #
      # A `Policy` consists of a list of `bindings`. A `binding` binds a list of
      # `members` to a `role`, where the members can be user accounts, Google groups,
      # Google domains, and service accounts. A `role` is a named list of permissions
      # defined by IAM.
      #
      # **JSON Example**
      #
      #     {
      #       "bindings": [
      #         {
      #           "role": "roles/owner",
      #           "members": [
      #             "user:mike@example.com",
      #             "group:admins@example.com",
      #             "domain:google.com",
      #             "serviceAccount:my-other-app@appspot.gserviceaccount.com"
      #           ]
      #         },
      #         {
      #           "role": "roles/viewer",
      #           "members": ["user:sean@example.com"]
      #         }
      #       ]
      #     }
      #
      # **YAML Example**
      #
      #     bindings:
      #     - members:
      #       - user:mike@example.com
      #       - group:admins@example.com
      #       - domain:google.com
      #       - serviceAccount:my-other-app@appspot.gserviceaccount.com
      #       role: roles/owner
      #     - members:
      #       - user:sean@example.com
      #       role: roles/viewer
      #
      #
      # For a description of IAM and its features, see the
      # [IAM developer's guide](https://cloud.google.com/iam/docs).
    "bindings": [ # Associates a list of `members` to a `role`.
        # `bindings` with no members will result in an error.
      { # Associates `members` with a `role`.
        "role": "A String", # Role that is assigned to `members`.
            # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
        "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@gmail.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`.
            #
            #
            # * `domain:{domain}`: The G Suite domain (primary) that represents all the
            #    users of that domain. For example, `google.com` or `example.com`.
            #
          "A String",
        ],
        "condition": { # Represents an expression text. Example: # 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.
            #
            #     title: "User account presence"
            #     description: "Determines whether the request has a user account"
            #     expression: "size(request.user) > 0"
          "location": "A String", # An optional string indicating the location of the expression for error
              # reporting, e.g. a file name and a position in the file.
          "expression": "A String", # Textual representation of an expression in
              # Common Expression Language syntax.
              #
              # The application context of the containing message determines which
              # well-known feature set of CEL is supported.
          "description": "A String", # An optional description of the expression. This is a longer text which
              # describes the expression, e.g. when hovered over it in a UI.
          "title": "A String", # An 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.
        },
      },
    ],
    "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.
        #
        # If no `etag` is provided in the call to `setIamPolicy`, then the existing
        # policy is overwritten blindly.
    "version": 42, # Deprecated.
  }
list(parent, pageToken=None, x__xgafv=None, pageSize=None)
Lists attestors.
Returns INVALID_ARGUMENT if the project does not exist.

Args:
  parent: string, Required. The resource name of the project associated with the
attestors, in the format `projects/*`. (required)
  pageToken: string, A token identifying a page of results the server should return. Typically,
this is the value of ListAttestorsResponse.next_page_token returned
from the previous call to the `ListAttestors` method.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format
  pageSize: integer, Requested page size. The server may return fewer results than requested. If
unspecified, the server will pick an appropriate default.

Returns:
  An object of the form:

    { # Response message for BinauthzManagementService.ListAttestors.
    "nextPageToken": "A String", # A token to retrieve the next page of results. Pass this value in the
        # ListAttestorsRequest.page_token field in the subsequent call to the
        # `ListAttestors` method to retrieve the next page of results.
    "attestors": [ # The list of attestors.
      { # An attestor that attests to container image
          # artifacts. An existing attestor cannot be modified except where
          # indicated.
        "updateTime": "A String", # Output only. Time when the attestor was last updated.
        "description": "A String", # Optional. A descriptive comment.  This field may be updated.
            # The field may be displayed in chooser dialogs.
        "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
            # ATTESTATION_AUTHORITY Note created by the user.
          "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
              # that this Attestor will use as the principal when querying Container
              # Analysis. Attestor administrators must grant this service account the
              # IAM role needed to read attestations from the note_reference in
              # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
              #
              # This email address is fixed for the lifetime of the Attestor, but callers
              # should not make any other assumptions about the service account email;
              # future versions may use an email based on a different naming pattern.
          "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
              # created by the user, in the format: `projects/*/notes/*` (or the legacy
              # `providers/*/notes/*`). This field may not be updated.
              #
              # An attestation by this attestor is stored as a Drydock
              # ATTESTATION_AUTHORITY Occurrence that names a container image and that
              # links to this Note. Drydock is an external dependency.
          "publicKeys": [ # Optional. Public keys that verify attestations signed by this
              # attestor.  This field may be updated.
              #
              # If this field is non-empty, one of the specified public keys must
              # verify that an attestation was signed by this attestor for the
              # image specified in the admission request.
              #
              # If this field is empty, this attestor always returns that no
              # valid attestations exist.
            { # An attestor public key that will be used to verify
                # attestations signed by this attestor.
              "comment": "A String", # Optional. A descriptive comment. This field may be updated.
              "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
                  # the command `gpg --export --armor foo@example.com` (either LF or CRLF
                  # line endings).
                  # When using this field, `id` should be left blank.  The BinAuthz API
                  # handlers will calculate the ID and fill it in automatically.  BinAuthz
                  # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
                  # upper-case hex.  If `id` is provided by the caller, it will be
                  # overwritten by the API-calculated ID.
              "id": "A String", # The ID of this public key.
                  # Signatures verified by BinAuthz must include the ID of the public key that
                  # can be used to verify them, and that ID must match the contents of this
                  # field exactly.
                  # Additional restrictions on this field can be imposed based on which public
                  # key type is encapsulated. See the documentation on `public_key` cases below
                  # for details.
              "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
                  #
                  # NOTE: `id` may be explicitly provided by the caller when using this
                  # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
                  # blank, a default one will be computed based on the digest of the DER
                  # encoding of the public key.
                  # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
                  # Public keys of this type are typically textually encoded using the PEM
                  # format.
                "publicKeyPem": "A String", # A PEM-encoded public key, as described in
                    # https://tools.ietf.org/html/rfc7468#section-13
                "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
                    # this key.
                    # These signature algorithm must match the structure and any object
                    # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
                    # that of the public key).
              },
            },
          ],
        },
        "name": "A String", # Required. The resource name, in the format:
            # `projects/*/attestors/*`. This field may not be updated.
      },
    ],
  }
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.
    
setIamPolicy(resource, body, x__xgafv=None)
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. (required)
    The object takes the form of:

{ # Request message for `SetIamPolicy` method.
    "policy": { # Defines an Identity and Access Management (IAM) policy. It is used to # 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.
        # specify access control policies for Cloud Platform resources.
        #
        #
        # A `Policy` consists of a list of `bindings`. A `binding` binds a list of
        # `members` to a `role`, where the members can be user accounts, Google groups,
        # Google domains, and service accounts. A `role` is a named list of permissions
        # defined by IAM.
        #
        # **JSON Example**
        #
        #     {
        #       "bindings": [
        #         {
        #           "role": "roles/owner",
        #           "members": [
        #             "user:mike@example.com",
        #             "group:admins@example.com",
        #             "domain:google.com",
        #             "serviceAccount:my-other-app@appspot.gserviceaccount.com"
        #           ]
        #         },
        #         {
        #           "role": "roles/viewer",
        #           "members": ["user:sean@example.com"]
        #         }
        #       ]
        #     }
        #
        # **YAML Example**
        #
        #     bindings:
        #     - members:
        #       - user:mike@example.com
        #       - group:admins@example.com
        #       - domain:google.com
        #       - serviceAccount:my-other-app@appspot.gserviceaccount.com
        #       role: roles/owner
        #     - members:
        #       - user:sean@example.com
        #       role: roles/viewer
        #
        #
        # For a description of IAM and its features, see the
        # [IAM developer's guide](https://cloud.google.com/iam/docs).
      "bindings": [ # Associates a list of `members` to a `role`.
          # `bindings` with no members will result in an error.
        { # Associates `members` with a `role`.
          "role": "A String", # Role that is assigned to `members`.
              # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
          "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@gmail.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`.
              #
              #
              # * `domain:{domain}`: The G Suite domain (primary) that represents all the
              #    users of that domain. For example, `google.com` or `example.com`.
              #
            "A String",
          ],
          "condition": { # Represents an expression text. Example: # 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.
              #
              #     title: "User account presence"
              #     description: "Determines whether the request has a user account"
              #     expression: "size(request.user) > 0"
            "location": "A String", # An optional string indicating the location of the expression for error
                # reporting, e.g. a file name and a position in the file.
            "expression": "A String", # Textual representation of an expression in
                # Common Expression Language syntax.
                #
                # The application context of the containing message determines which
                # well-known feature set of CEL is supported.
            "description": "A String", # An optional description of the expression. This is a longer text which
                # describes the expression, e.g. when hovered over it in a UI.
            "title": "A String", # An 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.
          },
        },
      ],
      "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.
          #
          # If no `etag` is provided in the call to `setIamPolicy`, then the existing
          # policy is overwritten blindly.
      "version": 42, # Deprecated.
    },
  }

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

Returns:
  An object of the form:

    { # Defines an Identity and Access Management (IAM) policy. It is used to
      # specify access control policies for Cloud Platform resources.
      #
      #
      # A `Policy` consists of a list of `bindings`. A `binding` binds a list of
      # `members` to a `role`, where the members can be user accounts, Google groups,
      # Google domains, and service accounts. A `role` is a named list of permissions
      # defined by IAM.
      #
      # **JSON Example**
      #
      #     {
      #       "bindings": [
      #         {
      #           "role": "roles/owner",
      #           "members": [
      #             "user:mike@example.com",
      #             "group:admins@example.com",
      #             "domain:google.com",
      #             "serviceAccount:my-other-app@appspot.gserviceaccount.com"
      #           ]
      #         },
      #         {
      #           "role": "roles/viewer",
      #           "members": ["user:sean@example.com"]
      #         }
      #       ]
      #     }
      #
      # **YAML Example**
      #
      #     bindings:
      #     - members:
      #       - user:mike@example.com
      #       - group:admins@example.com
      #       - domain:google.com
      #       - serviceAccount:my-other-app@appspot.gserviceaccount.com
      #       role: roles/owner
      #     - members:
      #       - user:sean@example.com
      #       role: roles/viewer
      #
      #
      # For a description of IAM and its features, see the
      # [IAM developer's guide](https://cloud.google.com/iam/docs).
    "bindings": [ # Associates a list of `members` to a `role`.
        # `bindings` with no members will result in an error.
      { # Associates `members` with a `role`.
        "role": "A String", # Role that is assigned to `members`.
            # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
        "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@gmail.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`.
            #
            #
            # * `domain:{domain}`: The G Suite domain (primary) that represents all the
            #    users of that domain. For example, `google.com` or `example.com`.
            #
          "A String",
        ],
        "condition": { # Represents an expression text. Example: # 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.
            #
            #     title: "User account presence"
            #     description: "Determines whether the request has a user account"
            #     expression: "size(request.user) > 0"
          "location": "A String", # An optional string indicating the location of the expression for error
              # reporting, e.g. a file name and a position in the file.
          "expression": "A String", # Textual representation of an expression in
              # Common Expression Language syntax.
              #
              # The application context of the containing message determines which
              # well-known feature set of CEL is supported.
          "description": "A String", # An optional description of the expression. This is a longer text which
              # describes the expression, e.g. when hovered over it in a UI.
          "title": "A String", # An 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.
        },
      },
    ],
    "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.
        #
        # If no `etag` is provided in the call to `setIamPolicy`, then the existing
        # policy is overwritten blindly.
    "version": 42, # Deprecated.
  }
testIamPermissions(resource, body, x__xgafv=None)
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.

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. (required)
    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",
    ],
  }
update(name, body, x__xgafv=None)
Updates an attestor.
Returns NOT_FOUND if the attestor does not exist.

Args:
  name: string, Required. The resource name, in the format:
`projects/*/attestors/*`. This field may not be updated. (required)
  body: object, The request body. (required)
    The object takes the form of:

{ # An attestor that attests to container image
    # artifacts. An existing attestor cannot be modified except where
    # indicated.
  "updateTime": "A String", # Output only. Time when the attestor was last updated.
  "description": "A String", # Optional. A descriptive comment.  This field may be updated.
      # The field may be displayed in chooser dialogs.
  "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
      # ATTESTATION_AUTHORITY Note created by the user.
    "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
        # that this Attestor will use as the principal when querying Container
        # Analysis. Attestor administrators must grant this service account the
        # IAM role needed to read attestations from the note_reference in
        # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
        #
        # This email address is fixed for the lifetime of the Attestor, but callers
        # should not make any other assumptions about the service account email;
        # future versions may use an email based on a different naming pattern.
    "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
        # created by the user, in the format: `projects/*/notes/*` (or the legacy
        # `providers/*/notes/*`). This field may not be updated.
        #
        # An attestation by this attestor is stored as a Drydock
        # ATTESTATION_AUTHORITY Occurrence that names a container image and that
        # links to this Note. Drydock is an external dependency.
    "publicKeys": [ # Optional. Public keys that verify attestations signed by this
        # attestor.  This field may be updated.
        #
        # If this field is non-empty, one of the specified public keys must
        # verify that an attestation was signed by this attestor for the
        # image specified in the admission request.
        #
        # If this field is empty, this attestor always returns that no
        # valid attestations exist.
      { # An attestor public key that will be used to verify
          # attestations signed by this attestor.
        "comment": "A String", # Optional. A descriptive comment. This field may be updated.
        "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
            # the command `gpg --export --armor foo@example.com` (either LF or CRLF
            # line endings).
            # When using this field, `id` should be left blank.  The BinAuthz API
            # handlers will calculate the ID and fill it in automatically.  BinAuthz
            # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
            # upper-case hex.  If `id` is provided by the caller, it will be
            # overwritten by the API-calculated ID.
        "id": "A String", # The ID of this public key.
            # Signatures verified by BinAuthz must include the ID of the public key that
            # can be used to verify them, and that ID must match the contents of this
            # field exactly.
            # Additional restrictions on this field can be imposed based on which public
            # key type is encapsulated. See the documentation on `public_key` cases below
            # for details.
        "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
            #
            # NOTE: `id` may be explicitly provided by the caller when using this
            # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
            # blank, a default one will be computed based on the digest of the DER
            # encoding of the public key.
            # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
            # Public keys of this type are typically textually encoded using the PEM
            # format.
          "publicKeyPem": "A String", # A PEM-encoded public key, as described in
              # https://tools.ietf.org/html/rfc7468#section-13
          "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
              # this key.
              # These signature algorithm must match the structure and any object
              # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
              # that of the public key).
        },
      },
    ],
  },
  "name": "A String", # Required. The resource name, in the format:
      # `projects/*/attestors/*`. This field may not be updated.
}

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

Returns:
  An object of the form:

    { # An attestor that attests to container image
      # artifacts. An existing attestor cannot be modified except where
      # indicated.
    "updateTime": "A String", # Output only. Time when the attestor was last updated.
    "description": "A String", # Optional. A descriptive comment.  This field may be updated.
        # The field may be displayed in chooser dialogs.
    "userOwnedDrydockNote": { # An user owned drydock note references a Drydock # A Drydock ATTESTATION_AUTHORITY Note, created by the user.
        # ATTESTATION_AUTHORITY Note created by the user.
      "delegationServiceAccountEmail": "A String", # Output only. This field will contain the service account email address
          # that this Attestor will use as the principal when querying Container
          # Analysis. Attestor administrators must grant this service account the
          # IAM role needed to read attestations from the note_reference in
          # Container Analysis (`containeranalysis.notes.occurrences.viewer`).
          #
          # This email address is fixed for the lifetime of the Attestor, but callers
          # should not make any other assumptions about the service account email;
          # future versions may use an email based on a different naming pattern.
      "noteReference": "A String", # Required. The Drydock resource name of a ATTESTATION_AUTHORITY Note,
          # created by the user, in the format: `projects/*/notes/*` (or the legacy
          # `providers/*/notes/*`). This field may not be updated.
          #
          # An attestation by this attestor is stored as a Drydock
          # ATTESTATION_AUTHORITY Occurrence that names a container image and that
          # links to this Note. Drydock is an external dependency.
      "publicKeys": [ # Optional. Public keys that verify attestations signed by this
          # attestor.  This field may be updated.
          #
          # If this field is non-empty, one of the specified public keys must
          # verify that an attestation was signed by this attestor for the
          # image specified in the admission request.
          #
          # If this field is empty, this attestor always returns that no
          # valid attestations exist.
        { # An attestor public key that will be used to verify
            # attestations signed by this attestor.
          "comment": "A String", # Optional. A descriptive comment. This field may be updated.
          "asciiArmoredPgpPublicKey": "A String", # ASCII-armored representation of a PGP public key, as the entire output by
              # the command `gpg --export --armor foo@example.com` (either LF or CRLF
              # line endings).
              # When using this field, `id` should be left blank.  The BinAuthz API
              # handlers will calculate the ID and fill it in automatically.  BinAuthz
              # computes this ID as the OpenPGP RFC4880 V4 fingerprint, represented as
              # upper-case hex.  If `id` is provided by the caller, it will be
              # overwritten by the API-calculated ID.
          "id": "A String", # The ID of this public key.
              # Signatures verified by BinAuthz must include the ID of the public key that
              # can be used to verify them, and that ID must match the contents of this
              # field exactly.
              # Additional restrictions on this field can be imposed based on which public
              # key type is encapsulated. See the documentation on `public_key` cases below
              # for details.
          "pkixPublicKey": { # A public key in the PkixPublicKey format (see # A raw PKIX SubjectPublicKeyInfo format public key.
              #
              # NOTE: `id` may be explicitly provided by the caller when using this
              # type of public key, but it MUST be a valid RFC3986 URI. If `id` is left
              # blank, a default one will be computed based on the digest of the DER
              # encoding of the public key.
              # https://tools.ietf.org/html/rfc5280#section-4.1.2.7 for details).
              # Public keys of this type are typically textually encoded using the PEM
              # format.
            "publicKeyPem": "A String", # A PEM-encoded public key, as described in
                # https://tools.ietf.org/html/rfc7468#section-13
            "signatureAlgorithm": "A String", # The signature algorithm used to verify a message against a signature using
                # this key.
                # These signature algorithm must match the structure and any object
                # identifiers encoded in `public_key_pem` (i.e. this algorithm must match
                # that of the public key).
          },
        },
      ],
    },
    "name": "A String", # Required. The resource name, in the format:
        # `projects/*/attestors/*`. This field may not be updated.
  }