Code:
                         / Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / clr / src / BCL / System / Security / Policy / PublisherMembershipCondition.cs / 1 / PublisherMembershipCondition.cs
                        
                        
                            // ==++== 
//
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//
// ==--== 
//  PublisherMembershipCondition.cs
// 
//  Implementation of membership condition for X509 certificate based publishers 
//
 
namespace System.Security.Policy {
    using System;
    using System.Collections;
    using System.Globalization; 
    using System.Security;
    using System.Security.Cryptography.X509Certificates; 
    using System.Security.Policy; 
    [Serializable] 
    [System.Runtime.InteropServices.ComVisible(true)]
    sealed public class PublisherMembershipCondition : IMembershipCondition, IConstantMembershipCondition, IReportMatchMembershipCondition
    {
        //------------------------------------------------------ 
        //
        // PRIVATE STATE DATA 
        // 
        //-----------------------------------------------------
 
        private X509Certificate m_certificate;
        private SecurityElement m_element;
        //----------------------------------------------------- 
        //
        // PUBLIC CONSTRUCTORS 
        // 
        //-----------------------------------------------------
 
        internal PublisherMembershipCondition()
        {
            m_element = null;
            m_certificate = null; 
        }
 
        public PublisherMembershipCondition( X509Certificate certificate ) 
        {
            CheckCertificate( certificate ); 
            m_certificate = new X509Certificate( certificate );
        }
        private static void CheckCertificate( X509Certificate certificate ) 
        {
            if (certificate == null) 
            { 
                throw new ArgumentNullException( "certificate" );
            } 
        }
        //------------------------------------------------------
        // 
        // PUBLIC ACCESSOR METHODS
        // 
        //----------------------------------------------------- 
        public X509Certificate Certificate 
        {
            set
            {
                CheckCertificate( value ); 
                m_certificate = new X509Certificate( value );
            } 
 
            get
            { 
                if (m_certificate == null && m_element != null)
                    ParseCertificate();
                if (m_certificate != null) 
                    return new X509Certificate( m_certificate );
                else 
                    return null; 
            }
        } 
        public override String ToString()
        {
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            if (m_certificate == null) 
                return Environment.GetResourceString( "Publisher_ToString" );
            else 
            {
                String name = m_certificate.Subject;
                if (name != null)
                    return String.Format( CultureInfo.CurrentCulture, Environment.GetResourceString( "Publisher_ToStringArg" ), System.Security.Util.Hex.EncodeHexString( m_certificate.GetPublicKey() ) ); 
                else
                    return Environment.GetResourceString( "Publisher_ToString" ); 
            } 
        }
 
        //------------------------------------------------------
        //
        // IMEMBERSHIPCONDITION IMPLEMENTATION
        // 
        //------------------------------------------------------
 
        public bool Check( Evidence evidence ) 
        {
            object usedEvidence = null; 
            return (this as IReportMatchMembershipCondition).Check(evidence, out usedEvidence);
        }
        bool IReportMatchMembershipCondition.Check(Evidence evidence, out object usedEvidence) 
        {
            usedEvidence = null; 
 
            if (evidence == null)
                return false; 
            IEnumerator enumerator = evidence.GetHostEnumerator();
            while (enumerator.MoveNext())
            { 
                Publisher publisher = enumerator.Current as Publisher;
                if (publisher != null) 
                { 
                    if (m_certificate == null && m_element != null)
                        ParseCertificate(); 
                    // We can't just compare certs directly here because Publisher equality
                    // depends only on the keys inside the certs.
                    if (publisher.Equals(new Publisher(m_certificate))) 
                    {
                        usedEvidence = publisher; 
                        return true; 
                    }
                } 
            }
            return false;
        }
 
        public IMembershipCondition Copy()
        { 
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            return new PublisherMembershipCondition( m_certificate );
        }
        public SecurityElement ToXml() 
        {
            return ToXml( null ); 
        } 
        public void FromXml( SecurityElement e ) 
        {
            FromXml( e, null );
        }
 
        public SecurityElement ToXml( PolicyLevel level )
        { 
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            SecurityElement root = new SecurityElement( "IMembershipCondition" );
            System.Security.Util.XMLUtil.AddClassAttribute( root, this.GetType(), "System.Security.Policy.PublisherMembershipCondition" );
            // If you hit this assert then most likely you are trying to change the name of this class.
            // This is ok as long as you change the hard coded string above and change the assert below. 
            BCLDebug.Assert( this.GetType().FullName.Equals( "System.Security.Policy.PublisherMembershipCondition" ), "Class name changed!" );
 
            root.AddAttribute( "version", "1" ); 
            if (m_certificate != null)
                root.AddAttribute( "X509Certificate", m_certificate.GetRawCertDataString() ); 
            return root;
        }
 
        public void FromXml( SecurityElement e, PolicyLevel level )
        { 
            if (e == null) 
                throw new ArgumentNullException("e");
 
            if (!e.Tag.Equals( "IMembershipCondition" ))
            {
                throw new ArgumentException( Environment.GetResourceString( "Argument_MembershipConditionElement" ) );
            } 
            lock (this) 
            { 
                m_element = e;
                m_certificate = null; 
            }
        }
        private void ParseCertificate() 
        {
            lock (this) 
            { 
                if (m_element == null)
                    return; 
                String elCert = m_element.Attribute( "X509Certificate" );
                m_certificate = elCert == null ? null : new X509Certificate( System.Security.Util.Hex.DecodeHexString( elCert ) );
                CheckCertificate( m_certificate ); 
                m_element = null;
            } 
        } 
        public override bool Equals( Object o ) 
        {
            PublisherMembershipCondition that = (o as PublisherMembershipCondition);
            if (that != null)
            { 
                if (this.m_certificate == null && this.m_element != null)
                    this.ParseCertificate(); 
                if (that.m_certificate == null && that.m_element != null) 
                    that.ParseCertificate();
 
                if ( Publisher.PublicKeyEquals( this.m_certificate, that.m_certificate ))
                    return true;
            }
            return false; 
        }
 
        public override int GetHashCode() 
        {
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
            if (m_certificate != null)
                return m_certificate.GetHashCode(); 
            else
                return typeof( PublisherMembershipCondition ).GetHashCode(); 
        } 
    }
} 
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// ==++== 
//
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//
// ==--== 
//  PublisherMembershipCondition.cs
// 
//  Implementation of membership condition for X509 certificate based publishers 
//
 
namespace System.Security.Policy {
    using System;
    using System.Collections;
    using System.Globalization; 
    using System.Security;
    using System.Security.Cryptography.X509Certificates; 
    using System.Security.Policy; 
    [Serializable] 
    [System.Runtime.InteropServices.ComVisible(true)]
    sealed public class PublisherMembershipCondition : IMembershipCondition, IConstantMembershipCondition, IReportMatchMembershipCondition
    {
        //------------------------------------------------------ 
        //
        // PRIVATE STATE DATA 
        // 
        //-----------------------------------------------------
 
        private X509Certificate m_certificate;
        private SecurityElement m_element;
        //----------------------------------------------------- 
        //
        // PUBLIC CONSTRUCTORS 
        // 
        //-----------------------------------------------------
 
        internal PublisherMembershipCondition()
        {
            m_element = null;
            m_certificate = null; 
        }
 
        public PublisherMembershipCondition( X509Certificate certificate ) 
        {
            CheckCertificate( certificate ); 
            m_certificate = new X509Certificate( certificate );
        }
        private static void CheckCertificate( X509Certificate certificate ) 
        {
            if (certificate == null) 
            { 
                throw new ArgumentNullException( "certificate" );
            } 
        }
        //------------------------------------------------------
        // 
        // PUBLIC ACCESSOR METHODS
        // 
        //----------------------------------------------------- 
        public X509Certificate Certificate 
        {
            set
            {
                CheckCertificate( value ); 
                m_certificate = new X509Certificate( value );
            } 
 
            get
            { 
                if (m_certificate == null && m_element != null)
                    ParseCertificate();
                if (m_certificate != null) 
                    return new X509Certificate( m_certificate );
                else 
                    return null; 
            }
        } 
        public override String ToString()
        {
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            if (m_certificate == null) 
                return Environment.GetResourceString( "Publisher_ToString" );
            else 
            {
                String name = m_certificate.Subject;
                if (name != null)
                    return String.Format( CultureInfo.CurrentCulture, Environment.GetResourceString( "Publisher_ToStringArg" ), System.Security.Util.Hex.EncodeHexString( m_certificate.GetPublicKey() ) ); 
                else
                    return Environment.GetResourceString( "Publisher_ToString" ); 
            } 
        }
 
        //------------------------------------------------------
        //
        // IMEMBERSHIPCONDITION IMPLEMENTATION
        // 
        //------------------------------------------------------
 
        public bool Check( Evidence evidence ) 
        {
            object usedEvidence = null; 
            return (this as IReportMatchMembershipCondition).Check(evidence, out usedEvidence);
        }
        bool IReportMatchMembershipCondition.Check(Evidence evidence, out object usedEvidence) 
        {
            usedEvidence = null; 
 
            if (evidence == null)
                return false; 
            IEnumerator enumerator = evidence.GetHostEnumerator();
            while (enumerator.MoveNext())
            { 
                Publisher publisher = enumerator.Current as Publisher;
                if (publisher != null) 
                { 
                    if (m_certificate == null && m_element != null)
                        ParseCertificate(); 
                    // We can't just compare certs directly here because Publisher equality
                    // depends only on the keys inside the certs.
                    if (publisher.Equals(new Publisher(m_certificate))) 
                    {
                        usedEvidence = publisher; 
                        return true; 
                    }
                } 
            }
            return false;
        }
 
        public IMembershipCondition Copy()
        { 
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            return new PublisherMembershipCondition( m_certificate );
        }
        public SecurityElement ToXml() 
        {
            return ToXml( null ); 
        } 
        public void FromXml( SecurityElement e ) 
        {
            FromXml( e, null );
        }
 
        public SecurityElement ToXml( PolicyLevel level )
        { 
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
 
            SecurityElement root = new SecurityElement( "IMembershipCondition" );
            System.Security.Util.XMLUtil.AddClassAttribute( root, this.GetType(), "System.Security.Policy.PublisherMembershipCondition" );
            // If you hit this assert then most likely you are trying to change the name of this class.
            // This is ok as long as you change the hard coded string above and change the assert below. 
            BCLDebug.Assert( this.GetType().FullName.Equals( "System.Security.Policy.PublisherMembershipCondition" ), "Class name changed!" );
 
            root.AddAttribute( "version", "1" ); 
            if (m_certificate != null)
                root.AddAttribute( "X509Certificate", m_certificate.GetRawCertDataString() ); 
            return root;
        }
 
        public void FromXml( SecurityElement e, PolicyLevel level )
        { 
            if (e == null) 
                throw new ArgumentNullException("e");
 
            if (!e.Tag.Equals( "IMembershipCondition" ))
            {
                throw new ArgumentException( Environment.GetResourceString( "Argument_MembershipConditionElement" ) );
            } 
            lock (this) 
            { 
                m_element = e;
                m_certificate = null; 
            }
        }
        private void ParseCertificate() 
        {
            lock (this) 
            { 
                if (m_element == null)
                    return; 
                String elCert = m_element.Attribute( "X509Certificate" );
                m_certificate = elCert == null ? null : new X509Certificate( System.Security.Util.Hex.DecodeHexString( elCert ) );
                CheckCertificate( m_certificate ); 
                m_element = null;
            } 
        } 
        public override bool Equals( Object o ) 
        {
            PublisherMembershipCondition that = (o as PublisherMembershipCondition);
            if (that != null)
            { 
                if (this.m_certificate == null && this.m_element != null)
                    this.ParseCertificate(); 
                if (that.m_certificate == null && that.m_element != null) 
                    that.ParseCertificate();
 
                if ( Publisher.PublicKeyEquals( this.m_certificate, that.m_certificate ))
                    return true;
            }
            return false; 
        }
 
        public override int GetHashCode() 
        {
            if (m_certificate == null && m_element != null) 
                ParseCertificate();
            if (m_certificate != null)
                return m_certificate.GetHashCode(); 
            else
                return typeof( PublisherMembershipCondition ).GetHashCode(); 
        } 
    }
} 
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
                        
                        
                        
                        
                    Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CfgParser.cs
- MemoryStream.cs
- SecurityDescriptor.cs
- PointF.cs
- SHA512Managed.cs
- WpfGeneratedKnownProperties.cs
- LabelDesigner.cs
- TcpServerChannel.cs
- FileSystemEventArgs.cs
- SiteIdentityPermission.cs
- ShadowGlyph.cs
- PageParser.cs
- ExceptionNotification.cs
- TextBoxLine.cs
- DataControlPagerLinkButton.cs
- KeyEventArgs.cs
- Size.cs
- Storyboard.cs
- ContractTypeNameCollection.cs
- RelationshipDetailsRow.cs
- DiscoveryClientDocuments.cs
- ColorBuilder.cs
- MetadataItemEmitter.cs
- Stream.cs
- Content.cs
- XmlnsDictionary.cs
- ParseChildrenAsPropertiesAttribute.cs
- BlockExpression.cs
- Span.cs
- DataBinding.cs
- ExtenderProvidedPropertyAttribute.cs
- SetterBaseCollection.cs
- ListView.cs
- XmlSchemaSequence.cs
- HttpModuleAction.cs
- BufferBuilder.cs
- ProcessInfo.cs
- LinqTreeNodeEvaluator.cs
- Evidence.cs
- DbReferenceCollection.cs
- Parameter.cs
- BaseResourcesBuildProvider.cs
- StateMachineHelpers.cs
- ToolZoneDesigner.cs
- ExpressionNode.cs
- ObjectParameterCollection.cs
- PackWebRequest.cs
- ForceCopyBuildProvider.cs
- FileDialogCustomPlacesCollection.cs
- BitmapSource.cs
- PageThemeCodeDomTreeGenerator.cs
- DBProviderConfigurationHandler.cs
- EdmScalarPropertyAttribute.cs
- ReliableMessagingVersion.cs
- Int64AnimationUsingKeyFrames.cs
- SqlReferenceCollection.cs
- ClientSettingsStore.cs
- WindowsBrush.cs
- Serializer.cs
- IQueryable.cs
- EnumMemberAttribute.cs
- updateconfighost.cs
- DefaultTextStore.cs
- ImageFormatConverter.cs
- GeneratedContractType.cs
- TextFindEngine.cs
- CommandHelper.cs
- DataControlImageButton.cs
- HotSpot.cs
- ToolConsole.cs
- ReferenceSchema.cs
- UseAttributeSetsAction.cs
- DropSource.cs
- WriteableOnDemandStream.cs
- control.ime.cs
- NetworkInformationPermission.cs
- OptimizerPatterns.cs
- CustomUserNameSecurityTokenAuthenticator.cs
- ServiceNameElement.cs
- AspCompat.cs
- ExpressionVisitor.cs
- xmlNames.cs
- LinqExpressionNormalizer.cs
- httpserverutility.cs
- HashFinalRequest.cs
- ClockGroup.cs
- OleDbTransaction.cs
- WriteTimeStream.cs
- ApplicationContext.cs
- ScrollViewerAutomationPeer.cs
- Assert.cs
- ISAPIRuntime.cs
- PassportAuthentication.cs
- Menu.cs
- ParagraphResult.cs
- Button.cs
- _NegoStream.cs
- DataGridTextBox.cs
- EdmScalarPropertyAttribute.cs
- SevenBitStream.cs