2 // IssuedTokenServiceElement.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.Cryptography.X509Certificates;
39 using System.Security.Principal;
40 using System.IdentityModel.Claims;
41 using System.IdentityModel.Policy;
42 using System.IdentityModel.Tokens;
43 using System.ServiceModel;
44 using System.ServiceModel.Channels;
45 using System.ServiceModel.Description;
46 using System.ServiceModel.Diagnostics;
47 using System.ServiceModel.Dispatcher;
48 using System.ServiceModel.MsmqIntegration;
49 using System.ServiceModel.PeerResolvers;
50 using System.ServiceModel.Security;
51 using System.Runtime.Serialization;
54 using System.IdentityModel.Selectors;
56 namespace System.ServiceModel.Configuration
58 public sealed class IssuedTokenServiceElement
59 : ConfigurationElement
61 public IssuedTokenServiceElement () {
67 [ConfigurationProperty ("allowUntrustedRsaIssuers",
68 Options = ConfigurationPropertyOptions.None,
69 DefaultValue = false)]
70 public bool AllowUntrustedRsaIssuers {
71 get { return (bool) base ["allowUntrustedRsaIssuers"]; }
72 set { base ["allowUntrustedRsaIssuers"] = value; }
75 [ConfigurationProperty ("knownCertificates",
76 Options = ConfigurationPropertyOptions.None)]
77 public X509CertificateTrustedIssuerElementCollection KnownCertificates {
78 get { return (X509CertificateTrustedIssuerElementCollection) base ["knownCertificates"]; }
81 protected override ConfigurationPropertyCollection Properties {
82 get { return base.Properties; }
85 [ConfigurationProperty ("samlSerializerType",
86 Options = ConfigurationPropertyOptions.None,
88 [StringValidator (MinLength = 0,
89 MaxLength = int.MaxValue,
90 InvalidCharacters = null)]
91 public string SamlSerializerType {
92 get { return (string) base ["samlSerializerType"]; }
93 set { base ["samlSerializerType"] = value; }
96 [ConfigurationProperty ("allowedAudienceUris")]
97 public AllowedAudienceUriElementCollection AllowedAudienceUris {
98 get { return (AllowedAudienceUriElementCollection) base ["allowedAudienceUris"]; }
101 [ConfigurationPropertyAttribute ("audienceUriMode",
102 DefaultValue = AudienceUriMode.BearerKeyOnly)]
103 public AudienceUriMode AudienceUriMode {
104 get { return (AudienceUriMode) this ["audienceUriMode"]; }
105 set { this ["audienceUriMode"] = value; }
108 [ConfigurationPropertyAttribute ("certificateValidationMode",
109 DefaultValue = X509CertificateValidationMode.ChainTrust)]
110 public X509CertificateValidationMode CertificateValidationMode {
111 get { return (X509CertificateValidationMode) this ["certificateValidationMode"]; }
112 set { this ["certificateValidationMode"] = value; }
115 [StringValidatorAttribute (MinLength = 0)]
116 [ConfigurationPropertyAttribute ("customCertificateValidatorType",
118 public string CustomCertificateValidatorType {
119 get { return (string) this ["customCertificateValidatorType"]; }
120 set { this ["customCertificateValidatorType"] = value; }
123 [ConfigurationPropertyAttribute ("revocationMode",
124 DefaultValue = X509RevocationMode.Online)]
125 public X509RevocationMode RevocationMode {
126 get { return (X509RevocationMode) this ["revocationMode"]; }
127 set { this ["revocationMode"] = value; }
130 [ConfigurationPropertyAttribute ("trustedStoreLocation",
131 DefaultValue = StoreLocation.LocalMachine)]
132 public StoreLocation TrustedStoreLocation {
133 get { return (StoreLocation) this ["trustedStoreLocation"]; }
134 set { this ["trustedStoreLocation"] = value; }