# frozen_string_literal: true module HTTPX module Plugins # # https://gitlab.com/honeyryderchuck/httpx/wikis/Authentication#ntlm-authentication # module NTLMAuth class << self def load_dependencies(_klass) require_relative "authentication/ntlm" end def extra_options(options) options.merge(max_concurrent_requests: 1) end end module OptionsMethods def option_ntlm(value) raise TypeError, ":ntlm must be a #{Authentication::Ntlm}" unless value.is_a?(Authentication::Ntlm) value end end module InstanceMethods def ntlm_authentication(user, password, domain = nil) with(ntlm: Authentication::Ntlm.new(user, password, domain: domain)) end alias_method :ntlm_auth, :ntlm_authentication def send_requests(*requests) requests.flat_map do |request| ntlm = request.options.ntlm if ntlm request.headers["authorization"] = ntlm.negotiate probe_response = wrap { super(request).first } if probe_response.status == 401 && ntlm.can_authenticate?(probe_response.headers["www-authenticate"]) request.transition(:idle) request.headers["authorization"] = ntlm.authenticate(request, probe_response.headers["www-authenticate"]) super(request) else probe_response end else super(request) end end end end end register_plugin :ntlm_authentication, NTLMAuth end end