class Chef::Knife::IonoscloudGroupGet

Attributes

description[R]
required_options[R]

Public Class Methods

new(args = []) click to toggle source
Calls superclass method
# File lib/chef/knife/ionoscloud_group_get.rb, line 17
def initialize(args = [])
  super(args)
  @description =
  'Retrieves detailed information about a specific group. This will also '\
  'retrieve a list of users who are members of the group.'
  @required_options = [:group_id, :ionoscloud_username, :ionoscloud_password]
end

Public Instance Methods

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

  user_management_api = Ionoscloud::UserManagementApi.new(api_client)
  group = user_management_api.um_groups_find_by_id(config[:group_id], { depth: 1 })

  users = group.entities.users.items.map! { |el| el.id }

  puts "#{ui.color('ID', :cyan)}: #{group.id}"
  puts "#{ui.color('Name', :cyan)}: #{group.properties.name}"
  puts "#{ui.color('Create Datacenter', :cyan)}: #{group.properties.create_data_center.to_s}"
  puts "#{ui.color('Create Snapshot', :cyan)}: #{group.properties.create_snapshot.to_s}"
  puts "#{ui.color('Reserve IP', :cyan)}: #{group.properties.reserve_ip.to_s}"
  puts "#{ui.color('Access Activity Log', :cyan)}: #{group.properties.access_activity_log.to_s}"
  puts "#{ui.color('S3 Privilege', :cyan)}: #{group.properties.s3_privilege.to_s}"
  puts "#{ui.color('Create Backup Unit', :cyan)}: #{group.properties.create_backup_unit.to_s}"
  puts "#{ui.color('Users', :cyan)}: #{users.to_s}"
end