fog/fog-openstack

View on GitHub
lib/fog/openstack/network/models/security_group_rules.rb

Summary

Maintainability
A
1 hr
Test Coverage
require 'fog/openstack/models/collection'
require 'fog/openstack/network/models/security_group_rule'

module Fog
  module OpenStack
    class Network
      class SecurityGroupRules < Fog::OpenStack::Collection
        attribute :filters

        model Fog::OpenStack::Network::SecurityGroupRule

        def initialize(attributes)
          self.filters ||= {}
          super
        end

        def all(filters_arg = filters)
          filters = filters_arg
          load_response(service.list_security_group_rules(filters), 'security_group_rules')
        end

        def get(sec_group_rule_id)
          if sec_group_rule = service.get_security_group_rule(sec_group_rule_id).body['security_group_rule']
            new(sec_group_rule)
          end
        rescue Fog::OpenStack::Network::NotFound
          nil
        end
      end
    end
  end
end