mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
[aws|compute] describe security groups parser was not taking into account ipPermissionsEgress and therefore returning unexpected results when the account had VPC groups.
This commit is contained in:
parent
3e8a2f3177
commit
5b5bea6553
1 changed files with 31 additions and 7 deletions
|
@ -8,8 +8,9 @@ module Fog
|
|||
def reset
|
||||
@group = {}
|
||||
@ip_permission = { 'groups' => [], 'ipRanges' => []}
|
||||
@ip_permission_egress = { 'groups' => [], 'ipRanges' => []}
|
||||
@ip_range = {}
|
||||
@security_group = { 'ipPermissions' => [] }
|
||||
@security_group = { 'ipPermissions' => [], 'ipPermissionsEgress' => [] }
|
||||
@response = { 'securityGroupInfo' => [] }
|
||||
end
|
||||
|
||||
|
@ -20,6 +21,8 @@ module Fog
|
|||
@in_groups = true
|
||||
when 'ipPermissions'
|
||||
@in_ip_permissions = true
|
||||
when 'ipPermissionsEgress'
|
||||
@in_ip_permissions_egress = true
|
||||
when 'ipRanges'
|
||||
@in_ip_ranges = true
|
||||
end
|
||||
|
@ -30,7 +33,11 @@ module Fog
|
|||
when 'cidrIp'
|
||||
@ip_range[name] = value
|
||||
when 'fromPort', 'toPort'
|
||||
@ip_permission[name] = value.to_i
|
||||
if @in_ip_permissions_egress
|
||||
@ip_permission_egress[name] = value.to_i
|
||||
else
|
||||
@ip_permission[name] = value.to_i
|
||||
end
|
||||
when 'groups'
|
||||
@in_groups = false
|
||||
when 'groupDescription', 'ownerId'
|
||||
|
@ -43,23 +50,40 @@ module Fog
|
|||
end
|
||||
when 'ipPermissions'
|
||||
@in_ip_permissions = false
|
||||
when 'ipPermissionsEgress'
|
||||
@in_ip_permissions_egress = false
|
||||
when 'ipProtocol'
|
||||
@ip_permission[name] = value
|
||||
if @in_ip_permissions_egress
|
||||
@ip_permission_egress[name] = value
|
||||
else
|
||||
@ip_permission[name] = value
|
||||
end
|
||||
when 'ipRanges'
|
||||
@in_ip_ranges = false
|
||||
when 'item'
|
||||
if @in_groups
|
||||
@ip_permission['groups'] << @group
|
||||
if @in_ip_permissions_egress
|
||||
@ip_permission_egress['group'] << @group
|
||||
else
|
||||
@ip_permission['groups'] << @group
|
||||
end
|
||||
@group = {}
|
||||
elsif @in_ip_ranges
|
||||
@ip_permission['ipRanges'] << @ip_range
|
||||
if @in_ip_permissions_egress
|
||||
@ip_permission_egress['ipRanges'] << @ip_range
|
||||
else
|
||||
@ip_permission['ipRanges'] << @ip_range
|
||||
end
|
||||
@ip_range = {}
|
||||
elsif @in_ip_permissions
|
||||
@security_group['ipPermissions'] << @ip_permission
|
||||
@ip_permission = { 'groups' => [], 'ipRanges' => []}
|
||||
else
|
||||
elsif @in_ip_permissions_egress
|
||||
@security_group['ipPermissionsEgress'] << @ip_permission_egress
|
||||
@ip_permission_egress = { 'groups' => [], 'ipRanges' => []}
|
||||
else
|
||||
@response['securityGroupInfo'] << @security_group
|
||||
@security_group = { 'ipPermissions' => [] }
|
||||
@security_group = { 'ipPermissions' => [], 'ipPermissionsEgress' => [] }
|
||||
end
|
||||
when 'requestId'
|
||||
@response[name] = value
|
||||
|
|
Loading…
Add table
Reference in a new issue