File: 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 (45 lines) | stat: -rw-r--r-- 1,245 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
require 'fog/openstack/models/model'

module Fog
  module OpenStack
    class Network
      class IpsecPolicy < Fog::OpenStack::Model
        identity :id

        attribute :name
        attribute :description
        attribute :status
        attribute :admin_state_up
        attribute :tenant_id
        attribute :auth_algorithm
        attribute :encryption_algorithm
        attribute :pfs
        attribute :transform_protocol
        attribute :encapsulation_mode
        attribute :lifetime

        def create
          requires :name, :auth_algorithm, :encryption_algorithm,
                   :lifetime, :pfs, :transform_protocol,
                   :encapsulation_mode
          merge_attributes(service.create_ipsec_policy(attributes).body['ipsecpolicy'])
          self
        end

        def update
          requires :id, :name, :auth_algorithm, :encryption_algorithm,
                   :lifetime, :pfs, :transform_protocol,
                   :encapsulation_mode
          merge_attributes(service.update_ipsec_policy(id, attributes).body['ipsecpolicy'])
          self
        end

        def destroy
          requires :id
          service.delete_ipsec_policy(id)
          true
        end
      end
    end
  end
end