[System] HttpListenerRequest: ignore bad cookies and keep request alive (#5657)
[mono.git] / mcs / class / System / System.Net / NtlmClient.cs
1 //
2 // System.Net.NtlmClient
3 //
4 // Authors:
5 //      Sebastien Pouliot (spouliot@motus.com)
6 //      Gonzalo Paniagua Javier (gonzalo@ximian.com)
7 //
8 // (C) 2003 Motus Technologies. All rights reserved.
9 // (c) 2003 Novell, Inc. (http://www.novell.com)
10 //
11
12 //
13 // Permission is hereby granted, free of charge, to any person obtaining
14 // a copy of this software and associated documentation files (the
15 // "Software"), to deal in the Software without restriction, including
16 // without limitation the rights to use, copy, modify, merge, publish,
17 // distribute, sublicense, and/or sell copies of the Software, and to
18 // permit persons to whom the Software is furnished to do so, subject to
19 // the following conditions:
20 // 
21 // The above copyright notice and this permission notice shall be
22 // included in all copies or substantial portions of the Software.
23 // 
24 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 //
32
33 using System;
34 using System.Reflection;
35
36 namespace System.Net
37 {
38         class NtlmClient : IAuthenticationModule
39         {
40                 IAuthenticationModule authObject;
41
42                 public NtlmClient ()
43                 {
44 #if SECURITY_DEP
45                         authObject = new Mono.Http.NtlmClient ();
46 #else
47                         authObject = null;
48 #endif
49                 }
50         
51                 public Authorization Authenticate (string challenge, WebRequest webRequest, ICredentials credentials) 
52                 {
53                         if (authObject == null)
54                                 return null;
55
56                         return authObject.Authenticate (challenge, webRequest, credentials);
57                 }
58
59                 public Authorization PreAuthenticate (WebRequest webRequest, ICredentials credentials) 
60                 {
61                         return null;
62                 }
63         
64                 public string AuthenticationType { 
65                         get { return "NTLM"; }
66                 }
67         
68                 public bool CanPreAuthenticate { 
69                         get { return false; }
70                 }
71         }
72 }
73