AWS services or capabilities described in AWS Documentation may vary by region/location. Click Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.
Returns information about all grants in the Amazon Web Services account and Region that have the specified retiring principal.
You can specify any principal in your Amazon Web Services account. The grants that are returned include grants for KMS keys in your Amazon Web Services account and other Amazon Web Services accounts. You might use this operation to determine which grants you may retire. To retire a grant, use the RetireGrant operation.
For detailed information about grants, including grant terminology, see Grants in KMS in the Key Management Service Developer Guide. For examples of working with grants in several programming languages, see Programming grants.
Cross-account use: You must specify a principal in your Amazon Web Services
account. This operation returns a list of grants where the retiring principal specified
in the ListRetirableGrants
request is the same retiring principal on the grant.
This can include grants on KMS keys owned by other Amazon Web Services accounts, but
you do not need kms:ListRetirableGrants
permission (or any other additional
permission) in any Amazon Web Services account other than your own.
Required permissions: kms:ListRetirableGrants (IAM policy) in your Amazon Web Services account.
KMS authorizes ListRetirableGrants
requests by evaluating the caller account's
kms:ListRetirableGrants permissions. The authorized resource in ListRetirableGrants
calls is the retiring principal specified in the request. KMS does not evaluate the
caller's permissions to verify their access to any KMS keys or grants that might be
returned by the ListRetirableGrants
call.
Related operations:
Eventual consistency: The KMS API follows an eventual consistency model. For more information, see KMS eventual consistency.
For .NET Core this operation is only available in asynchronous form. Please refer to ListRetirableGrantsAsync.
Namespace: Amazon.KeyManagementService
Assembly: AWSSDK.KeyManagementService.dll
Version: 3.x.y.z
public virtual ListRetirableGrantsResponse ListRetirableGrants( ListRetirableGrantsRequest request )
Container for the necessary parameters to execute the ListRetirableGrants service method.
Exception | Condition |
---|---|
DependencyTimeoutException | The system timed out while trying to fulfill the request. You can retry the request. |
InvalidArnException | The request was rejected because a specified ARN, or an ARN in a key policy, is not valid. |
InvalidMarkerException | The request was rejected because the marker that specifies where pagination should next begin is not valid. |
KMSInternalException | The request was rejected because an internal exception occurred. The request can be retried. |
NotFoundException | The request was rejected because the specified entity or resource could not be found. |
The following example lists the grants that the specified principal (identity) can retire.
var client = new AmazonKeyManagementServiceClient(); var response = client.ListRetirableGrants(new ListRetirableGrantsRequest { RetiringPrincipal = "arn:aws:iam::111122223333:role/ExampleRole" // The retiring principal whose grants you want to list. Use the Amazon Resource Name (ARN) of a principal such as an AWS account (root), IAM user, federated user, or assumed role user. }); List<GrantListEntry> grants = response.Grants; // A list of grants that the specified principal can retire. bool truncated = response.Truncated; // A boolean that indicates whether there are more items in the list. Returns true when there are more items, or false when there are not.
.NET Framework:
Supported in: 4.5 and newer, 3.5