require "ffi_yajl" require_relative "../rest_base" module ChefZero module Endpoints # /authenticate_user class AuthenticateUserEndpoint < RestBase def post(request) request_json = FFI_Yajl::Parser.parse(request.body) name = request_json["username"] password = request_json["password"] begin user = data_store.get(["users", name]) rescue ChefZero::DataStore::DataNotFoundError raise RestErrorResponse.new(401, "Bad username or password") end user = FFI_Yajl::Parser.parse(user) user = ChefData::DataNormalizer.normalize_user(user, name, [ "username" ], server.options[:osc_compat]) if user["password"] != password raise RestErrorResponse.new(401, "Bad username or password") end # Include only particular user data in the response user.keep_if { |key, value| %w{first_name last_name display_name email username}.include?(key) } json_response(200, { "status" => "linked", "user" => user, }) end end end end