2 // HttpTransportSecurityElement.cs
5 // Atsushi Enomoto <atsushi@ximian.com>
7 // Copyright (C) 2006 Novell, Inc. http://www.novell.com
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:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
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.
30 using System.Collections;
31 using System.Collections.Generic;
32 using System.Collections.ObjectModel;
33 using System.ComponentModel;
34 using System.Configuration;
36 using System.Net.Security;
37 using System.Reflection;
38 using System.Security.Authentication.ExtendedProtection;
39 using System.Security.Authentication.ExtendedProtection.Configuration;
40 using System.Security.Cryptography.X509Certificates;
41 using System.Security.Principal;
42 using System.IdentityModel.Claims;
43 using System.IdentityModel.Policy;
44 using System.IdentityModel.Tokens;
45 using System.ServiceModel;
46 using System.ServiceModel.Channels;
47 using System.ServiceModel.Description;
48 using System.ServiceModel.Diagnostics;
49 using System.ServiceModel.Dispatcher;
50 using System.ServiceModel.MsmqIntegration;
51 using System.ServiceModel.PeerResolvers;
52 using System.ServiceModel.Security;
53 using System.Runtime.Serialization;
57 namespace System.ServiceModel.Configuration
60 public sealed partial class HttpTransportSecurityElement
61 : ConfigurationElement
64 static ConfigurationPropertyCollection properties;
65 static ConfigurationProperty client_credential_type;
66 static ConfigurationProperty proxy_credential_type;
67 static ConfigurationProperty realm;
68 static ConfigurationProperty extended_protection_policy;
70 static HttpTransportSecurityElement ()
72 properties = new ConfigurationPropertyCollection ();
73 client_credential_type = new ConfigurationProperty ("clientCredentialType",
74 typeof (HttpClientCredentialType), "None", null/* FIXME: get converter for HttpClientCredentialType*/, null,
75 ConfigurationPropertyOptions.None);
77 proxy_credential_type = new ConfigurationProperty ("proxyCredentialType",
78 typeof (HttpProxyCredentialType), "None", null/* FIXME: get converter for HttpProxyCredentialType*/, null,
79 ConfigurationPropertyOptions.None);
81 realm = new ConfigurationProperty ("realm",
82 typeof (string), "", new StringConverter (), null,
83 ConfigurationPropertyOptions.None);
85 extended_protection_policy = new ConfigurationProperty ("extendedProtectionPolicy",
86 typeof (ExtendedProtectionPolicyElement), null, new ExtendedProtectionPolicyTypeConverter (), null,
87 ConfigurationPropertyOptions.None);
89 properties.Add (client_credential_type);
90 properties.Add (proxy_credential_type);
91 properties.Add (realm);
92 properties.Add (extended_protection_policy);
95 public HttpTransportSecurityElement ()
102 [ConfigurationProperty ("clientCredentialType",
103 Options = ConfigurationPropertyOptions.None,
104 DefaultValue = HttpClientCredentialType.None)]
105 public HttpClientCredentialType ClientCredentialType {
106 get { return (HttpClientCredentialType) base [client_credential_type]; }
107 set { base [client_credential_type] = value; }
110 [ConfigurationProperty ("extendedProtectionPolicy",
111 Options = ConfigurationPropertyOptions.None)]
112 public ExtendedProtectionPolicyElement extendedProtectionPolicy {
113 get { return (ExtendedProtectionPolicyElement) base [extended_protection_policy]; }
114 set { base [extended_protection_policy] = value; }
117 protected override ConfigurationPropertyCollection Properties {
118 get { return properties; }
121 [ConfigurationProperty ("proxyCredentialType",
122 Options = ConfigurationPropertyOptions.None,
123 DefaultValue = HttpProxyCredentialType.None)]
124 public HttpProxyCredentialType ProxyCredentialType {
125 get { return (HttpProxyCredentialType) base [proxy_credential_type]; }
126 set { base [proxy_credential_type] = value; }
129 [ConfigurationProperty ("realm",
130 Options = ConfigurationPropertyOptions.None,
132 [StringValidator ( MinLength = 0,
133 MaxLength = int.MaxValue,
134 InvalidCharacters = null)]
135 public string Realm {
136 get { return (string) base [realm]; }
137 set { base [realm] = value; }
140 internal void ApplyConfiguration (HttpTransportSecurity security)
142 security.ClientCredentialType = ClientCredentialType;
143 security.ProxyCredentialType = ProxyCredentialType;
144 security.Realm = Realm;
145 // FIXME: enable this
146 // security.ExtendedProtectionPolicy = ExtendedProtectionPolicy.BuildPolicy ();