File: update_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 (51 lines) | stat: -rw-r--r-- 1,989 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
module Fog
  module OpenStack
    class Network
      class Real
        def update_ipsec_policy(ipsec_policy_id, options = {})
          data = {'ipsecpolicy' => {}}

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

          request(
            :body    => Fog::JSON.encode(data),
            :expects => 200,
            :method  => 'PUT',
            :path    => "vpn/ipsecpolicies/#{ipsec_policy_id}"
          )
        end
      end

      class Mock
        def update_ipsec_policy(ipsec_policy_id, options = {})
          response = Excon::Response.new
          ipsec_policy = list_ipsec_policies.body['ipsecpolicies'].detect do |instance|
            instance['id'] == ipsec_policy_id
          end
          if ipsec_policy
            ipsec_policy['name']                 = options[:name]
            ipsec_policy['description']          = options[:description]
            ipsec_policy['tenant_id']            = options[:tenant_id]
            ipsec_policy['auth_algorithm']       = options[:auth_algorithm]
            ipsec_policy['encryption_algorithm'] = options[:encryption_algorithm]
            ipsec_policy['pfs']                  = options[:pfs]
            ipsec_policy['transform_protocol']   = options[:transform_protocol]
            ipsec_policy['encapsulation_mode']   = options[:encapsulation_mode]
            ipsec_policy['lifetime']             = options[:lifetime]
            response.body = {'ipsecpolicy' => ipsec_policy}
            response.status = 200
            response
          else
            raise Fog::OpenStack::Network::NotFound
          end
        end
      end
    end
  end
end