class Chef::Knife::UserCreate
Attributes
user_field[RW]
Public Instance Methods
create_user_from_hash(hash)
click to toggle source
# File lib/chef/knife/user_create.rb, line 67 def create_user_from_hash(hash) Chef::UserV1.from_hash(hash).create end
osc_11_warning()
click to toggle source
# File lib/chef/knife/user_create.rb, line 71 def osc_11_warning <<-EOF IF YOU ARE USING CHEF SERVER 12+, PLEASE FOLLOW THE INSTRUCTIONS UNDER knife user create --help. You only passed a single argument to knife user create. For backwards compatibility, when only a single argument is passed, knife user create assumes you want Open Source 11 Server user creation. knife user create for Open Source 11 Server is being deprecated. Open Source 11 Server user commands now live under the knife osc_user namespace. For backwards compatibility, we will forward this request to knife osc_user create. If you are using an Open Source 11 Server, please use that command to avoid this warning. NOTE: Backwards compatibility for Open Source 11 Server in these commands will be removed in Chef 15 which will be released April 2019. EOF end
run()
click to toggle source
# File lib/chef/knife/user_create.rb, line 93 def run # DEPRECATION NOTE # Remove this if statement and corrosponding code post OSC 11 support. # # If only 1 arg is passed, assume OSC 11 case. if @name_args.length == 1 ui.warn(osc_11_warning) run_osc_11_user_create else # EC / CS 12 user create test_mandatory_field(@name_args[0], "username") user.username @name_args[0] test_mandatory_field(@name_args[1], "display name") user.display_name @name_args[1] test_mandatory_field(@name_args[2], "first name") user.first_name @name_args[2] test_mandatory_field(@name_args[3], "last name") user.last_name @name_args[3] test_mandatory_field(@name_args[4], "email") user.email @name_args[4] test_mandatory_field(@name_args[5], "password") user.password @name_args[5] if config[:user_key] && config[:prevent_keygen] show_usage ui.fatal("You cannot pass --user-key and --prevent-keygen") exit 1 end if !config[:prevent_keygen] && !config[:user_key] user.create_key(true) end if config[:user_key] user.public_key File.read(File.expand_path(config[:user_key])) end output = edit_hash(user) final_user = create_user_from_hash(output) ui.info("Created #{user}") if final_user.private_key if config[:file] File.open(config[:file], "w") do |f| f.print(final_user.private_key) end else ui.msg final_user.private_key end end end end
run_osc_11_user_create()
click to toggle source
# File lib/chef/knife/user_create.rb, line 86 def run_osc_11_user_create # run osc_user_create with our input ARGV.delete("user") ARGV.unshift("osc_user") Chef::Knife.run(ARGV, Chef::Application::Knife.options) end
user()
click to toggle source
# File lib/chef/knife/user_create.rb, line 63 def user @user_field ||= Chef::UserV1.new end