1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
module Fog
module AWS
class Compute
class Real
require 'fog/aws/parsers/compute/basic'
# Deletes a network ACL entry
#
# ==== Parameters
# * network_acl_id<~String> - The ID of the network ACL
# * rule_number<~Integer> - The rule number of the entry to delete.
# * egress<~Boolean> - Indicates whether the rule is an egress rule (true) or ingress rule (false)
#
# === Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'requestId'<~String> - Id of request
# * 'return'<~Boolean> - Returns true if the request succeeds.
#
# {Amazon API Reference}[http://docs.aws.amazon.com/AWSEC2/latest/APIReference/ApiReference-query-DeleteNetworkAclEntry.html]
def delete_network_acl_entry(network_acl_id, rule_number, egress)
request(
'Action' => 'DeleteNetworkAclEntry',
'NetworkAclId' => network_acl_id,
'RuleNumber' => rule_number,
'Egress' => egress,
:parser => Fog::Parsers::AWS::Compute::Basic.new
)
end
end
class Mock
def delete_network_acl_entry(network_acl_id, rule_number, egress)
response = Excon::Response.new
if self.data[:network_acls][network_acl_id]
if self.data[:network_acls][network_acl_id]['entrySet'].find { |r| r['ruleNumber'] == rule_number && r['egress'] == egress }
self.data[:network_acls][network_acl_id]['entrySet'].delete_if { |r| r['ruleNumber'] == rule_number && r['egress'] == egress }
else
raise Fog::AWS::Compute::Error.new("No rule with that number and egress value")
end
response.status = 200
response.body = {
'requestId' => Fog::AWS::Mock.request_id,
'return' => true
}
response
else
raise Fog::AWS::Compute::NotFound.new("The network ACL '#{network_acl_id}' does not exist")
end
end
end
end
end
end
|