2010-06-03 Jb Evain <jbevain@novell.com>
[mcs.git] / class / System.ServiceModel / System.ServiceModel.Security.Tokens / SslSecurityTokenParameters.cs
blob0e70f06eeb88ea8bee46e0cf1f572e0bfd68f326
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.
28 using System.IdentityModel.Selectors;
29 using System.IdentityModel.Tokens;
30 using System.ServiceModel.Security;
32 using ReqType = System.ServiceModel.Security.Tokens.ServiceModelSecurityTokenRequirement;
34 namespace System.ServiceModel.Security.Tokens
36 public class SslSecurityTokenParameters : SecurityTokenParameters
38 public SslSecurityTokenParameters ()
39 : this (false, false)
43 public SslSecurityTokenParameters (bool requireClientCertificate)
44 : this (requireClientCertificate, false)
48 public SslSecurityTokenParameters (bool requireClientCertificate,
49 bool requireCancellation)
51 this.cert = requireClientCertificate;
52 this.cancel = requireCancellation;
55 protected SslSecurityTokenParameters (SslSecurityTokenParameters source)
56 : base (source)
58 cert = source.cert;
59 cancel = source.cancel;
62 bool cert, cancel;
64 public bool RequireClientCertificate {
65 get { return cert; }
66 set { cert = value; }
69 public bool RequireCancellation {
70 get { return cancel; }
71 set { cancel = value; }
74 [MonoTODO]
75 public override string ToString ()
77 return base.ToString ();
80 protected override bool HasAsymmetricKey {
81 get { return false; }
84 protected override bool SupportsClientAuthentication {
85 get { return false; }
88 protected override bool SupportsClientWindowsIdentity {
89 get { return false; }
92 protected override bool SupportsServerAuthentication {
93 get { return true; }
96 protected override SecurityTokenParameters CloneCore ()
98 return new SslSecurityTokenParameters (this);
101 protected override SecurityKeyIdentifierClause CreateKeyIdentifierClause (
102 SecurityToken token, SecurityTokenReferenceStyle referenceStyle)
104 if (token == null)
105 throw new ArgumentNullException ("token");
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);
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;
122 protected override void InitializeSecurityTokenRequirement (SecurityTokenRequirement requirement)
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;