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