<testcase>
<info>
<keywords>
HTTP
HTTP GET
--proxy-anyauth
HTTP proxy NTLM auth
</keywords>
</info>
# Server-side
<reply>

<data>
HTTP/1.1 407 Authorization Required swsclose

Server: Apache/1.3.27 (Darwin) PHP/4.1.2

Proxy-Authenticate: Blackmagic realm="gimme all yer s3cr3ts"

Proxy-Authenticate: Basic realm="gimme all yer s3cr3ts"

Proxy-Authenticate: NTLM

Content-Type: text/html; charset=iso-8859-1

Connection: close



This is not the real page
</data>

# this is returned first since we get no proxy-auth
<data1001>
HTTP/1.1 407 Authorization Required to proxy me my dear

Proxy-Authenticate: NTLM TlRMTVNTUAACAAAAAgACADAAAAAGgoEAc51AYVDgyNcAAAAAAAAAAG4AbgAyAAAAQ0MCAAQAQwBDAAEAEgBFAEwASQBTAEEAQgBFAFQASAAEABgAYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAwAsAGUAbABpAHMAYQBiAGUAdABoAC4AYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAAAAAA==

Content-Length: 34



Hey you, authenticate or go away!
</data1001>

# This is supposed to be returned when the server gets the second
# Authorization: NTLM line passed-in from the client
<data1002>
HTTP/1.1 200 Things are fine in proxy land swsclose

Server: Microsoft-IIS/5.0

Content-Type: text/html; charset=iso-8859-1

Content-Length: 42



Contents of that page you requested, sir.
</data1002>

<datacheck>
HTTP/1.1 407 Authorization Required swsclose

Server: Apache/1.3.27 (Darwin) PHP/4.1.2

Proxy-Authenticate: Blackmagic realm="gimme all yer s3cr3ts"

Proxy-Authenticate: Basic realm="gimme all yer s3cr3ts"

Proxy-Authenticate: NTLM

Content-Type: text/html; charset=iso-8859-1

Connection: close



HTTP/1.1 407 Authorization Required to proxy me my dear

Proxy-Authenticate: NTLM TlRMTVNTUAACAAAAAgACADAAAAAGgoEAc51AYVDgyNcAAAAAAAAAAG4AbgAyAAAAQ0MCAAQAQwBDAAEAEgBFAEwASQBTAEEAQgBFAFQASAAEABgAYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAwAsAGUAbABpAHMAYQBiAGUAdABoAC4AYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAAAAAA==

Content-Length: 34



HTTP/1.1 200 Things are fine in proxy land swsclose

Server: Microsoft-IIS/5.0

Content-Type: text/html; charset=iso-8859-1

Content-Length: 42



Contents of that page you requested, sir.
</datacheck>
</reply>

# Client-side
<client>
<server>
http
</server>
<features>
NTLM
</features>
 <name>
HTTP POST with --proxy-anyauth, picking NTLM
 </name>
 <command>
http://%HOSTIP:%HTTPPORT/243 --proxy http://%HOSTIP:%HTTPPORT --proxy-user silly:person --proxy-anyauth -d "postit"
</command>
</client>

# Verify data after the test has been "shot"
<verify>
<strip>
^User-Agent: curl/.*
</strip>
# We strip off a large chunk of the type-2 NTLM message since it depends on
# the local host name and thus differs on different machines!
<strippart>
s/^(Proxy-Authorization: NTLM TlRMTVNTUAADAAAAGAAYAEAAAAAYABgAWAAAAAAAAABwAAAABQAFAHAAAAA).*/$1/
</strippart>
<protocol nonewline="yes">
POST http://%HOSTIP:%HTTPPORT/243 HTTP/1.1

User-Agent: curl/7.13.2-CVS (i686-pc-linux-gnu) libcurl/7.13.2-CVS OpenSSL/0.9.7e zlib/1.2.2 libidn/0.5.13

Host: %HOSTIP:%HTTPPORT

Pragma: no-cache

Accept: */*

Proxy-Connection: Keep-Alive

Content-Length: 6

Content-Type: application/x-www-form-urlencoded



postitPOST http://%HOSTIP:%HTTPPORT/243 HTTP/1.1

Proxy-Authorization: NTLM TlRMTVNTUAABAAAABoIIAAAAAAAAAAAAAAAAAAAAAAA=

User-Agent: curl/7.13.2-CVS (i686-pc-linux-gnu) libcurl/7.13.2-CVS OpenSSL/0.9.7e zlib/1.2.2 libidn/0.5.13

Host: %HOSTIP:%HTTPPORT

Pragma: no-cache

Accept: */*

Proxy-Connection: Keep-Alive

Content-Length: 0

Content-Type: application/x-www-form-urlencoded



POST http://%HOSTIP:%HTTPPORT/243 HTTP/1.1

Proxy-Authorization: NTLM TlRMTVNTUAADAAAAGAAYAEAAAAAYABgAWAAAAAAAAABwAAAABQAFAHAAAAA
User-Agent: curl/7.13.2-CVS (i686-pc-linux-gnu) libcurl/7.13.2-CVS OpenSSL/0.9.7e zlib/1.2.2 libidn/0.5.13

Host: %HOSTIP:%HTTPPORT

Pragma: no-cache

Accept: */*

Proxy-Connection: Keep-Alive

Content-Length: 6

Content-Type: application/x-www-form-urlencoded



postit
</protocol>
</verify>
</testcase>
