class Fog::Compute::Cloudstack::SecurityGroupRule

Public Instance Methods

destroy() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 14
def destroy
  data = service.send("revoke_security_group_#{self.direction}", "id" => self.id)
  job = service.jobs.new(data["revokesecuritygroup#{self.direction}"])
  job.wait_for { ready? }
  job.successful?
end
port_range() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 21
def port_range
  (self.start_port..self.end_port)
end
reload() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 40
def reload
  requires :id, :security_group_id, :cidr

  merge_attributes(security_group.rules.get(self.id))
end
save() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 25
def save
  requires :security_group_id, :cidr, :direction

  data = service.send("authorize_security_group_#{self.direction}".to_sym, params)
  job = service.jobs.new(data["authorizesecuritygroup#{self.direction}response"])
  job.wait_for { ready? }
  # durty
  merge_attributes(job.result.send("#{self.direction}_rules").last)
  self
end
security_group() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 36
def security_group
  service.security_groups.get(self.security_group_id)
end

Private Instance Methods

params() click to toggle source
# File lib/fog/cloudstack/models/compute/security_group_rule.rb, line 48
def params
  options = {
    "securitygroupid" => self.security_group_id,
    "protocol"        => self.protocol,
    "cidrlist"        => self.cidr
  }
  options.merge!("startport" => self.start_port) unless self.start_port.nil?
  options.merge("endport" => self.end_port) unless self.end_port.nil?
end