Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / ServiceModel / System / ServiceModel / Security / WSTrustDec2005.cs / 1 / WSTrustDec2005.cs
//------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//-----------------------------------------------------------
namespace System.ServiceModel.Security
{
using System;
using System.ServiceModel;
using System.ServiceModel.Description;
using System.Collections;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Diagnostics;
using System.Globalization;
using System.IO;
using System.Text;
using System.Threading;
using System.Xml;
using System.IdentityModel.Claims;
using System.IdentityModel.Policy;
using System.IdentityModel.Tokens;
using System.Security.Cryptography.X509Certificates;
using System.ServiceModel.Security.Tokens;
using HexBinary = System.Runtime.Remoting.Metadata.W3cXsd2001.SoapHexBinary;
using System.ServiceModel.Channels;
using System.ServiceModel.Security;
using System.Runtime.Serialization;
using System.ServiceModel.Dispatcher;
using KeyIdentifierEntry = WSSecurityTokenSerializer.KeyIdentifierEntry;
using KeyIdentifierClauseEntry = WSSecurityTokenSerializer.KeyIdentifierClauseEntry;
using TokenEntry = WSSecurityTokenSerializer.TokenEntry;
using StrEntry = WSSecurityTokenSerializer.StrEntry;
class WSTrustDec2005 : WSTrustFeb2005
{
public WSTrustDec2005(WSSecurityTokenSerializer tokenSerializer)
: base(tokenSerializer)
{
}
public override TrustDictionary SerializerDictionary
{
get { return DXD.TrustDec2005Dictionary; }
}
public class DriverDec2005 : WSTrustFeb2005.DriverFeb2005
{
public DriverDec2005(SecurityStandardsManager standardsManager)
: base(standardsManager)
{
}
public override TrustDictionary DriverDictionary
{
get
{
return DXD.TrustDec2005Dictionary;
}
}
public override XmlDictionaryString RequestSecurityTokenResponseFinalAction
{
get
{
return DXD.TrustDec2005Dictionary.RequestSecurityTokenCollectionIssuanceFinalResponse;
}
}
public override XmlElement CreateKeyTypeElement(SecurityKeyType keyType)
{
if (keyType == SecurityKeyType.BearerKey)
{
XmlDocument doc = new XmlDocument();
XmlElement result = doc.CreateElement(this.DriverDictionary.Prefix.Value, this.DriverDictionary.KeyType.Value,
this.DriverDictionary.Namespace.Value);
result.AppendChild(doc.CreateTextNode(DXD.TrustDec2005Dictionary.BearerKeyType.Value));
return result;
}
return base.CreateKeyTypeElement(keyType);
}
public override bool TryParseKeyTypeElement(XmlElement element, out SecurityKeyType keyType)
{
if (element == null)
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("element");
if (element.LocalName == this.DriverDictionary.KeyType.Value
&& element.NamespaceURI == this.DriverDictionary.Namespace.Value
&& element.InnerText == DXD.TrustDec2005Dictionary.BearerKeyType.Value)
{
keyType = SecurityKeyType.BearerKey;
return true;
}
return base.TryParseKeyTypeElement(element, out keyType);
}
public override XmlElement CreateRequiredClaimsElement(IEnumerable claimsList)
{
XmlElement result = base.CreateRequiredClaimsElement(claimsList);
XmlAttribute dialectAttribute = result.OwnerDocument.CreateAttribute(DXD.TrustDec2005Dictionary.Dialect.Value);
dialectAttribute.Value = DXD.TrustDec2005Dictionary.DialectType.Value;
result.Attributes.Append(dialectAttribute);
return result;
}
public override IChannelFactory CreateFederationProxy(EndpointAddress address, Binding binding, KeyedByTypeCollection channelBehaviors)
{
if (channelBehaviors == null)
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("channelBehaviors");
ChannelFactory result = new ChannelFactory(binding, address);
SetProtectionLevelForFederation(result.Endpoint.Contract.Operations);
// remove the default client credentials that gets added to channel factories
result.Endpoint.Behaviors.Remove();
for (int i = 0; i < channelBehaviors.Count; ++i)
{
result.Endpoint.Behaviors.Add(channelBehaviors[i]);
}
// add a behavior that removes the UI channel initializer added by the client credentials since there should be no UI
// initializer popped up as part of obtaining the federation token (the UI should already have been popped up for the main channel)
result.Endpoint.Behaviors.Add(new WSTrustFeb2005.DriverFeb2005.InteractiveInitializersRemovingBehavior());
return new WSTrustFeb2005.DriverFeb2005.RequestChannelFactory(result);
}
public override Collection ProcessUnknownRequestParameters(Collection unknownRequestParameters, Collection originalRequestParameters)
{
// For WS-Trust 1.3 we want everything in the requestSecurityTokenTemplate parameters to endup as Addtional parameters.
// The parameters will appear as a child element under a XmlElement named secondaryParameters.
if (originalRequestParameters == null)
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("originalRequestParameters");
if (originalRequestParameters.Count > 0 && originalRequestParameters[0] != null && originalRequestParameters[0].OwnerDocument != null)
{
XmlElement secondaryParamElement = originalRequestParameters[0].OwnerDocument.CreateElement(DXD.TrustDec2005Dictionary.Prefix.Value, DXD.TrustDec2005Dictionary.SecondaryParameters.Value, DXD.TrustDec2005Dictionary.Namespace.Value);
for (int i = 0; i < originalRequestParameters.Count; ++i)
{
secondaryParamElement.AppendChild(originalRequestParameters[i]);
}
Collection tempCollection = new Collection();
tempCollection.Add(secondaryParamElement);
return tempCollection;
}
return originalRequestParameters;
}
internal virtual bool IsSecondaryParametersElement(XmlElement element)
{
return ((element.LocalName == DXD.TrustDec2005Dictionary.SecondaryParameters.Value) &&
(element.NamespaceURI == DXD.TrustDec2005Dictionary.Namespace.Value));
}
public virtual XmlElement CreateKeyWrapAlgorithmElement(string keyWrapAlgorithm)
{
if (keyWrapAlgorithm == null)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("keyWrapAlgorithm");
}
XmlDocument doc = new XmlDocument();
XmlElement result = doc.CreateElement(DXD.TrustDec2005Dictionary.Prefix.Value, DXD.TrustDec2005Dictionary.KeyWrapAlgorithm.Value,
DXD.TrustDec2005Dictionary.Namespace.Value);
result.AppendChild(doc.CreateTextNode(keyWrapAlgorithm));
return result;
}
internal override bool IsKeyWrapAlgorithmElement(XmlElement element, out string keyWrapAlgorithm)
{
return CheckElement(element, DXD.TrustDec2005Dictionary.KeyWrapAlgorithm.Value, DXD.TrustDec2005Dictionary.Namespace.Value, out keyWrapAlgorithm);
}
[ServiceContract]
internal interface IWsTrustDec2005SecurityTokenService
{
[OperationContract(IsOneWay = false,
Action = TrustDec2005Strings.RequestSecurityTokenIssuance,
ReplyAction = TrustDec2005Strings.RequestSecurityTokenCollectionIssuanceFinalResponse)]
[FaultContract(typeof(string), Action = "*", ProtectionLevel = System.Net.Security.ProtectionLevel.Sign)]
Message RequestToken(Message message);
}
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- WebConfigurationHost.cs
- TextElementCollection.cs
- ZipIOLocalFileDataDescriptor.cs
- DSASignatureDeformatter.cs
- Drawing.cs
- Schedule.cs
- Util.cs
- DataBoundLiteralControl.cs
- SettingsPropertyNotFoundException.cs
- ErrorWrapper.cs
- InternalBufferOverflowException.cs
- DispatcherExceptionEventArgs.cs
- PeerValidationBehavior.cs
- WebBrowsableAttribute.cs
- PreviewPageInfo.cs
- HttpTransportElement.cs
- DynamicMethod.cs
- SortKey.cs
- HttpResponseInternalBase.cs
- PlatformNotSupportedException.cs
- MethodAccessException.cs
- DataGridViewCellMouseEventArgs.cs
- ContentType.cs
- GeometryHitTestResult.cs
- SqlClientWrapperSmiStreamChars.cs
- MultiView.cs
- FormsAuthenticationModule.cs
- Line.cs
- HtmlTableRow.cs
- _DisconnectOverlappedAsyncResult.cs
- CodeLabeledStatement.cs
- Parallel.cs
- StyleCollection.cs
- TrustSection.cs
- StatusBarDrawItemEvent.cs
- XmlNamedNodeMap.cs
- MouseButtonEventArgs.cs
- X509RecipientCertificateClientElement.cs
- _FtpDataStream.cs
- ToolStripPanelRow.cs
- NullableConverter.cs
- LogicalExpr.cs
- TextEvent.cs
- TextRunProperties.cs
- unsafenativemethodstextservices.cs
- DesignerForm.cs
- EnterpriseServicesHelper.cs
- ClientRolePrincipal.cs
- KeyValuePair.cs
- SqlNode.cs
- Boolean.cs
- GacUtil.cs
- SafeNativeMethods.cs
- HelpProvider.cs
- BasicCellRelation.cs
- FolderBrowserDialog.cs
- LocalizeDesigner.cs
- ButtonChrome.cs
- InputLangChangeEvent.cs
- UserPersonalizationStateInfo.cs
- TableAdapterManagerMethodGenerator.cs
- PropertyItem.cs
- DoubleLink.cs
- FileDocument.cs
- FacetDescription.cs
- GlobalizationAssembly.cs
- DataGridViewRowPrePaintEventArgs.cs
- ModelPropertyDescriptor.cs
- FieldBuilder.cs
- Attributes.cs
- CornerRadius.cs
- Win32Interop.cs
- ServicePointManager.cs
- CommunicationObject.cs
- FormsAuthenticationConfiguration.cs
- MimeTypeMapper.cs
- DataListItemCollection.cs
- Rule.cs
- TypeSystemProvider.cs
- PropertyGridCommands.cs
- EdmSchemaAttribute.cs
- NaturalLanguageHyphenator.cs
- ClonableStack.cs
- InvalidOperationException.cs
- XmlIterators.cs
- SchemaImporterExtension.cs
- XmlSortKeyAccumulator.cs
- BaseTemplateCodeDomTreeGenerator.cs
- OracleDataReader.cs
- StructuredType.cs
- GorillaCodec.cs
- SatelliteContractVersionAttribute.cs
- WeakHashtable.cs
- JsonEnumDataContract.cs
- SmtpClient.cs
- CodeRemoveEventStatement.cs
- XslTransform.cs
- ObjectListCommandsPage.cs
- FormViewRow.cs
- DataGridViewSelectedCellsAccessibleObject.cs