Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WCF / IdentityModel / System / IdentityModel / Tokens / X509IssuerSerialKeyIdentifierClause.cs / 1305376 / X509IssuerSerialKeyIdentifierClause.cs
//------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Diagnostics; using System.Globalization; using System.Security.Cryptography; using System.Security.Cryptography.X509Certificates; public class X509IssuerSerialKeyIdentifierClause : SecurityKeyIdentifierClause { readonly string issuerName; readonly string issuerSerialNumber; public X509IssuerSerialKeyIdentifierClause(string issuerName, string issuerSerialNumber) : base(null) { if (String.IsNullOrEmpty(issuerName)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("issuerName"); if (String.IsNullOrEmpty(issuerSerialNumber)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("issuerSerialNumber"); this.issuerName = issuerName; this.issuerSerialNumber = issuerSerialNumber; } public X509IssuerSerialKeyIdentifierClause(X509Certificate2 certificate) : base(null) { if (certificate == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("certificate"); this.issuerName = certificate.Issuer; this.issuerSerialNumber = Asn1IntegerConverter.Asn1IntegerToDecimalString(certificate.GetSerialNumber()); } public string IssuerName { get { return this.issuerName; } } public string IssuerSerialNumber { get { return this.issuerSerialNumber; } } public override bool Matches(SecurityKeyIdentifierClause keyIdentifierClause) { X509IssuerSerialKeyIdentifierClause that = keyIdentifierClause as X509IssuerSerialKeyIdentifierClause; // PreSharp Bug: Parameter 'that' to this public method must be validated: A null-dereference can occur here. #pragma warning suppress 56506 return ReferenceEquals(this, that) || (that != null && that.Matches(this.issuerName, this.issuerSerialNumber)); } public bool Matches(X509Certificate2 certificate) { if (certificate == null) return false; return Matches(certificate.Issuer, Asn1IntegerConverter.Asn1IntegerToDecimalString(certificate.GetSerialNumber())); } public bool Matches(string issuerName, string issuerSerialNumber) { if (issuerName == null) { return false; } // If serial numbers dont match, we can avoid the potentially expensive issuer name comparison if (this.issuerSerialNumber != issuerSerialNumber) { return false; } // Serial numbers match. Do a string comparison of issuer names if (this.issuerName == issuerName) { return true; } // String equality comparison for issuer names failed // Do a byte-level comparison of the X500 distinguished names corresponding to the issuer names. // X500DistinguishedName constructor can throw for malformed inputs bool x500IssuerNameMatch = false; try { if (CryptoHelper.IsEqual(new X500DistinguishedName(this.issuerName).RawData, new X500DistinguishedName(issuerName).RawData)) { x500IssuerNameMatch = true; } } catch (CryptographicException e) { // Absorb and log exception. Fallthrough and return false from method. if (DiagnosticUtility.ShouldTraceWarning) { DiagnosticUtility.ExceptionUtility.TraceHandledException(e, TraceEventType.Warning); } } return x500IssuerNameMatch; } public override string ToString() { return string.Format(CultureInfo.InvariantCulture, "X509IssuerSerialKeyIdentifierClause(Issuer = '{0}', Serial = '{1}')", this.IssuerName, this.IssuerSerialNumber); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Diagnostics; using System.Globalization; using System.Security.Cryptography; using System.Security.Cryptography.X509Certificates; public class X509IssuerSerialKeyIdentifierClause : SecurityKeyIdentifierClause { readonly string issuerName; readonly string issuerSerialNumber; public X509IssuerSerialKeyIdentifierClause(string issuerName, string issuerSerialNumber) : base(null) { if (String.IsNullOrEmpty(issuerName)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("issuerName"); if (String.IsNullOrEmpty(issuerSerialNumber)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("issuerSerialNumber"); this.issuerName = issuerName; this.issuerSerialNumber = issuerSerialNumber; } public X509IssuerSerialKeyIdentifierClause(X509Certificate2 certificate) : base(null) { if (certificate == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("certificate"); this.issuerName = certificate.Issuer; this.issuerSerialNumber = Asn1IntegerConverter.Asn1IntegerToDecimalString(certificate.GetSerialNumber()); } public string IssuerName { get { return this.issuerName; } } public string IssuerSerialNumber { get { return this.issuerSerialNumber; } } public override bool Matches(SecurityKeyIdentifierClause keyIdentifierClause) { X509IssuerSerialKeyIdentifierClause that = keyIdentifierClause as X509IssuerSerialKeyIdentifierClause; // PreSharp Bug: Parameter 'that' to this public method must be validated: A null-dereference can occur here. #pragma warning suppress 56506 return ReferenceEquals(this, that) || (that != null && that.Matches(this.issuerName, this.issuerSerialNumber)); } public bool Matches(X509Certificate2 certificate) { if (certificate == null) return false; return Matches(certificate.Issuer, Asn1IntegerConverter.Asn1IntegerToDecimalString(certificate.GetSerialNumber())); } public bool Matches(string issuerName, string issuerSerialNumber) { if (issuerName == null) { return false; } // If serial numbers dont match, we can avoid the potentially expensive issuer name comparison if (this.issuerSerialNumber != issuerSerialNumber) { return false; } // Serial numbers match. Do a string comparison of issuer names if (this.issuerName == issuerName) { return true; } // String equality comparison for issuer names failed // Do a byte-level comparison of the X500 distinguished names corresponding to the issuer names. // X500DistinguishedName constructor can throw for malformed inputs bool x500IssuerNameMatch = false; try { if (CryptoHelper.IsEqual(new X500DistinguishedName(this.issuerName).RawData, new X500DistinguishedName(issuerName).RawData)) { x500IssuerNameMatch = true; } } catch (CryptographicException e) { // Absorb and log exception. Fallthrough and return false from method. if (DiagnosticUtility.ShouldTraceWarning) { DiagnosticUtility.ExceptionUtility.TraceHandledException(e, TraceEventType.Warning); } } return x500IssuerNameMatch; } public override string ToString() { return string.Format(CultureInfo.InvariantCulture, "X509IssuerSerialKeyIdentifierClause(Issuer = '{0}', Serial = '{1}')", this.IssuerName, this.IssuerSerialNumber); } } } // 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
- ThemeableAttribute.cs
- EditCommandColumn.cs
- SqlDataSourceCustomCommandEditor.cs
- EditCommandColumn.cs
- XmlSchemaCollection.cs
- AttachedPropertyInfo.cs
- ManipulationLogic.cs
- SqlProfileProvider.cs
- LZCodec.cs
- SqlConnectionFactory.cs
- AutoResetEvent.cs
- EastAsianLunisolarCalendar.cs
- InitializationEventAttribute.cs
- HwndSourceParameters.cs
- CertificateManager.cs
- InputBinding.cs
- ActivityCollectionMarkupSerializer.cs
- TreeView.cs
- AnnotationResource.cs
- StateBag.cs
- Hash.cs
- XmlSerializableWriter.cs
- RuntimeIdentifierPropertyAttribute.cs
- ProxyWebPartManager.cs
- TabItem.cs
- CalendarKeyboardHelper.cs
- RIPEMD160.cs
- TextCompositionManager.cs
- TypeUtils.cs
- _OverlappedAsyncResult.cs
- BasePattern.cs
- SqlMethodAttribute.cs
- ProgressPage.cs
- listviewsubitemcollectioneditor.cs
- InternalBufferOverflowException.cs
- DiffuseMaterial.cs
- DriveNotFoundException.cs
- WindowsStatic.cs
- XmlSchemaDatatype.cs
- ClassicBorderDecorator.cs
- TranslateTransform.cs
- DesignerPerfEventProvider.cs
- DragEvent.cs
- SafeFreeMibTable.cs
- MultiTrigger.cs
- RtfToXamlLexer.cs
- ErrorsHelper.cs
- EpmSourceTree.cs
- LookupNode.cs
- OracleConnectionStringBuilder.cs
- TypeBuilderInstantiation.cs
- HTMLTagNameToTypeMapper.cs
- ToolStripDropDownItem.cs
- DataServiceQueryException.cs
- AutoGeneratedField.cs
- GZipStream.cs
- UnsafeNativeMethods.cs
- ControlCommandSet.cs
- GenericEnumerator.cs
- MenuDesigner.cs
- FileClassifier.cs
- ClientScriptManager.cs
- GPPOINT.cs
- Calendar.cs
- AncestorChangedEventArgs.cs
- HitTestParameters.cs
- DbParameterCollection.cs
- DocumentApplication.cs
- MSHTMLHost.cs
- ClonableStack.cs
- MarkupCompiler.cs
- RepeatButton.cs
- ScrollProperties.cs
- XhtmlConformanceSection.cs
- ChtmlTextWriter.cs
- FontEmbeddingManager.cs
- GridSplitter.cs
- While.cs
- DataGrid.cs
- HandlerMappingMemo.cs
- ScrollItemPattern.cs
- TypefaceCollection.cs
- SerializerDescriptor.cs
- RuntimeUtils.cs
- IImplicitResourceProvider.cs
- ResourceAttributes.cs
- storagemappingitemcollection.viewdictionary.cs
- PagesSection.cs
- PagerSettings.cs
- SafeRightsManagementHandle.cs
- DivideByZeroException.cs
- DataGridViewRowPrePaintEventArgs.cs
- VisualTarget.cs
- Compress.cs
- Pen.cs
- OleDbRowUpdatingEvent.cs
- ExpressionConverter.cs
- selecteditemcollection.cs
- IsolatedStorageFilePermission.cs
- Currency.cs