Actions, resources, and condition keys for Elastic Load Balancing V2 - Service Authorization Reference

Actions, resources, and condition keys for Elastic Load Balancing V2

Elastic Load Balancing V2 (service prefix: elasticloadbalancing) provides the following service-specific resources, actions, and condition context keys for use in IAM permission policies.

References:

Actions defined by Elastic Load Balancing V2

You can specify the following actions in the Action element of an IAM policy statement. Use policies to grant permissions to perform an operation in AWS. When you use an action in a policy, you usually allow or deny access to the API operation or CLI command with the same name. However, in some cases, a single action controls access to more than one operation. Alternatively, some operations require several different actions.

The Resource types column indicates whether each action supports resource-level permissions. If there is no value for this column, you must specify all resources ("*") in the Resource element of your policy statement. If the column includes a resource type, then you can specify an ARN of that type in a statement with that action. Required resources are indicated in the table with an asterisk (*). If you specify a resource-level permission ARN in a statement using this action, then it must be of this type. Some actions support multiple resource types. If the resource type is optional (not indicated as required), then you can choose to use one but not the other.

For details about the columns in the following table, see Actions table.

Actions Description Access level Resource types (*required) Condition keys Dependent actions
AddListenerCertificates Grants permission to add the specified certificates to the specified secure listener Write

listener/app*

listener/net*

AddTags Grants permission to add the specified tags to the specified load balancer. Each load balancer can have a maximum of 10 tags Tagging

listener-rule/app

listener-rule/net

listener/app

listener/net

loadbalancer/app/

loadbalancer/net/

targetgroup

aws:RequestTag/${TagKey}

aws:TagKeys

CreateListener Grants permission to create a listener for the specified Application Load Balancer Write

loadbalancer/app/

loadbalancer/net/

aws:RequestTag/${TagKey}

aws:TagKeys

CreateLoadBalancer Grants permission to create a load balancer Write

loadbalancer/app/

loadbalancer/net/

aws:RequestTag/${TagKey}

aws:TagKeys

CreateRule Grants permission to create a rule for the specified listener Write

listener/app*

listener/net*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateTargetGroup Grants permission to create a target group Write

targetgroup*

aws:RequestTag/${TagKey}

aws:TagKeys

DeleteListener Grants permission to delete the specified listener Write

listener/app*

listener/net*

DeleteLoadBalancer Grants permission to delete the specified load balancer Write

loadbalancer/app/

loadbalancer/net/

DeleteRule Grants permission to delete the specified rule Write

listener-rule/app*

listener-rule/net*

DeleteTargetGroup Grants permission to delete the specified target group Write

targetgroup*

DeregisterTargets Grants permission to deregister the specified targets from the specified target group Write

targetgroup*

DescribeAccountLimits Grants permission to describe the Elastic Load Balancing resource limits for the AWS account Read
DescribeListenerCertificates Grants permission to describe the certificates for the specified secure listener Read
DescribeListeners Grants permission to describe the specified listeners or the listeners for the specified Application Load Balancer Read
DescribeLoadBalancerAttributes Grants permission to describe the attributes for the specified load balancer Read
DescribeLoadBalancers Grants permission to describe the specified the load balancers. If no load balancers are specified, the call describes all of your load balancers Read
DescribeRules Grants permission to describe the specified rules or the rules for the specified listener Read
DescribeSSLPolicies Grants permission to describe the specified policies or all policies used for SSL negotiation Read
DescribeTags Grants permission to describe the tags associated with the specified resource Read
DescribeTargetGroupAttributes Grants permission to describe the attributes for the specified target group Read
DescribeTargetGroups Grants permission to describe the specified target groups or all of your target groups Read
DescribeTargetHealth Grants permission to describe the health of the specified targets or all of your targets Read
ModifyListener Grants permission to modify the specified properties of the specified listener Write

listener/app*

listener/net*

ModifyLoadBalancerAttributes Grants permission to modify the attributes of the specified load balancer Write

loadbalancer/app/

loadbalancer/net/

ModifyRule Grants permission to modify the specified rule Write

listener-rule/app*

listener-rule/net*

ModifyTargetGroup Grants permission to modify the health checks used when evaluating the health state of the targets in the specified target group Write

targetgroup*

ModifyTargetGroupAttributes Grants permission to modify the specified attributes of the specified target group Write

targetgroup*

RegisterTargets Grants permission to register the specified targets with the specified target group Write

targetgroup*

RemoveListenerCertificates Grants permission to remove the specified certificates of the specified secure listener Write

listener/app*

listener/net*

RemoveTags Grants permission to remove one or more tags from the specified load balancer Tagging

listener-rule/app

listener-rule/net

listener/app

listener/net

loadbalancer/app/

loadbalancer/net/

targetgroup

aws:RequestTag/${TagKey}

aws:TagKeys

SetIpAddressType Grants permission to set the type of IP addresses used by the subnets of the specified load balancer Write

loadbalancer/app/

loadbalancer/net/

SetRulePriorities Grants permission to set the priorities of the specified rules Write

listener-rule/app*

listener-rule/net*

SetSecurityGroups Grants permission to associate the specified security groups with the specified load balancer Write

loadbalancer/app/

loadbalancer/net/

SetSubnets Grants permission to enable the Availability Zone for the specified subnets for the specified load balancer Write

loadbalancer/app/

loadbalancer/net/

SetWebAcl [permission only] Grants permission to give WebAcl permission to WAF Write

Resource types defined by Elastic Load Balancing V2

The following resource types are defined by this service and can be used in the Resource element of IAM permission policy statements. Each action in the Actions table identifies the resource types that can be specified with that action. A resource type can also define which condition keys you can include in a policy. These keys are displayed in the last column of the table. For details about the columns in the following table, see Resource types table.

Resource types ARN Condition keys
listener/app arn:${Partition}:elasticloadbalancing:${Region}:${Account}:listener/app/${LoadBalancerName}/${LoadBalancerId}/${ListenerId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

listener-rule/app arn:${Partition}:elasticloadbalancing:${Region}:${Account}:listener-rule/app/${LoadBalancerName}/${LoadBalancerId}/${ListenerId}/${ListenerRuleId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

listener/net arn:${Partition}:elasticloadbalancing:${Region}:${Account}:listener/net/${LoadBalancerName}/${LoadBalancerId}/${ListenerId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

listener-rule/net arn:${Partition}:elasticloadbalancing:${Region}:${Account}:listener-rule/net/${LoadBalancerName}/${LoadBalancerId}/${ListenerId}/${ListenerRuleId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

loadbalancer/app/ arn:${Partition}:elasticloadbalancing:${Region}:${Account}:loadbalancer/app/${LoadBalancerName}/${LoadBalancerId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

loadbalancer/net/ arn:${Partition}:elasticloadbalancing:${Region}:${Account}:loadbalancer/net/${LoadBalancerName}/${LoadBalancerId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

targetgroup arn:${Partition}:elasticloadbalancing:${Region}:${Account}:targetgroup/${TargetGroupName}/${TargetGroupId}

aws:ResourceTag/${TagKey}

elasticloadbalancing:ResourceTag/${TagKey}

Condition keys for Elastic Load Balancing V2

Elastic Load Balancing V2 defines the following condition keys that can be used in the Condition element of an IAM policy. You can use these keys to further refine the conditions under which the policy statement applies. For details about the columns in the following table, see Condition keys table.

To view the global condition keys that are available to all services, see Available global condition keys.

Condition keys Description Type
aws:RequestTag/${TagKey} A key that is present in the request the user makes to the ELB service String
aws:ResourceTag/${TagKey} Global tag key and value pair String
aws:TagKeys The list of all the tag key names associated with the resource in the request ArrayOfString
elasticloadbalancing:ResourceTag/${TagKey} A tag key and value pair String