/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
/*
* Do not modify this file. This file is generated from the iam-2010-05-08.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.IdentityManagement.Model
{
///
/// Container for the parameters to the ListPoliciesGrantingServiceAccess operation.
/// Retrieves a list of policies that the IAM identity (user, group, or role) can use
/// to access each specified service.
///
///
///
/// This operation does not use other policy types when determining whether a resource
/// could access a service. These other policy types include resource-based policies,
/// access control lists, Organizations policies, IAM permissions boundaries, and STS
/// assume role policies. It only applies permissions policy logic. For more about the
/// evaluation of policy types, see Evaluating
/// policies in the IAM User Guide.
///
///
///
/// 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.
///
///
///
/// For each managed policy, this operation returns the ARN and policy name. For each
/// inline policy, it returns the policy name and the entity to which it is attached.
/// Inline policies do not have an ARN. For more information about these policy types,
/// see Managed
/// policies and inline policies in the IAM User Guide.
///
///
///
/// 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.
///
///
public partial class ListPoliciesGrantingServiceAccessRequest : AmazonIdentityManagementServiceRequest
{
private string _arn;
private string _marker;
private List _serviceNamespaces = new List();
///
/// Gets and sets the property Arn.
///
/// The ARN of the IAM identity (user, group, or role) whose policies you want to list.
///
///
[AWSProperty(Required=true, Min=20, Max=2048)]
public string Arn
{
get { return this._arn; }
set { this._arn = value; }
}
// Check to see if Arn property is set
internal bool IsSetArn()
{
return this._arn != null;
}
///
/// Gets and sets the property 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.
///
///
[AWSProperty(Min=1, Max=320)]
public string Marker
{
get { return this._marker; }
set { this._marker = value; }
}
// Check to see if Marker property is set
internal bool IsSetMarker()
{
return this._marker != null;
}
///
/// Gets and sets the property ServiceNamespaces.
///
/// The service namespace for the Amazon Web Services services whose policies you want
/// to list.
///
///
///
/// To learn the service namespace for a service, see Actions,
/// resources, and condition keys for Amazon Web Services 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 Amazon
/// Web Services service namespaces in the Amazon Web Services General Reference.
///
///
[AWSProperty(Required=true, Min=1, Max=200)]
public List ServiceNamespaces
{
get { return this._serviceNamespaces; }
set { this._serviceNamespaces = value; }
}
// Check to see if ServiceNamespaces property is set
internal bool IsSetServiceNamespaces()
{
return this._serviceNamespaces != null && this._serviceNamespaces.Count > 0;
}
}
}