1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/lib/fog/aws/models/compute/security_group.rb

78 lines
2 KiB
Ruby
Raw Normal View History

2010-03-16 18:46:21 -04:00
require 'fog/model'
2009-09-18 11:56:42 -04:00
module Fog
module AWS
2010-09-08 17:40:02 -04:00
class Compute
2009-09-18 11:56:42 -04:00
class SecurityGroup < Fog::Model
identity :name, :aliases => 'groupName'
attribute :description, :aliases => 'groupDescription'
attribute :ip_permissions, :aliases => 'ipPermissions'
attribute :owner_id, :aliases => 'ownerId'
2009-09-18 11:56:42 -04:00
def authorize_group_and_owner(group, owner)
requires :name
connection.authorize_security_group_ingress(
'GroupName' => @name,
'SourceSecurityGroupName' => group,
'SourceSecurityGroupOwnerId' => owner
)
end
def authorize_port_range(range, options = {})
requires :name
connection.authorize_security_group_ingress(
'CidrIp' => options[:cidr_ip] || '0.0.0.0/0',
'FromPort' => range.min,
'GroupName' => @name,
'ToPort' => range.max,
'IpProtocol' => options[:ip_protocol] || 'tcp'
)
end
2009-09-20 12:21:03 -04:00
def destroy
requires :name
connection.delete_security_group(@name)
2009-09-18 11:56:42 -04:00
true
end
def revoke_group_and_owner(group, owner)
requires :name
connection.revoke_security_group_ingress(
'GroupName' => @name,
'SourceSecurityGroupName' => group,
'SourceSecurityGroupOwnerId' => owner
)
end
def revoke_port_range(range, options = {})
requires :name
connection.revoke_security_group_ingress(
'CidrIp' => options[:cidr_ip] || '0.0.0.0/0',
'FromPort' => range.min,
'GroupName' => @name,
'ToPort' => range.max,
'IpProtocol' => options[:ip_protocol] || 'tcp'
)
end
2009-09-18 11:56:42 -04:00
def save
requires :description, :name
data = connection.create_security_group(@name, @description).body
2009-09-18 11:56:42 -04:00
true
end
end
end
end
end