- NAME
- 
- gcloud alpha kms keys add-iam-policy-binding - add IAM policy binding for a kms key
 
- SYNOPSIS
- 
- 
gcloud alpha kms keys add-iam-policy-binding(KEY:--keyring=KEYRING--location=LOCATION)--member=PRINCIPAL--role=ROLE[--condition=[KEY=VALUE,…] |--condition-from-file=PATH_TO_FILE] [GCLOUD_WIDE_FLAG …]
 
- 
- DESCRIPTION
- 
(ALPHA)Adds a policy binding to the IAM policy of a kms key. A binding consists of at least one member, a role, and an optional condition.
- EXAMPLES
- 
To add an IAM policy binding for the role of 'roles/editor' for the user
'test-user@gmail.com' on the key frodo with the keyring fellowship and location
global, run:
gcloud alpha kms keys add-iam-policy-binding frodo --keyring='fellowship' --location='global' --member='user:test-user@gmail.com' --role='roles/editor'To add an IAM policy binding which expires at the end of the year 2018 for the role of 'roles/cloudkms.signer' and the user 'test-user@gmail.com' on a the key frodo with the keyring fellowship and location global, run: gcloud alpha kms keys add-iam-policy-binding frodo --keyring='fellowship' --location='global' --member='user:test-user@gmail.com' --role='roles/cloudkms.signer' --condition='expression=request.time <timestamp("2019-01-01T00:00:00Z"),title=expires_end_of_2018,descrip\ tion=Expires at midnight on 2018-12-31'See https://cloud.google.com/iam/docs/managing-policies for details of policy role and member types. 
- POSITIONAL ARGUMENTS
- 
- 
Key resource - The key to add the IAM policy binding. The arguments in this
group can be used to specify the attributes of this resource. (NOTE) Some
attributes are not given arguments in this group but can be set in other ways.
To set the projectattribute:- 
provide the argument keyon the command line with a fully specified name;
- 
provide the argument --projecton the command line;
- 
set the property core/project.
 This must be specified. - KEY
- 
ID of the key or fully qualified identifier for the key.
To set the keyattribute:- 
provide the argument keyon the command line.
 This positional argument must be specified if any of the other arguments in this group are specified. 
- 
provide the argument 
- --keyring=- KEYRING
- 
The containing keyring.
To set the keyringattribute:- 
provide the argument keyon the command line with a fully specified name;
- 
provide the argument --keyringon the command line.
 
- 
provide the argument 
- --location=- LOCATION
- 
The location of the resource.
To set the locationattribute:- 
provide the argument keyon the command line with a fully specified name;
- 
provide the argument --locationon the command line.
 
- 
provide the argument 
 
- 
provide the argument 
 
- 
Key resource - The key to add the IAM policy binding. The arguments in this
group can be used to specify the attributes of this resource. (NOTE) Some
attributes are not given arguments in this group but can be set in other ways.
- REQUIRED FLAGS
- 
- --member=- PRINCIPAL
- 
The principal to add the binding for. Should be of the form
user|group|serviceAccount:emailordomain:domain.Examples: user:test-user@gmail.com,group:admins@example.com,serviceAccount:test123@example.domain.com, ordomain:example.domain.com.Some resources also accept the following special values: - 
allUsers- Special identifier that represents anyone who is on the internet, with or without a Google account.
- 
allAuthenticatedUsers- Special identifier that represents anyone who is authenticated with a Google account or a service account.
 
- 
- --role=- ROLE
- 
Role name to assign to the principal. The role name is the complete path of a
predefined role, such as roles/logging.viewer, or the role ID for a custom role, such asorganizations/{ORGANIZATION_ID}/roles/logging.viewer.
 
- OPTIONAL FLAGS
- 
- 
At most one of these can be specified:
- --condition=[- KEY=- VALUE,…]
- 
A condition to include in the binding. When the condition is explicitly
specified as None(--condition=None), a binding without a condition is added. When the condition is specified and is notNone,--rolecannot be a basic role. Basic roles areroles/editor,roles/owner, androles/viewer. For more on conditions, refer to the conditions overview guide: https://cloud.google.com/iam/docs/conditions-overviewWhen using the --conditionflag, include the following key-value pairs:- expression
- 
(Required) Condition expression that evaluates to True or False. This uses a
subset of Common Expression Language syntax.
If the condition expression includes a comma, use a different delimiter to separate the key-value pairs. Specify the delimiter before listing the key-value pairs. For example, to specify a colon ( :) as the delimiter, do the following:--condition=^:^title=TITLE:expression=EXPRESSION. For more information, see https://cloud.google.com/sdk/gcloud/reference/topic/escaping.
- title
- (Required) A short string describing the purpose of the expression.
- description
- (Optional) Additional description for the expression.
 
- --condition-from-file=- PATH_TO_FILE
- 
Path to a local JSON or YAML file that defines the condition. To see available
fields, see the help for --condition. Use a full or relative path to a local file containing the value of condition.
 
 
- 
At most one of these can be specified:
- GCLOUD WIDE FLAGS
- 
These flags are available to all commands: --access-token-file,--account,--billing-project,--configuration,--flags-file,--flatten,--format,--help,--impersonate-service-account,--log-http,--project,--quiet,--trace-token,--user-output-enabled,--verbosity.Run $ gcloud helpfor details.
- API REFERENCE
- 
This command uses the cloudkms/v1API. The full documentation for this API can be found at: https://cloud.google.com/kms/
- NOTES
- 
This command is currently in alpha and might change without notice. If this
command fails with API permission errors despite specifying the correct project,
you might be trying to access an API with an invitation-only early access
allowlist. These variants are also available:
gcloud kms keys add-iam-policy-bindinggcloud beta kms keys add-iam-policy-binding
      gcloud alpha kms keys add-iam-policy-binding
  
  
  Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-05-07 UTC.