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