Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / ServiceModel / System / ServiceModel / Security / TrustDriver.cs / 1 / TrustDriver.cs
//------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- namespace System.ServiceModel.Security { using System; using System.ServiceModel.Channels; using System.ServiceModel; using System.ServiceModel.Description; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Diagnostics; using System.Runtime.Serialization; using System.IdentityModel.Claims; using System.IdentityModel.Policy; using System.IdentityModel.Selectors; using System.IdentityModel.Tokens; using System.Security.Principal; using System.Security.Cryptography; using System.ServiceModel.Security.Tokens; using System.Xml; abstract class TrustDriver { // issued tokens control public virtual bool IsIssuedTokensSupported { get { return false; } } // issued tokens feature public virtual string IssuedTokensHeaderName { get { // PreSharp Bug: Property get methods should not throw exceptions. #pragma warning suppress 56503 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.TrustDriverVersionDoesNotSupportIssuedTokens))); } } // issued tokens feature public virtual string IssuedTokensHeaderNamespace { get { // PreSharp Bug: Property get methods should not throw exceptions. #pragma warning suppress 56503 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.TrustDriverVersionDoesNotSupportIssuedTokens))); } } // session control public virtual bool IsSessionSupported { get { return false; } } public abstract XmlDictionaryString RequestSecurityTokenAction { get; } public abstract XmlDictionaryString RequestSecurityTokenResponseAction { get; } public abstract XmlDictionaryString RequestSecurityTokenResponseFinalAction { get; } // session feature public virtual string RequestTypeClose { get { // PreSharp Bug: Property get methods should not throw exceptions. #pragma warning suppress 56503 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.TrustDriverVersionDoesNotSupportSession))); } } public abstract string RequestTypeIssue { get; } // session feature public virtual string RequestTypeRenew { get { // PreSharp Bug: Property get methods should not throw exceptions. #pragma warning suppress 56503 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.TrustDriverVersionDoesNotSupportSession))); } } public abstract string ComputedKeyAlgorithm { get; } public abstract SecurityStandardsManager StandardsManager { get; } public abstract XmlDictionaryString Namespace { get; } // RST specific method public abstract RequestSecurityToken CreateRequestSecurityToken(XmlReader reader); // RSTR specific method public abstract RequestSecurityTokenResponse CreateRequestSecurityTokenResponse(XmlReader reader); // RSTRC specific method public abstract RequestSecurityTokenResponseCollection CreateRequestSecurityTokenResponseCollection(XmlReader xmlReader); public abstract bool IsAtRequestSecurityTokenResponse(XmlReader reader); public abstract bool IsAtRequestSecurityTokenResponseCollection(XmlReader reader); public abstract bool IsRequestedSecurityTokenElement(string name, string nameSpace); public abstract bool IsRequestedProofTokenElement(string name, string nameSpace); public abstract T GetAppliesTo(RequestSecurityToken rst, XmlObjectSerializer serializer); public abstract T GetAppliesTo (RequestSecurityTokenResponse rstr, XmlObjectSerializer serializer); public abstract void GetAppliesToQName(RequestSecurityToken rst, out string localName, out string namespaceUri); public abstract void GetAppliesToQName(RequestSecurityTokenResponse rstr, out string localName, out string namespaceUri); public abstract bool IsAppliesTo(string localName, string namespaceUri); // RSTR specific method public abstract byte[] GetAuthenticator(RequestSecurityTokenResponse rstr); // RST specific method public abstract BinaryNegotiation GetBinaryNegotiation(RequestSecurityToken rst); // RSTR specific method public abstract BinaryNegotiation GetBinaryNegotiation(RequestSecurityTokenResponse rstr); // RST specific method public abstract SecurityToken GetEntropy(RequestSecurityToken rst, SecurityTokenResolver resolver); // RSTR specific method public abstract SecurityToken GetEntropy(RequestSecurityTokenResponse rstr, SecurityTokenResolver resolver); // RSTR specific method public abstract GenericXmlSecurityToken GetIssuedToken(RequestSecurityTokenResponse rstr, SecurityTokenResolver resolver, IList allowedAuthenticators, SecurityKeyEntropyMode keyEntropyMode, byte[] requestorEntropy, string expectedTokenType, ReadOnlyCollection authorizationPolicies, int defaultKeySize, bool isBearerKeyType); public abstract GenericXmlSecurityToken GetIssuedToken(RequestSecurityTokenResponse rstr, string expectedTokenType, ReadOnlyCollection authorizationPolicies, RSA clientKey); public abstract void OnRSTRorRSTRCMissingException(); // RST specific method public abstract void WriteRequestSecurityToken(RequestSecurityToken rst, XmlWriter w); // RSTR specific method public abstract void WriteRequestSecurityTokenResponse(RequestSecurityTokenResponse rstr, XmlWriter w); // RSTR Collection method public abstract void WriteRequestSecurityTokenResponseCollection(RequestSecurityTokenResponseCollection rstrCollection, XmlWriter writer); // Federation proxy creation public abstract IChannelFactory CreateFederationProxy(EndpointAddress address, Binding binding, KeyedByTypeCollection channelBehaviors); public abstract XmlElement CreateKeySizeElement(int keySize); public abstract XmlElement CreateKeyTypeElement(SecurityKeyType keyType); public abstract XmlElement CreateTokenTypeElement(string tokenTypeUri); public abstract XmlElement CreateRequiredClaimsElement(IEnumerable claimsList); public abstract XmlElement CreateUseKeyElement(SecurityKeyIdentifier keyIdentifier, SecurityStandardsManager standardsManager); public abstract XmlElement CreateSignWithElement(string signatureAlgorithm); public abstract XmlElement CreateEncryptWithElement(string encryptionAlgorithm); public abstract XmlElement CreateEncryptionAlgorithmElement(string encryptionAlgorithm); public abstract XmlElement CreateCanonicalizationAlgorithmElement(string canonicalicationAlgorithm); public abstract XmlElement CreateComputedKeyAlgorithmElement(string computedKeyAlgorithm); public abstract Collection ProcessUnknownRequestParameters(Collection unknownRequestParameters, Collection originalRequestParameters); public abstract bool TryParseKeySizeElement(XmlElement element, out int keySize); public abstract bool TryParseKeyTypeElement(XmlElement element, out SecurityKeyType keyType); public abstract bool TryParseTokenTypeElement(XmlElement element, out string tokenType); public abstract bool TryParseRequiredClaimsElement(XmlElement element, out Collection requiredClaims); // helper methods for the parsing standard binding elements internal virtual bool IsSignWithElement(XmlElement element, out string signatureAlgorithm) { signatureAlgorithm = null; return false; } internal virtual bool IsEncryptWithElement(XmlElement element, out string encryptWithAlgorithm) { encryptWithAlgorithm = null; return false; } internal virtual bool IsEncryptionAlgorithmElement(XmlElement element, out string encryptionAlgorithm) { encryptionAlgorithm = null; return false; } internal virtual bool IsCanonicalizationAlgorithmElement(XmlElement element, out string canonicalizationAlgorithm) { canonicalizationAlgorithm = null; return false; } internal virtual bool IsKeyWrapAlgorithmElement(XmlElement element, out string keyWrapAlgorithm) { keyWrapAlgorithm = null; return false; } } } // 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
- XmlElementAttribute.cs
- TemplateParser.cs
- UpdateCommand.cs
- EntityParameter.cs
- TagPrefixAttribute.cs
- WebEventCodes.cs
- SplitterCancelEvent.cs
- MaskedTextProvider.cs
- WriteableBitmap.cs
- StylusPointProperty.cs
- ResourceWriter.cs
- XmlSchemaSimpleTypeList.cs
- Cell.cs
- loginstatus.cs
- CharUnicodeInfo.cs
- SBCSCodePageEncoding.cs
- PseudoWebRequest.cs
- ViewStateModeByIdAttribute.cs
- CategoryValueConverter.cs
- SerializerDescriptor.cs
- Compiler.cs
- SvcMapFileSerializer.cs
- AddressingProperty.cs
- RequestCache.cs
- SerializationException.cs
- TraceListener.cs
- ReflectionServiceProvider.cs
- EntityProxyFactory.cs
- ChangeConflicts.cs
- SharedPersonalizationStateInfo.cs
- SqlProviderServices.cs
- JournalEntryListConverter.cs
- ProfilePropertyNameValidator.cs
- HashCryptoHandle.cs
- BaseParaClient.cs
- ObjectHandle.cs
- WbemProvider.cs
- FixedSOMGroup.cs
- TimeSpanHelper.cs
- ColumnMapProcessor.cs
- DataGridViewLinkColumn.cs
- sqlcontext.cs
- XmlSchemaComplexContentExtension.cs
- HttpVersion.cs
- WebBrowserContainer.cs
- ConfigXmlSignificantWhitespace.cs
- XamlFilter.cs
- RegionData.cs
- ArglessEventHandlerProxy.cs
- DataListCommandEventArgs.cs
- CodeSnippetExpression.cs
- ActiveXMessageFormatter.cs
- SiteMapHierarchicalDataSourceView.cs
- Lazy.cs
- OdbcConnectionFactory.cs
- ConstructorNeedsTagAttribute.cs
- XmlTextReaderImplHelpers.cs
- SubpageParaClient.cs
- PerfCounters.cs
- XpsS0ValidatingLoader.cs
- PassportIdentity.cs
- ExecutionContext.cs
- MouseEvent.cs
- DodSequenceMerge.cs
- FontStyles.cs
- Line.cs
- EmbeddedMailObject.cs
- _DigestClient.cs
- TextTabProperties.cs
- MultiView.cs
- AppDomainAttributes.cs
- CheckedPointers.cs
- DataGridViewCellEventArgs.cs
- EntityDataSourceViewSchema.cs
- ConsoleTraceListener.cs
- CommandHelper.cs
- BamlStream.cs
- DispatchChannelSink.cs
- PopOutPanel.cs
- ReadWriteObjectLock.cs
- SqlNodeAnnotations.cs
- Configuration.cs
- FormViewCommandEventArgs.cs
- NullableConverter.cs
- XPathExpr.cs
- XmlDataImplementation.cs
- SystemInfo.cs
- EntryPointNotFoundException.cs
- Int32Storage.cs
- BufferedResponseStream.cs
- ConsoleCancelEventArgs.cs
- EnumMember.cs
- InvokePatternIdentifiers.cs
- Clock.cs
- QuaternionValueSerializer.cs
- GeneratedView.cs
- ExtractorMetadata.cs
- RadioButtonList.cs
- ProvideValueServiceProvider.cs
- RegexFCD.cs