mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
02ff3171ee
Added security_groups collection and security_group model to Fog::AWS::RDS Added API methods: Fog::AWS::RDS#describe_db_security_groups Fog::AWS::RDS#create_db_security_group Fog::AWS::RDS#delete_db_security_group Fog::AWS::RDS#authorize_db_security_group_ingress Fog::AWS::RDS#revoke_db_security_group_ingress
39 lines
1.1 KiB
Ruby
39 lines
1.1 KiB
Ruby
module Fog
|
|
module Parsers
|
|
module AWS
|
|
module RDS
|
|
|
|
class SecurityGroupParser < Fog::Parsers::Base
|
|
|
|
def reset
|
|
@security_group = fresh_security_group
|
|
end
|
|
|
|
def fresh_security_group
|
|
{'EC2SecurityGroups' => [], 'IPRanges' => []}
|
|
end
|
|
|
|
def start_element(name, attrs = [])
|
|
super
|
|
case name
|
|
when 'EC2SecurityGroup', 'IPRange'; then @ingress = {}
|
|
end
|
|
|
|
end
|
|
|
|
def end_element(name)
|
|
case name
|
|
when 'DBSecurityGroupDescription' then @security_group['DBSecurityGroupDescription'] = @value
|
|
when 'DBSecurityGroupName' then @security_group['DBSecurityGroupName'] = @value
|
|
when 'OwnerId' then @security_group['OwnerId'] = @value
|
|
when 'EC2SecurityGroup', 'IPRange'
|
|
@security_group["#{name}s"] << @ingress unless @ingress.empty?
|
|
when 'EC2SecurityGroupName', 'EC2SecurityGroupOwnerId', 'CIDRIP', 'Status'
|
|
@ingress[name] = @value
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|