Merge branch 'marek'
[mono.git] / mcs / class / System.ServiceModel / System.ServiceModel.Security.Tokens / SslSecurityTokenParameters.cs
1 //
2 // SslSecurityTokenParameters.cs
3 //
4 // Author:
5 //      Atsushi Enomoto <atsushi@ximian.com>
6 //
7 // Copyright (C) 2006 Novell, Inc.  http://www.novell.com
8 //
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
16 // 
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
19 // 
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27 //
28 using System.IdentityModel.Selectors;
29 using System.IdentityModel.Tokens;
30 using System.ServiceModel.Security;
31
32 using ReqType = System.ServiceModel.Security.Tokens.ServiceModelSecurityTokenRequirement;
33
34 namespace System.ServiceModel.Security.Tokens
35 {
36         public class SslSecurityTokenParameters : SecurityTokenParameters
37         {
38                 public SslSecurityTokenParameters ()
39                         : this (false, false)
40                 {
41                 }
42
43                 public SslSecurityTokenParameters (bool requireClientCertificate)
44                         : this (requireClientCertificate, false)
45                 {
46                 }
47
48                 public SslSecurityTokenParameters (bool requireClientCertificate,
49                         bool requireCancellation)
50                 {
51                         this.cert = requireClientCertificate;
52                         this.cancel = requireCancellation;
53                 }
54
55                 protected SslSecurityTokenParameters (SslSecurityTokenParameters source)
56                         : base (source)
57                 {
58                         cert = source.cert;
59                         cancel = source.cancel;
60                 }
61
62                 bool cert, cancel;
63
64                 public bool RequireClientCertificate {
65                         get { return cert; }
66                         set { cert = value; }
67                 }
68
69                 public bool RequireCancellation {
70                         get { return cancel; }
71                         set { cancel = value; }
72                 }
73
74                 [MonoTODO]
75                 public override string ToString ()
76                 {
77                         return base.ToString ();
78                 }
79
80                 protected override bool HasAsymmetricKey {
81                         get { return false; }
82                 }
83
84                 protected override bool SupportsClientAuthentication {
85                         get { return false; } 
86                 }
87
88                 protected override bool SupportsClientWindowsIdentity {
89                         get { return false; } 
90                 }
91
92                 protected override bool SupportsServerAuthentication {
93                         get { return true; } 
94                 }
95
96                 protected override SecurityTokenParameters CloneCore ()
97                 {
98                         return new SslSecurityTokenParameters (this);
99                 }
100
101                 protected override SecurityKeyIdentifierClause CreateKeyIdentifierClause (
102                         SecurityToken token, SecurityTokenReferenceStyle referenceStyle)
103                 {
104                         if (token == null)
105                                 throw new ArgumentNullException ("token");
106
107                         SecurityContextSecurityToken sct = token as SecurityContextSecurityToken;
108                         if (sct == null)
109                                 throw new ArgumentException (String.Format ("Not supported SecurityToken: '{0}'", token));
110                         return referenceStyle == SecurityTokenReferenceStyle.Internal ?
111                                 (SecurityKeyIdentifierClause)
112                                 new LocalIdKeyIdentifierClause (sct.Id) :
113                                 new SecurityContextKeyIdentifierClause (sct.ContextId, sct.KeyGeneration);
114                         /*
115                         GenericXmlSecurityToken x = token as GenericXmlSecurityToken;
116                         if (x == null)
117                                 throw new ArgumentException (String.Format ("Not supported SecurityToken: '{0}'", token));
118                         return referenceStyle == SecurityTokenReferenceStyle.Internal ? x.InternalTokenReference : x.ExternalTokenReference;
119                         */
120                 }
121
122                 protected override void InitializeSecurityTokenRequirement (SecurityTokenRequirement requirement)
123                 {
124                         requirement.TokenType =
125                                 RequireClientCertificate ?
126                                 ServiceModelSecurityTokenTypes.MutualSslnego :
127                                 ServiceModelSecurityTokenTypes.AnonymousSslnego;
128                         requirement.RequireCryptographicToken = true;
129                         requirement.Properties [ReqType.SupportSecurityContextCancellationProperty] = RequireCancellation;
130                         requirement.Properties [ReqType.IssuedSecurityTokenParametersProperty] = this.Clone ();
131                         requirement.KeyType = SecurityKeyType.SymmetricKey;
132                 }
133         }
134 }