class Chef::Knife::IonoscloudFirewallList

Attributes

description[R]
required_options[R]

Public Class Methods

new(args = []) click to toggle source
Calls superclass method
# File lib/chef/knife/ionoscloud_firewall_list.rb, line 27
def initialize(args = [])
  super(args)
  @description =
  'Lists all available firewall rules assigned to a NIC.'
  @required_options = [:datacenter_id, :server_id, :nic_id, :ionoscloud_username, :ionoscloud_password]
end

Public Instance Methods

run() click to toggle source
# File lib/chef/knife/ionoscloud_firewall_list.rb, line 34
def run
  $stdout.sync = true
  handle_extra_config
  validate_required_params(@required_options, config)

  firewall_list = [
    ui.color('ID', :bold),
    ui.color('Name', :bold),
    ui.color('Protocol', :bold),
    ui.color('Source MAC', :bold),
    ui.color('Source IP', :bold),
    ui.color('Target IP', :bold),
    ui.color('Port Range Start', :bold),
    ui.color('Port Range End', :bold),
    ui.color('ICMP Type', :bold),
    ui.color('ICMP CODE', :bold),
  ]

  nic_api = Ionoscloud::NicApi.new(api_client)

  nic_api.datacenters_servers_nics_firewallrules_get(
    config[:datacenter_id], config[:server_id], config[:nic_id], { depth: 1 }
  ).items.each do |firewall|
    firewall_list << firewall.id
    firewall_list << firewall.properties.name
    firewall_list << firewall.properties.protocol.to_s
    firewall_list << firewall.properties.source_mac.to_s
    firewall_list << firewall.properties.source_ip.to_s
    firewall_list << firewall.properties.target_ip.to_s
    firewall_list << firewall.properties.port_range_start.to_s
    firewall_list << firewall.properties.port_range_end.to_s
    firewall_list << firewall.properties.icmp_type.to_s
    firewall_list << firewall.properties.icmp_code.to_s
  end

  puts ui.list(firewall_list, :uneven_columns_across, 10)
end