summaryrefslogtreecommitdiff
path: root/lib/chef_zero/endpoints/system_recovery_endpoint.rb
blob: a3c62fab4566f7d47b5f3190284263b4d5f2ebd7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
require 'json'
require 'chef_zero/rest_base'

module ChefZero
  module Endpoints
    # /system_recovery
    class SystemRecoveryEndpoint < RestBase
      def post(request)
        request_json = JSON.parse(request.body, :create_additions => false)
        name = request_json['username']
        password = request_json['password']
        user = get_data(request, request.rest_path[0..-2] + ['users', name], :nil)
        if !user
          raise RestErrorResponse.new(403, "Nonexistent user")
        end

        user = JSON.parse(user, :create_additions => false)
        user = ChefData::DataNormalizer.normalize_user(user, name, [ 'username' ], server.options[:osc_compat])
        if !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
    end
  end
end