listPoliciesGrantingServiceAccess method
Retrieves a list of policies that the IAM identity (user, group, or role) can use to access each specified service. The list of policies returned by the operation depends on the ARN of the identity that you provide.
- User – The list of policies includes the managed and inline policies that are attached to the user directly. The list also includes any additional managed and inline policies that are attached to the group to which the user belongs.
- Group – The list of policies includes only the managed and inline policies that are attached to the group directly. Policies that are attached to the group’s user are not included.
- Role – The list of policies includes only the managed and inline policies that are attached to the role.
Policies that are attached to users and roles as permissions boundaries are not returned. To view which managed policy is currently used to set the permissions boundary for a user or role, use the GetUser or GetRole operations.
May throw NoSuchEntityException. May throw InvalidInputException.
Parameter arn
:
The ARN of the IAM identity (user, group, or role) whose policies you want
to list.
Parameter serviceNamespaces
:
The service namespace for the AWS services whose policies you want to
list.
To learn the service namespace for a service, go to Actions,
Resources, and Condition Keys for AWS Services in the IAM User
Guide. Choose the name of the service to view details for that
service. In the first paragraph, find the service prefix. For example,
(service prefix: a4b)
. For more information about service
namespaces, see AWS
Service Namespaces in the AWS General Reference.
Parameter marker
:
Use this parameter only when paginating results and only after you receive
a response indicating that the results are truncated. Set it to the value
of the Marker
element in the response that you received to
indicate where the next call should start.
Implementation
Future<ListPoliciesGrantingServiceAccessResponse>
listPoliciesGrantingServiceAccess({
required String arn,
required List<String> serviceNamespaces,
String? marker,
}) async {
ArgumentError.checkNotNull(arn, 'arn');
_s.validateStringLength(
'arn',
arn,
20,
2048,
isRequired: true,
);
ArgumentError.checkNotNull(serviceNamespaces, 'serviceNamespaces');
_s.validateStringLength(
'marker',
marker,
1,
320,
);
final $request = <String, dynamic>{};
$request['Arn'] = arn;
$request['ServiceNamespaces'] = serviceNamespaces;
marker?.also((arg) => $request['Marker'] = arg);
final $result = await _protocol.send(
$request,
action: 'ListPoliciesGrantingServiceAccess',
version: '2010-05-08',
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
shape: shapes['ListPoliciesGrantingServiceAccessRequest'],
shapes: shapes,
resultWrapper: 'ListPoliciesGrantingServiceAccessResult',
);
return ListPoliciesGrantingServiceAccessResponse.fromXml($result);
}