fog/fog-azure-rm

View on GitHub
lib/fog/azurerm/models/network/network_security_rule.rb

Summary

Maintainability
A
0 mins
Test Coverage
F
53%
module Fog
  module Network
    class AzureRM
      # Security Rule model for Network Service
      class NetworkSecurityRule < Fog::Model
        identity :name
        attribute :id
        attribute :resource_group
        attribute :network_security_group_name
        attribute :description
        attribute :protocol
        attribute :source_port_range
        attribute :destination_port_range
        attribute :source_address_prefix
        attribute :destination_address_prefix
        attribute :access
        attribute :priority
        attribute :direction

        def self.parse(nsr)
          hash = {}
          hash['id'] = nsr.id
          hash['name'] = nsr.name
          hash['resource_group'] = get_resource_group_from_id(nsr.id)
          hash['network_security_group_name'] = get_resource_from_resource_id(nsr.id, RESOURCE_NAME)
          hash['description'] = nsr.description
          hash['protocol'] = nsr.protocol
          hash['source_port_range'] = nsr.source_port_range
          hash['destination_port_range'] = nsr.destination_port_range
          hash['source_address_prefix'] = nsr.source_address_prefix
          hash['destination_address_prefix'] = nsr.destination_address_prefix
          hash['access'] = nsr.access
          hash['priority'] = nsr.priority
          hash['direction'] = nsr.direction
          hash
        end

        def save
          requires :name, :network_security_group_name, :resource_group, :protocol, :source_port_range, :destination_port_range, :source_address_prefix, :destination_address_prefix, :access, :priority, :direction
          network_security_rule = service.create_or_update_network_security_rule(security_rule_params)
          merge_attributes(Fog::Network::AzureRM::NetworkSecurityRule.parse(network_security_rule))
        end

        def security_rule_params
          {
            name: name,
            resource_group: resource_group,
            protocol: protocol,
            network_security_group_name: network_security_group_name,
            source_port_range: source_port_range,
            destination_port_range: destination_port_range,
            source_address_prefix: source_address_prefix,
            destination_address_prefix: destination_address_prefix,
            access: access,
            priority: priority,
            direction: direction
          }
        end

        def destroy
          service.delete_network_security_rule(resource_group, network_security_group_name, name)
        end
      end
    end
  end
end