//------------------------------------------------------------ // 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; } } }