File: create_ipsec_policy.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 (52 lines) | stat: -rw-r--r-- 1,742 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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
module Fog
  module OpenStack
    class Network
      class Real
        def create_ipsec_policy(options = {})
          data = {
            'ipsecpolicy' => {
            }
          }

          vanilla_options = [:name, :description, :tenant_id,
                             :auth_algorithm, :encryption_algorithm,
                             :pfs, :transform_protocol,
                             :lifetime, :encapsulation_mode]
          vanilla_options.reject { |o| options[o].nil? }.each do |key|
            data['ipsecpolicy'][key] = options[key]
          end

          request(
            :body    => Fog::JSON.encode(data),
            :expects => [201],
            :method  => 'POST',
            :path    => 'vpn/ipsecpolicies'
          )
        end
      end

      class Mock
        def create_ipsec_policy(options = {})
          response = Excon::Response.new
          response.status = 201
          data = {
            'id'                   => Fog::Mock.random_numbers(6).to_s,
            'name'                 => options[:name],
            'description'          => options[:description],
            'tenant_id'            => options[:tenant_id],
            'auth_algorithm'       => options[:auth_algorithm],
            'encryption_algorithm' => options[:encryption_algorithm],
            'pfs'                  => options[:pfs],
            'transform_protocol'   => options[:transform_protocol],
            'lifetime'             => options[:lifetime],
            'encapsulation_mode'   => options[:encapsulation_mode]
          }

          self.data[:ipsec_policies][data['id']] = data
          response.body = {'ipsecpolicy' => data}
          response
        end
      end
    end
  end
end