Code:
/ FX-1434 / FX-1434 / 1.0 / untmp / whidbey / REDBITS / 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 { //------------------------------------------------------ // // 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 ) { if (evidence == null) return false; IEnumerator enumerator = evidence.GetHostEnumerator(); while (enumerator.MoveNext()) { Object obj = enumerator.Current; if (obj is Publisher) { 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)obj).Equals(new Publisher(m_certificate))) 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(); } } }
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- OracleColumn.cs
- DataException.cs
- DbParameterCollectionHelper.cs
- ImageKeyConverter.cs
- WebPartMenuStyle.cs
- ClientOperation.cs
- GestureRecognizer.cs
- EntityConnectionStringBuilder.cs
- RegexNode.cs
- SmiMetaData.cs
- EUCJPEncoding.cs
- StringDictionaryCodeDomSerializer.cs
- ObjectConverter.cs
- Cursor.cs
- OuterGlowBitmapEffect.cs
- TextRunTypographyProperties.cs
- PagesSection.cs
- SqlDataSourceAdvancedOptionsForm.cs
- NativeStructs.cs
- DataGridDetailsPresenter.cs
- PKCS1MaskGenerationMethod.cs
- NamedPipeTransportManager.cs
- CompositeControlDesigner.cs
- XamlStream.cs
- MembershipValidatePasswordEventArgs.cs
- HtmlControl.cs
- TableParagraph.cs
- ParserOptions.cs
- ObjectListCommandCollection.cs
- ZipIOCentralDirectoryFileHeader.cs
- GcSettings.cs
- SynchronousChannelMergeEnumerator.cs
- HttpModuleCollection.cs
- Cursor.cs
- RoleGroup.cs
- SerializationEventsCache.cs
- AppModelKnownContentFactory.cs
- PolicyStatement.cs
- SelectionRange.cs
- FamilyTypeface.cs
- NameTable.cs
- NameTable.cs
- FontFamily.cs
- TextServicesDisplayAttribute.cs
- ReliableInputConnection.cs
- ScrollProviderWrapper.cs
- PreviewPrintController.cs
- FontCacheUtil.cs
- ItemCheckedEvent.cs
- NotSupportedException.cs
- DispatcherExceptionFilterEventArgs.cs
- xdrvalidator.cs
- EntityDesignerUtils.cs
- XmlCDATASection.cs
- Pen.cs
- PrintPreviewGraphics.cs
- FloaterParagraph.cs
- SiteOfOriginContainer.cs
- DoubleAnimationClockResource.cs
- FixedSOMFixedBlock.cs
- ContainerUIElement3D.cs
- CqlErrorHelper.cs
- TransformerConfigurationWizardBase.cs
- HtmlAnchor.cs
- BinaryWriter.cs
- FamilyCollection.cs
- _LoggingObject.cs
- MD5.cs
- XmlSchemaAny.cs
- ResXDataNode.cs
- RSAPKCS1SignatureDeformatter.cs
- RepeatButtonAutomationPeer.cs
- ScopelessEnumAttribute.cs
- FormsAuthenticationUser.cs
- HtmlMeta.cs
- PolyBezierSegment.cs
- MembershipValidatePasswordEventArgs.cs
- SpellerStatusTable.cs
- Visual3D.cs
- DelegateBodyWriter.cs
- SecurityCriticalDataForSet.cs
- OracleCommandBuilder.cs
- VectorAnimation.cs
- KeyGesture.cs
- EventSourceCreationData.cs
- EventHandlerService.cs
- Win32.cs
- SafeEventLogWriteHandle.cs
- AssertSection.cs
- LockRenewalTask.cs
- UpdateCompiler.cs
- DynamicFilter.cs
- HttpListener.cs
- BmpBitmapDecoder.cs
- UpdateException.cs
- SqlConnectionPoolGroupProviderInfo.cs
- PropertyStore.cs
- TaskFactory.cs
- Transform3D.cs
- CodeAccessSecurityEngine.cs