Merge branch 'atsushi'
[mono.git] / mcs / class / System.ServiceModel / System.ServiceModel.Configuration / IssuedTokenServiceElement.cs
1 //
2 // IssuedTokenServiceElement.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
29 using System;
30 using System.Collections;
31 using System.Collections.Generic;
32 using System.Collections.ObjectModel;
33 using System.ComponentModel;
34 using System.Configuration;
35 using System.Net;
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;
52 using System.Text;
53 using System.Xml;
54 using System.IdentityModel.Selectors;
55
56 namespace System.ServiceModel.Configuration
57 {
58         public sealed class IssuedTokenServiceElement
59                  : ConfigurationElement
60         {
61                 public IssuedTokenServiceElement () {
62                 }
63
64
65                 // Properties
66
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; }
73                 }
74
75                 [ConfigurationProperty ("knownCertificates",
76                          Options = ConfigurationPropertyOptions.None)]
77                 public X509CertificateTrustedIssuerElementCollection KnownCertificates {
78                         get { return (X509CertificateTrustedIssuerElementCollection) base ["knownCertificates"]; }
79                 }
80
81                 protected override ConfigurationPropertyCollection Properties {
82                         get { return base.Properties; }
83                 }
84
85                 [ConfigurationProperty ("samlSerializerType",
86                          Options = ConfigurationPropertyOptions.None,
87                          DefaultValue = "")]
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; }
94                 }
95
96                 [ConfigurationProperty ("allowedAudienceUris")]
97                 public AllowedAudienceUriElementCollection AllowedAudienceUris {
98                         get { return (AllowedAudienceUriElementCollection) base ["allowedAudienceUris"]; }
99                 }
100
101                 [ConfigurationPropertyAttribute ("audienceUriMode",
102                         DefaultValue = AudienceUriMode.BearerKeyOnly)]
103                 public AudienceUriMode AudienceUriMode {
104                         get { return (AudienceUriMode) this ["audienceUriMode"]; }
105                         set { this ["audienceUriMode"] = value; }
106                 }
107
108                 [ConfigurationPropertyAttribute ("certificateValidationMode",
109                         DefaultValue = X509CertificateValidationMode.ChainTrust)]
110                 public X509CertificateValidationMode CertificateValidationMode {
111                         get { return (X509CertificateValidationMode) this ["certificateValidationMode"]; }
112                         set { this ["certificateValidationMode"] = value; }
113                 }
114
115                 [StringValidatorAttribute (MinLength = 0)]
116                 [ConfigurationPropertyAttribute ("customCertificateValidatorType",
117                         DefaultValue = "")]
118                 public string CustomCertificateValidatorType {
119                         get { return (string) this ["customCertificateValidatorType"]; }
120                         set { this ["customCertificateValidatorType"] = value; }
121                 }
122
123                 [ConfigurationPropertyAttribute ("revocationMode", 
124                         DefaultValue = X509RevocationMode.Online)]
125                 public X509RevocationMode RevocationMode {
126                         get { return (X509RevocationMode) this ["revocationMode"]; }
127                         set { this ["revocationMode"] = value; }
128                 }
129
130                 [ConfigurationPropertyAttribute ("trustedStoreLocation", 
131                         DefaultValue = StoreLocation.LocalMachine)]
132                 public StoreLocation TrustedStoreLocation {
133                         get { return (StoreLocation) this ["trustedStoreLocation"]; }
134                         set { this ["trustedStoreLocation"] = value; }
135                 }
136         }
137
138 }