24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
# File 'lib/ActiveDocument/mark_logic_http.rb', line 24
def digest_auth(user, password, response)
@@nonce_count += 1
response['www-authenticate'] =~ /^(\w+) (.*)/
params = {}
$2.gsub(/(\w+)="(.*?)"/) { params[$1] = $2 }
a_1 = "#{user}:#{params['realm']}:#{password}"
a_2 = "#{@method}:#{@path}"
request_digest = ''
request_digest << Digest::MD5.new.update(a_1).hexdigest
request_digest << ':' << params['nonce']
request_digest << ':' << ('%08x' % @@nonce_count)
request_digest << ':' << CNONCE
request_digest << ':' << params['qop']
request_digest << ':' << Digest::MD5.new.update(a_2).hexdigest
= []
<< "Digest username=\"#{user}\""
<< "realm=\"#{params['realm']}\""
<< "qop=#{params['qop']}"
<< "algorithm=MD5"
<< "uri=\"#{@path}\""
<< "nonce=\"#{params['nonce']}\""
<< "nc=#{'%08x' % @@nonce_count}"
<< "cnonce=\"#{CNONCE}\""
<< "response=\"#{Digest::MD5.new.update(request_digest).hexdigest}\""
@header['Authorization'] =
end
|