a575963da9
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
300 lines
11 KiB
C#
300 lines
11 KiB
C#
//
|
|
// LocalServiceSecuritySettingsElement.cs
|
|
//
|
|
// Author:
|
|
// Atsushi Enomoto <atsushi@ximian.com>
|
|
//
|
|
// Copyright (C) 2006 Novell, Inc. http://www.novell.com
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining
|
|
// a copy of this software and associated documentation files (the
|
|
// "Software"), to deal in the Software without restriction, including
|
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
|
// permit persons to whom the Software is furnished to do so, subject to
|
|
// the following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be
|
|
// included in all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
//
|
|
|
|
using System;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.ComponentModel;
|
|
using System.Configuration;
|
|
using System.Net;
|
|
using System.Net.Security;
|
|
using System.Reflection;
|
|
using System.Security.Cryptography.X509Certificates;
|
|
using System.Security.Principal;
|
|
using System.IdentityModel.Claims;
|
|
using System.IdentityModel.Policy;
|
|
using System.IdentityModel.Tokens;
|
|
using System.ServiceModel;
|
|
using System.ServiceModel.Channels;
|
|
using System.ServiceModel.Description;
|
|
using System.ServiceModel.Diagnostics;
|
|
using System.ServiceModel.Dispatcher;
|
|
using System.ServiceModel.MsmqIntegration;
|
|
using System.ServiceModel.PeerResolvers;
|
|
using System.ServiceModel.Security;
|
|
using System.Runtime.Serialization;
|
|
using System.Text;
|
|
using System.Xml;
|
|
|
|
namespace System.ServiceModel.Configuration
|
|
{
|
|
[MonoTODO]
|
|
public sealed partial class LocalServiceSecuritySettingsElement
|
|
: ConfigurationElement
|
|
{
|
|
// Static Fields
|
|
static ConfigurationPropertyCollection properties;
|
|
static ConfigurationProperty detect_replays;
|
|
static ConfigurationProperty inactivity_timeout;
|
|
static ConfigurationProperty issued_cookie_lifetime;
|
|
static ConfigurationProperty max_cached_cookies;
|
|
static ConfigurationProperty max_clock_skew;
|
|
static ConfigurationProperty max_pending_sessions;
|
|
static ConfigurationProperty max_stateful_negotiations;
|
|
static ConfigurationProperty negotiation_timeout;
|
|
static ConfigurationProperty reconnect_transport_on_failure;
|
|
static ConfigurationProperty replay_cache_size;
|
|
static ConfigurationProperty replay_window;
|
|
static ConfigurationProperty session_key_renewal_interval;
|
|
static ConfigurationProperty session_key_rollover_interval;
|
|
static ConfigurationProperty timestamp_validity_duration;
|
|
|
|
static LocalServiceSecuritySettingsElement ()
|
|
{
|
|
properties = new ConfigurationPropertyCollection ();
|
|
detect_replays = new ConfigurationProperty ("detectReplays",
|
|
typeof (bool), "true", new BooleanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
inactivity_timeout = new ConfigurationProperty ("inactivityTimeout",
|
|
typeof (TimeSpan), "00:02:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
issued_cookie_lifetime = new ConfigurationProperty ("issuedCookieLifetime",
|
|
typeof (TimeSpan), "10:00:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
max_cached_cookies = new ConfigurationProperty ("maxCachedCookies",
|
|
typeof (int), "1000", null/* FIXME: get converter for int*/, null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
max_clock_skew = new ConfigurationProperty ("maxClockSkew",
|
|
typeof (TimeSpan), "00:05:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
max_pending_sessions = new ConfigurationProperty ("maxPendingSessions",
|
|
typeof (int), "128", null/* FIXME: get converter for int*/, null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
max_stateful_negotiations = new ConfigurationProperty ("maxStatefulNegotiations",
|
|
typeof (int), "128", null/* FIXME: get converter for int*/, null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
negotiation_timeout = new ConfigurationProperty ("negotiationTimeout",
|
|
typeof (TimeSpan), "00:01:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
reconnect_transport_on_failure = new ConfigurationProperty ("reconnectTransportOnFailure",
|
|
typeof (bool), "true", new BooleanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
replay_cache_size = new ConfigurationProperty ("replayCacheSize",
|
|
typeof (int), "900000", null/* FIXME: get converter for int*/, null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
replay_window = new ConfigurationProperty ("replayWindow",
|
|
typeof (TimeSpan), "00:05:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
session_key_renewal_interval = new ConfigurationProperty ("sessionKeyRenewalInterval",
|
|
typeof (TimeSpan), "15:00:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
session_key_rollover_interval = new ConfigurationProperty ("sessionKeyRolloverInterval",
|
|
typeof (TimeSpan), "00:05:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
timestamp_validity_duration = new ConfigurationProperty ("timestampValidityDuration",
|
|
typeof (TimeSpan), "00:05:00", new TimeSpanConverter (), null,
|
|
ConfigurationPropertyOptions.None);
|
|
|
|
properties.Add (detect_replays);
|
|
properties.Add (inactivity_timeout);
|
|
properties.Add (issued_cookie_lifetime);
|
|
properties.Add (max_cached_cookies);
|
|
properties.Add (max_clock_skew);
|
|
properties.Add (max_pending_sessions);
|
|
properties.Add (max_stateful_negotiations);
|
|
properties.Add (negotiation_timeout);
|
|
properties.Add (reconnect_transport_on_failure);
|
|
properties.Add (replay_cache_size);
|
|
properties.Add (replay_window);
|
|
properties.Add (session_key_renewal_interval);
|
|
properties.Add (session_key_rollover_interval);
|
|
properties.Add (timestamp_validity_duration);
|
|
}
|
|
|
|
public LocalServiceSecuritySettingsElement ()
|
|
{
|
|
}
|
|
|
|
|
|
// Properties
|
|
|
|
[ConfigurationProperty ("detectReplays",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = true)]
|
|
public bool DetectReplays {
|
|
get { return (bool) base [detect_replays]; }
|
|
set { base [detect_replays] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("inactivityTimeout",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:02:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan InactivityTimeout {
|
|
get { return (TimeSpan) base [inactivity_timeout]; }
|
|
set { base [inactivity_timeout] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("issuedCookieLifetime",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "10:00:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan IssuedCookieLifetime {
|
|
get { return (TimeSpan) base [issued_cookie_lifetime]; }
|
|
set { base [issued_cookie_lifetime] = value; }
|
|
}
|
|
|
|
[IntegerValidator ( MinValue = 0,
|
|
MaxValue = int.MaxValue,
|
|
ExcludeRange = false)]
|
|
[ConfigurationProperty ("maxCachedCookies",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "1000")]
|
|
public int MaxCachedCookies {
|
|
get { return (int) base [max_cached_cookies]; }
|
|
set { base [max_cached_cookies] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("maxClockSkew",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:05:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan MaxClockSkew {
|
|
get { return (TimeSpan) base [max_clock_skew]; }
|
|
set { base [max_clock_skew] = value; }
|
|
}
|
|
|
|
[IntegerValidator ( MinValue = 1,
|
|
MaxValue = int.MaxValue,
|
|
ExcludeRange = false)]
|
|
[ConfigurationProperty ("maxPendingSessions",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "128")]
|
|
public int MaxPendingSessions {
|
|
get { return (int) base [max_pending_sessions]; }
|
|
set { base [max_pending_sessions] = value; }
|
|
}
|
|
|
|
[IntegerValidator ( MinValue = 0,
|
|
MaxValue = int.MaxValue,
|
|
ExcludeRange = false)]
|
|
[ConfigurationProperty ("maxStatefulNegotiations",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "128")]
|
|
public int MaxStatefulNegotiations {
|
|
get { return (int) base [max_stateful_negotiations]; }
|
|
set { base [max_stateful_negotiations] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("negotiationTimeout",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:01:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan NegotiationTimeout {
|
|
get { return (TimeSpan) base [negotiation_timeout]; }
|
|
set { base [negotiation_timeout] = value; }
|
|
}
|
|
|
|
protected override ConfigurationPropertyCollection Properties {
|
|
get { return properties; }
|
|
}
|
|
|
|
[ConfigurationProperty ("reconnectTransportOnFailure",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = true)]
|
|
public bool ReconnectTransportOnFailure {
|
|
get { return (bool) base [reconnect_transport_on_failure]; }
|
|
set { base [reconnect_transport_on_failure] = value; }
|
|
}
|
|
|
|
[IntegerValidator ( MinValue = 1,
|
|
MaxValue = int.MaxValue,
|
|
ExcludeRange = false)]
|
|
[ConfigurationProperty ("replayCacheSize",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "900000")]
|
|
public int ReplayCacheSize {
|
|
get { return (int) base [replay_cache_size]; }
|
|
set { base [replay_cache_size] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("replayWindow",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:05:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan ReplayWindow {
|
|
get { return (TimeSpan) base [replay_window]; }
|
|
set { base [replay_window] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("sessionKeyRenewalInterval",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "15:00:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan SessionKeyRenewalInterval {
|
|
get { return (TimeSpan) base [session_key_renewal_interval]; }
|
|
set { base [session_key_renewal_interval] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("sessionKeyRolloverInterval",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:05:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan SessionKeyRolloverInterval {
|
|
get { return (TimeSpan) base [session_key_rollover_interval]; }
|
|
set { base [session_key_rollover_interval] = value; }
|
|
}
|
|
|
|
[ConfigurationProperty ("timestampValidityDuration",
|
|
Options = ConfigurationPropertyOptions.None,
|
|
DefaultValue = "00:05:00")]
|
|
[TypeConverter (typeof (TimeSpanConverter))]
|
|
public TimeSpan TimestampValidityDuration {
|
|
get { return (TimeSpan) base [timestamp_validity_duration]; }
|
|
set { base [timestamp_validity_duration] = value; }
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|