Code:
/ DotNET / DotNET / 8.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
- SqlDataAdapter.cs
- MessageVersion.cs
- SoapReflectionImporter.cs
- HScrollProperties.cs
- SafePEFileHandle.cs
- ToolboxComponentsCreatingEventArgs.cs
- HtmlWindow.cs
- HeaderedItemsControl.cs
- PngBitmapEncoder.cs
- VolatileEnlistmentMultiplexing.cs
- OracleBinary.cs
- WebPartVerbsEventArgs.cs
- FontWeightConverter.cs
- WebPartManagerInternals.cs
- PeerNameRecordCollection.cs
- ECDiffieHellmanPublicKey.cs
- MetabaseSettingsIis7.cs
- TerminateDesigner.cs
- DocumentSequence.cs
- WindowsSecurityToken.cs
- Empty.cs
- ListViewPagedDataSource.cs
- StateDesigner.LayoutSelectionGlyph.cs
- BitmapData.cs
- CacheEntry.cs
- IdleTimeoutMonitor.cs
- PackageFilter.cs
- FontStretchConverter.cs
- ComponentCommands.cs
- BorderGapMaskConverter.cs
- ThreadExceptionDialog.cs
- SimpleApplicationHost.cs
- WorkItem.cs
- BindingNavigator.cs
- ListBoxItemWrapperAutomationPeer.cs
- LinkClickEvent.cs
- ParseNumbers.cs
- __ComObject.cs
- Html32TextWriter.cs
- EventListener.cs
- HwndSubclass.cs
- XmlConvert.cs
- BindingCompleteEventArgs.cs
- HealthMonitoringSectionHelper.cs
- ZipIOCentralDirectoryDigitalSignature.cs
- InputLanguageCollection.cs
- MexHttpBindingElement.cs
- ConfigurationStrings.cs
- ObjectListCommandsPage.cs
- ImageFormatConverter.cs
- HMACSHA384.cs
- Encoder.cs
- Ipv6Element.cs
- TreeViewItemAutomationPeer.cs
- PreviewKeyDownEventArgs.cs
- SecurityCriticalDataForSet.cs
- SubstitutionDesigner.cs
- PropertyValueEditor.cs
- FormsAuthenticationModule.cs
- FileDialogPermission.cs
- SchemaDeclBase.cs
- webproxy.cs
- ServicePointManager.cs
- FileAuthorizationModule.cs
- ZipIOCentralDirectoryDigitalSignature.cs
- HtmlElement.cs
- CopyAttributesAction.cs
- SafePEFileHandle.cs
- EventLogConfiguration.cs
- SqlDependencyUtils.cs
- ListViewContainer.cs
- FillBehavior.cs
- ReadContentAsBinaryHelper.cs
- XsltSettings.cs
- EntityConnectionStringBuilder.cs
- SkinBuilder.cs
- SizeChangedInfo.cs
- AnnotationDocumentPaginator.cs
- WsiProfilesElement.cs
- SqlMethodTransformer.cs
- Semaphore.cs
- TokenBasedSet.cs
- Point3DCollectionValueSerializer.cs
- DataViewManagerListItemTypeDescriptor.cs
- HighlightVisual.cs
- SlipBehavior.cs
- VoiceObjectToken.cs
- InputLanguageProfileNotifySink.cs
- Literal.cs
- SiteOfOriginPart.cs
- TracingConnectionListener.cs
- WindowsGraphicsWrapper.cs
- ChtmlTextWriter.cs
- List.cs
- UnsafeNativeMethods.cs
- HitTestWithPointDrawingContextWalker.cs
- HotCommands.cs
- XmlSchemaNotation.cs
- WebPartConnectionsCancelVerb.cs
- FlowNode.cs