File: get_security_group_rule.rb

package info (click to toggle)
ruby-fog-openstack 1.1.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 11,784 kB
  • sloc: ruby: 47,937; makefile: 5; sh: 4
file content (38 lines) | stat: -rw-r--r-- 1,279 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
module Fog
  module OpenStack
    class Compute
      class Real
        def get_security_group_rule(security_group_rule_id)
          request(
            :expects => [200],
            :method  => 'GET',
            :path    => "os-security-group-rules/#{security_group_rule_id}"
          )
        end
      end

      class Mock
        def get_security_group_rule(security_group_rule_id)
          security_group_rule = nil
          data[:security_groups].find { |_id, sg| security_group_rule = sg["rules"].find { |sgr| sgr["id"].to_s == security_group_rule_id.to_s } }
          response = Excon::Response.new
          if security_group_rule
            response.status = 200
            response.headers = {
              "X-Compute-Request-Id" => "req-63a90344-7c4d-42e2-936c-fd748bced1b3",
              "Content-Type"         => "application/json",
              "Content-Length"       => "167",
              "Date"                 => Date.new
            }
            response.body = {
              "security_group_rule" => security_group_rule
            }
          else
            raise Fog::OpenStack::Compute::NotFound, "Security group rule #{security_group_rule_id} does not exist"
          end
          response
        end
      end
    end
  end
end