listGrants method
Gets a list of all grants for the specified customer master key (CMK).
Cross-account use: Yes. To perform this operation on a CMK in a
different AWS account, specify the key ARN in the value of the
KeyId
parameter.
Required permissions: kms:ListGrants (key policy)
Related operations:
May throw NotFoundException. May throw DependencyTimeoutException. May throw InvalidMarkerException. May throw InvalidArnException. May throw KMSInternalException. May throw KMSInvalidStateException.
Parameter keyId
:
A unique identifier for the customer master key (CMK).
Specify the key ID or the Amazon Resource Name (ARN) of the CMK. To specify a CMK in a different AWS account, you must use the key ARN.
For example:
-
Key ID:
1234abcd-12ab-34cd-56ef-1234567890ab
-
Key ARN:
arn:aws:kms:us-east-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab
Parameter limit
:
Use this parameter to specify the maximum number of items to return. When
this value is present, AWS KMS does not return more than the specified
number of items, but it might return fewer.
This value is optional. If you include a value, it must be between 1 and 100, inclusive. If you do not include a value, it defaults to 50.
Parameter marker
:
Use this parameter in a subsequent request after you receive a response
with truncated results. Set it to the value of NextMarker
from the truncated response you just received.
Implementation
Future<ListGrantsResponse> listGrants({
required String keyId,
int? limit,
String? marker,
}) async {
ArgumentError.checkNotNull(keyId, 'keyId');
_s.validateStringLength(
'keyId',
keyId,
1,
2048,
isRequired: true,
);
_s.validateNumRange(
'limit',
limit,
1,
1000,
);
_s.validateStringLength(
'marker',
marker,
1,
1024,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.1',
'X-Amz-Target': 'TrentService.ListGrants'
};
final jsonResponse = await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'KeyId': keyId,
if (limit != null) 'Limit': limit,
if (marker != null) 'Marker': marker,
},
);
return ListGrantsResponse.fromJson(jsonResponse.body);
}