[Microsoft.Build] Fix expected output newline from ProcessWrapper.OutputStreamChanged...
[mono.git] / mcs / class / Mainsoft.Web / Mainsoft.Web.Security / ServletAuthenticationModule.cs
1 //
2 // System.Web.Security.ServletAuthenticationModule
3 //
4
5 //
6 // Permission is hereby granted, free of charge, to any person obtaining
7 // a copy of this software and associated documentation files (the
8 // "Software"), to deal in the Software without restriction, including
9 // without limitation the rights to use, copy, modify, merge, publish,
10 // distribute, sublicense, and/or sell copies of the Software, and to
11 // permit persons to whom the Software is furnished to do so, subject to
12 // the following conditions:
13 // 
14 // The above copyright notice and this permission notice shall be
15 // included in all copies or substantial portions of the Software.
16 // 
17 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
21 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
22 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
23 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24 //
25
26 using System;
27 using System.Security.Principal;
28 using System.Text;
29 using System.Web;
30 using System.Web.Configuration;
31 using System.Web.Util;
32 using javax.servlet;
33 using javax.servlet.http;
34 using Mainsoft.Web.Hosting;
35
36 namespace Mainsoft.Web.Security
37 {
38         /// <summary>
39         /// <para>This class supports the Framework infrastructure and is not intended to be used directly from your code.</para>
40         /// <para>Sets the identity of the user for an ASP.NET Java EE application.</para>
41         /// </summary>
42         public sealed class SevletAuthenticationModule : IHttpModule
43         {
44                 public void Dispose () {
45                 }
46
47                 public void Init (HttpApplication app) {
48                         app.AuthenticateRequest += new EventHandler (OnAuthenticateRequest);
49                 }
50
51                 void OnAuthenticateRequest (object sender, EventArgs args) {
52                         HttpApplication app = (HttpApplication) sender;
53                         BaseWorkerRequest req = J2EEUtils.GetWorkerRequest (app.Context);
54                         if (req.GetRemoteUser () != null)
55                                 app.Context.User = new ServletPrincipal (req);
56                 }
57         }
58
59         public sealed class ServletPrincipal : IPrincipal
60         {
61                 readonly BaseWorkerRequest _request;
62                 readonly IIdentity _identity;
63
64                 internal ServletPrincipal (BaseWorkerRequest req) {
65                         _request = req;
66                         string authType = req.GetAuthType ();
67                         if (authType == null)
68                                 authType = String.Empty;
69                         _identity = new GenericIdentity (req.GetRemoteUser (), authType);
70                 }
71
72                 public bool IsInRole (string role) {
73                         return _request.IsUserInRole (role);
74                 }
75
76                 public IIdentity Identity { get { return _identity; } }
77
78                 public java.security.Principal Principal { get { return _request.GetUserPrincipal (); } }
79         }
80 }
81