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/openstack/requests/compute/create_security_group_rule.rb
Erik Michaels-Ober f2bd2404d1 Revert "Updated gem spec to require json rather than multi_json"
This reverts commits: 66638b25d7,
3f0314dbd1, and
18ce4b7eca.

Since google-api-client was added as a dependency in afa9b025e9,
multi_json is a de facto dependency of fog, so this is a needless layer.
If #1034 is still an issue, I'd be happy to ship a version of multi_json
that requires rubygems >= 1.3.5.
2013-05-06 04:05:36 -07:00

59 lines
1.9 KiB
Ruby

module Fog
module Compute
class OpenStack
class Real
def create_security_group_rule(parent_group_id, ip_protocol, from_port, to_port, cidr, group_id=nil)
data = {
'security_group_rule' => {
'parent_group_id' => parent_group_id,
'ip_protocol' => ip_protocol,
'from_port' => from_port,
'to_port' => to_port,
'cidr' => cidr,
'group_id' => group_id
}
}
request(
:expects => 200,
:method => 'POST',
:body => MultiJson.encode(data),
:path => 'os-security-group-rules.json'
)
end
end
class Mock
def create_security_group_rule(parent_group_id, ip_protocol, from_port, to_port, cidr, group_id=nil)
parent_group_id = parent_group_id.to_i
response = Excon::Response.new
response.status = 200
response.headers = {
'X-Compute-Request-Id' => "req-#{Fog::Mock.random_hex(32)}",
'Content-Type' => 'application/json',
'Content-Length' => Fog::Mock.random_numbers(3).to_s,
'Date' => Date.new
}
rule = {
'id' => Fog::Mock.random_numbers(2).to_i,
'from_port' => from_port,
'group' => group_id || {},
'ip_protocol' => ip_protocol,
'to_port' => to_port,
'parent_group_id' => parent_group_id,
'ip_range' => {
'cidr' => cidr
}
}
self.data[:security_groups][parent_group_id]['rules'].push(rule)
response.body = {
'security_group_rule' => rule
}
response
end
end # mock
end # openstack
end # compute
end # fog