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