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(IEnumerableclaimsList) { 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
- TextSerializer.cs
- dbdatarecord.cs
- MembershipAdapter.cs
- ADMembershipProvider.cs
- StructuredTypeEmitter.cs
- StoryFragments.cs
- InputDevice.cs
- AsymmetricKeyExchangeFormatter.cs
- ListViewGroupConverter.cs
- ErrorItem.cs
- ArithmeticException.cs
- SchemaNamespaceManager.cs
- AccessedThroughPropertyAttribute.cs
- XmlRawWriter.cs
- DbConnectionStringCommon.cs
- InternalResources.cs
- DesignerResources.cs
- DataKeyCollection.cs
- ProtectedProviderSettings.cs
- CollectionChangeEventArgs.cs
- RadioButtonList.cs
- safesecurityhelperavalon.cs
- HashSetEqualityComparer.cs
- NetTcpBinding.cs
- DbParameterHelper.cs
- querybuilder.cs
- DbConnectionStringCommon.cs
- LabelAutomationPeer.cs
- FixedTextSelectionProcessor.cs
- TableLayoutCellPaintEventArgs.cs
- EntityProviderFactory.cs
- Duration.cs
- PeerNameRegistration.cs
- DockProviderWrapper.cs
- SerializationSectionGroup.cs
- DesignerActionHeaderItem.cs
- MoveSizeWinEventHandler.cs
- _SafeNetHandles.cs
- TextParagraphCache.cs
- XmlException.cs
- XPathScanner.cs
- BinaryQueryOperator.cs
- EventHandlingScope.cs
- ChangeTracker.cs
- FunctionDefinition.cs
- ProfileSection.cs
- xmlfixedPageInfo.cs
- MetafileHeader.cs
- TextLine.cs
- CodeTypeDelegate.cs
- RuntimeConfigLKG.cs
- ProfessionalColors.cs
- FontFaceLayoutInfo.cs
- EventLogger.cs
- ProcessModule.cs
- StreamUpgradeProvider.cs
- RightsManagementSuppressedStream.cs
- DrawListViewItemEventArgs.cs
- NativeRightsManagementAPIsStructures.cs
- Baml2006SchemaContext.cs
- MailFileEditor.cs
- AttributeAction.cs
- SendMessageRecord.cs
- DateRangeEvent.cs
- Reference.cs
- ListItem.cs
- Stack.cs
- ToolboxDataAttribute.cs
- EditorPartChrome.cs
- storepermissionattribute.cs
- NavigationFailedEventArgs.cs
- MimeAnyImporter.cs
- SqlRemoveConstantOrderBy.cs
- TagMapCollection.cs
- EntityContainer.cs
- ConfigXmlAttribute.cs
- DetailsView.cs
- _DomainName.cs
- ObsoleteAttribute.cs
- WsdlBuildProvider.cs
- DataBinding.cs
- SHA384.cs
- nulltextnavigator.cs
- Parallel.cs
- DataTableClearEvent.cs
- UserInitiatedNavigationPermission.cs
- HtmlInputText.cs
- InputMethod.cs
- ComAdminWrapper.cs
- NetworkInterface.cs
- MediaContextNotificationWindow.cs
- DataSourceHelper.cs
- DateTimeConverter.cs
- EpmCustomContentSerializer.cs
- TouchEventArgs.cs
- PersonalizationStateInfo.cs
- DetailsViewUpdatedEventArgs.cs
- PageAsyncTask.cs
- DateTimeUtil.cs
- SmtpDigestAuthenticationModule.cs