mirror of
https://github.com/fog/fog-aws.git
synced 2022-11-09 13:50:52 -05:00
60 lines
2.1 KiB
Ruby
60 lines
2.1 KiB
Ruby
module Fog
|
|
module Compute
|
|
class AWS
|
|
class Real
|
|
require 'fog/aws/parsers/compute/create_security_group'
|
|
|
|
# Create a new security group
|
|
#
|
|
# ==== Parameters
|
|
# * group_name<~String> - Name of the security group.
|
|
# * group_description<~String> - Description of group.
|
|
# * vpc_id<~String> - ID of the VPC
|
|
#
|
|
# ==== Returns
|
|
# * response<~Excon::Response>:
|
|
# * body<~Hash>:
|
|
# * 'requestId'<~String> - Id of request
|
|
# * 'return'<~Boolean> - success?
|
|
# * 'groupId'<~String> - Id of created group
|
|
#
|
|
# {Amazon API Reference}[http://docs.amazonwebservices.com/AWSEC2/latest/APIReference/ApiReference-query-CreateSecurityGroup.html]
|
|
def create_security_group(name, description, vpc_id=nil)
|
|
request(
|
|
'Action' => 'CreateSecurityGroup',
|
|
'GroupName' => name,
|
|
'GroupDescription' => description,
|
|
'VpcId' => vpc_id,
|
|
:parser => Fog::Parsers::Compute::AWS::CreateSecurityGroup.new
|
|
)
|
|
end
|
|
end
|
|
|
|
class Mock
|
|
def create_security_group(name, description, vpc_id=nil)
|
|
response = Excon::Response.new
|
|
unless self.data[:security_groups][name]
|
|
data = {
|
|
'groupDescription' => description,
|
|
'groupName' => name,
|
|
'groupId' => Fog::AWS::Mock.security_group_id,
|
|
'ipPermissionsEgress' => [],
|
|
'ipPermissions' => [],
|
|
'ownerId' => self.data[:owner_id],
|
|
'vpcId' => vpc_id
|
|
}
|
|
self.data[:security_groups][name] = data
|
|
response.body = {
|
|
'requestId' => Fog::AWS::Mock.request_id,
|
|
'groupId' => data['groupId'],
|
|
'return' => true
|
|
}
|
|
response
|
|
else
|
|
raise Fog::Compute::AWS::Error.new("InvalidGroup.Duplicate => The security group '#{name}' already exists")
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|