Class: ChefZero::Endpoints::SystemRecoveryEndpoint

Inherits:
RestBase
  • Object
show all
Defined in:
lib/chef_zero/endpoints/system_recovery_endpoint.rb

Overview

/system_recovery

Constant Summary

Constants inherited from RestBase

RestBase::DEFAULT_REQUEST_VERSION, RestBase::DEFAULT_RESPONSE_VERSION

Instance Attribute Summary

Attributes inherited from RestBase

#server

Instance Method Summary collapse

Methods inherited from RestBase

#accepts?, #already_json_response, #build_uri, build_uri, #call, #check_api_version, #create_data, #create_data_dir, #data_store, #delete_data, #delete_data_dir, #error, #exists_data?, #exists_data_dir?, #get_data, #get_data_or_else, #hashify_list, #head_request, #initialize, #json_only, #json_response, #list_data, #list_data_or_else, #parse_json, #policy_name_invalid?, #populate_defaults, rfc2396_parser, #set_data, #text_response, #to_json

Constructor Details

This class inherits a constructor from ChefZero::RestBase

Instance Method Details

#post(request) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/chef_zero/endpoints/system_recovery_endpoint.rb', line 8

def post(request)
  request_json = FFI_Yajl::Parser.parse(request.body)
  name = request_json["username"]
  password = request_json["password"]
  user = get_data(request, request.rest_path[0..-2] + ["users", name], :nil)
  unless user
    raise RestErrorResponse.new(403, "Nonexistent user")
  end

  user = FFI_Yajl::Parser.parse(user)
  user = ChefData::DataNormalizer.normalize_user(user, name, [ "username" ], server.options[:osc_compat])
  unless user["recovery_authentication_enabled"]
    raise RestErrorResponse.new(403, "Only users with recovery_authentication_enabled=true may use /system_recovery to log in")
  end
  if user["password"] != password
    raise RestErrorResponse.new(401, "Incorrect password")
  end

  json_response(200, user)
end