Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Base / MS / Internal / IO / Packaging / Certificate.cs / 1305600 / Certificate.cs
//------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // Handles serialization to/from X509 Certificate part (X509v3 = ASN.1 DER format) // // History: // 03/22/2004: BruceMac: Initial Implementation // //----------------------------------------------------------------------------- using System; using System.Diagnostics; // for Assert using System.Security.Cryptography.X509Certificates; using System.Windows; // For Exception strings - SRID using System.IO.Packaging; using System.IO; // for Stream using MS.Internal; // For ContentType using MS.Internal.WindowsBase; namespace MS.Internal.IO.Packaging { ////// CertificatePart /// internal class CertificatePart { #region Internal Members //----------------------------------------------------- // // Internal Properties // //----------------------------------------------------- ////// Type of relationship to a Certificate Part /// static internal string RelationshipType { get { return _certificatePartRelationshipType; } } ////// Prefix of auto-generated Certificate Part names /// static internal string PartNamePrefix { get { return _certificatePartNamePrefix; } } ////// Extension of Certificate Part file names /// static internal string PartNameExtension { get { return _certificatePartNameExtension; } } ////// ContentType of Certificate Parts /// static internal ContentType ContentType { get { return _certificatePartContentType; } } internal Uri Uri { get { return _part.Uri; } } //------------------------------------------------------ // // Internal Methods // //----------------------------------------------------- ////// Certificate to associate with this Certificate Part /// ////// stream is too large internal X509Certificate2 GetCertificate() { // lazy init if (_certificate == null) { // obtain from the part using (Stream s = _part.GetStream()) { if (s.Length > 0) { // throw if stream is beyond any reasonable length if (s.Length > _maximumCertificateStreamLength) throw new FileFormatException(SR.Get(SRID.CorruptedData)); // X509Certificate constructor desires a byte array Byte[] byteArray = new Byte[s.Length]; PackagingUtilities.ReliableRead(s, byteArray, 0, (int)s.Length); _certificate = new X509Certificate2(byteArray); } } } return _certificate; } internal void SetCertificate(X509Certificate2 certificate) { if (certificate == null) throw new ArgumentNullException("certificate"); _certificate = certificate; // persist to the part Byte[] byteArray = _certificate.GetRawCertData(); // FileMode.Create will ensure that the stream will shrink if overwritten using (Stream s = _part.GetStream(FileMode.Create, FileAccess.Write)) { s.Write(byteArray, 0, byteArray.Length); } } ////// CertificatePart constructor /// internal CertificatePart(Package container, Uri partName) { if (container == null) throw new ArgumentNullException("container"); if (partName == null) throw new ArgumentNullException("partName"); partName = PackUriHelper.ValidatePartUri(partName); // create if not found if (container.PartExists(partName)) { // open the part _part = container.GetPart(partName); // ensure the part is of the expected type if (_part.ValidatedContentType.AreTypeAndSubTypeEqual(_certificatePartContentType) == false) throw new FileFormatException(SR.Get(SRID.CertificatePartContentTypeMismatch)); } else { // create the part _part = container.CreatePart(partName, _certificatePartContentType.ToString()); } } //------------------------------------------------------ // // Private Fields // //------------------------------------------------------ private PackagePart _part; // part that houses the certificate private X509Certificate2 _certificate; // certificate itself // certificate part constants private static readonly ContentType _certificatePartContentType = new ContentType("application/vnd.openxmlformats-package.digital-signature-certificate"); private static readonly string _certificatePartNamePrefix = "/package/services/digital-signature/certificate/"; private static readonly string _certificatePartNameExtension = ".cer"; private static readonly string _certificatePartRelationshipType = "http://schemas.openxmlformats.org/package/2006/relationships/digital-signature/certificate"; private static long _maximumCertificateStreamLength = 0x40000; // 4MB #endregion Private Members } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // Handles serialization to/from X509 Certificate part (X509v3 = ASN.1 DER format) // // History: // 03/22/2004: BruceMac: Initial Implementation // //----------------------------------------------------------------------------- using System; using System.Diagnostics; // for Assert using System.Security.Cryptography.X509Certificates; using System.Windows; // For Exception strings - SRID using System.IO.Packaging; using System.IO; // for Stream using MS.Internal; // For ContentType using MS.Internal.WindowsBase; namespace MS.Internal.IO.Packaging { ////// CertificatePart /// internal class CertificatePart { #region Internal Members //----------------------------------------------------- // // Internal Properties // //----------------------------------------------------- ////// Type of relationship to a Certificate Part /// static internal string RelationshipType { get { return _certificatePartRelationshipType; } } ////// Prefix of auto-generated Certificate Part names /// static internal string PartNamePrefix { get { return _certificatePartNamePrefix; } } ////// Extension of Certificate Part file names /// static internal string PartNameExtension { get { return _certificatePartNameExtension; } } ////// ContentType of Certificate Parts /// static internal ContentType ContentType { get { return _certificatePartContentType; } } internal Uri Uri { get { return _part.Uri; } } //------------------------------------------------------ // // Internal Methods // //----------------------------------------------------- ////// Certificate to associate with this Certificate Part /// ////// stream is too large internal X509Certificate2 GetCertificate() { // lazy init if (_certificate == null) { // obtain from the part using (Stream s = _part.GetStream()) { if (s.Length > 0) { // throw if stream is beyond any reasonable length if (s.Length > _maximumCertificateStreamLength) throw new FileFormatException(SR.Get(SRID.CorruptedData)); // X509Certificate constructor desires a byte array Byte[] byteArray = new Byte[s.Length]; PackagingUtilities.ReliableRead(s, byteArray, 0, (int)s.Length); _certificate = new X509Certificate2(byteArray); } } } return _certificate; } internal void SetCertificate(X509Certificate2 certificate) { if (certificate == null) throw new ArgumentNullException("certificate"); _certificate = certificate; // persist to the part Byte[] byteArray = _certificate.GetRawCertData(); // FileMode.Create will ensure that the stream will shrink if overwritten using (Stream s = _part.GetStream(FileMode.Create, FileAccess.Write)) { s.Write(byteArray, 0, byteArray.Length); } } ////// CertificatePart constructor /// internal CertificatePart(Package container, Uri partName) { if (container == null) throw new ArgumentNullException("container"); if (partName == null) throw new ArgumentNullException("partName"); partName = PackUriHelper.ValidatePartUri(partName); // create if not found if (container.PartExists(partName)) { // open the part _part = container.GetPart(partName); // ensure the part is of the expected type if (_part.ValidatedContentType.AreTypeAndSubTypeEqual(_certificatePartContentType) == false) throw new FileFormatException(SR.Get(SRID.CertificatePartContentTypeMismatch)); } else { // create the part _part = container.CreatePart(partName, _certificatePartContentType.ToString()); } } //------------------------------------------------------ // // Private Fields // //------------------------------------------------------ private PackagePart _part; // part that houses the certificate private X509Certificate2 _certificate; // certificate itself // certificate part constants private static readonly ContentType _certificatePartContentType = new ContentType("application/vnd.openxmlformats-package.digital-signature-certificate"); private static readonly string _certificatePartNamePrefix = "/package/services/digital-signature/certificate/"; private static readonly string _certificatePartNameExtension = ".cer"; private static readonly string _certificatePartRelationshipType = "http://schemas.openxmlformats.org/package/2006/relationships/digital-signature/certificate"; private static long _maximumCertificateStreamLength = 0x40000; // 4MB #endregion Private Members } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- WindowsScroll.cs
- _SafeNetHandles.cs
- PenContexts.cs
- CheckedListBox.cs
- SoapHeaderAttribute.cs
- Partitioner.cs
- ObjectQueryState.cs
- BindingMemberInfo.cs
- COM2AboutBoxPropertyDescriptor.cs
- BinaryUtilClasses.cs
- XmlConvert.cs
- RSAOAEPKeyExchangeDeformatter.cs
- ListItem.cs
- documentsequencetextcontainer.cs
- ContextProperty.cs
- ImageCollectionEditor.cs
- XhtmlBasicListAdapter.cs
- httpserverutility.cs
- XPathParser.cs
- FrameworkElementAutomationPeer.cs
- ComNativeDescriptor.cs
- Set.cs
- Literal.cs
- ApplicationSecurityInfo.cs
- PngBitmapDecoder.cs
- DataColumnMappingCollection.cs
- AbstractExpressions.cs
- handlecollector.cs
- DataGridViewHeaderCell.cs
- InternalConfigConfigurationFactory.cs
- ResXDataNode.cs
- SqlHelper.cs
- InstallerTypeAttribute.cs
- PasswordRecoveryDesigner.cs
- TcpHostedTransportConfiguration.cs
- DesignerInterfaces.cs
- LogWriteRestartAreaState.cs
- SystemEvents.cs
- HttpProtocolImporter.cs
- VirtualPath.cs
- LookupNode.cs
- DataException.cs
- _NegotiateClient.cs
- NameValueConfigurationElement.cs
- GeneralTransform3DTo2D.cs
- BuildProvider.cs
- DeviceFilterEditorDialog.cs
- FontUnit.cs
- Convert.cs
- NullableDecimalMinMaxAggregationOperator.cs
- MessageQueuePermissionEntryCollection.cs
- ScrollPattern.cs
- AsyncStreamReader.cs
- Compilation.cs
- DataGridItemAutomationPeer.cs
- ArglessEventHandlerProxy.cs
- IpcChannel.cs
- TextBox.cs
- PaperSource.cs
- XmlUtf8RawTextWriter.cs
- _SafeNetHandles.cs
- HttpHostedTransportConfiguration.cs
- QueryCacheManager.cs
- BaseAppDomainProtocolHandler.cs
- DragDeltaEventArgs.cs
- DetailsViewPageEventArgs.cs
- Link.cs
- CompiledAction.cs
- EntityClientCacheEntry.cs
- AnchoredBlock.cs
- XamlVector3DCollectionSerializer.cs
- ExpressionTextBox.xaml.cs
- WebPartConnectionsEventArgs.cs
- Exceptions.cs
- WindowsButton.cs
- ListViewPagedDataSource.cs
- MDIWindowDialog.cs
- FlowLayoutSettings.cs
- OleDbPropertySetGuid.cs
- Evidence.cs
- VisualStyleTypesAndProperties.cs
- GroupByExpressionRewriter.cs
- MailMessage.cs
- RegexReplacement.cs
- DeviceContexts.cs
- WindowsPen.cs
- XPathLexer.cs
- XmlBoundElement.cs
- NativeMethods.cs
- WorkflowOperationFault.cs
- PageSetupDialog.cs
- AuthenticationService.cs
- ApplicationContext.cs
- QueryTaskGroupState.cs
- BufferModeSettings.cs
- DefaultTraceListener.cs
- InternalConfigSettingsFactory.cs
- BooleanToVisibilityConverter.cs
- NestedContainer.cs
- Pts.cs