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
- Models.cs
- PointHitTestParameters.cs
- HttpRequestWrapper.cs
- DesignBindingValueUIHandler.cs
- DataGridViewColumnEventArgs.cs
- ToolZone.cs
- SQLCharsStorage.cs
- XmlLinkedNode.cs
- DateTimeAutomationPeer.cs
- FontResourceCache.cs
- Maps.cs
- TextTreeDeleteContentUndoUnit.cs
- ObjectParameterCollection.cs
- LiteralControl.cs
- DigitalSignatureProvider.cs
- GifBitmapEncoder.cs
- HttpProfileBase.cs
- TypeConverterHelper.cs
- IntSecurity.cs
- MonthCalendarDesigner.cs
- ContextItemManager.cs
- TokenBasedSetEnumerator.cs
- CodeArgumentReferenceExpression.cs
- GuidConverter.cs
- TypedDataSetSchemaImporterExtension.cs
- ApplicationProxyInternal.cs
- QuaternionRotation3D.cs
- WebPartMenu.cs
- CallTemplateAction.cs
- AssemblyNameProxy.cs
- CapacityStreamGeometryContext.cs
- ClosableStream.cs
- Aes.cs
- Attribute.cs
- BlockingCollection.cs
- SQLMembershipProvider.cs
- NodeLabelEditEvent.cs
- SqlDataSourceSelectingEventArgs.cs
- AssemblyUtil.cs
- _MultipleConnectAsync.cs
- ProgressBar.cs
- BitmapEffectGeneralTransform.cs
- TableStyle.cs
- CodeCompiler.cs
- XPathMessageFilterElementComparer.cs
- AsyncDataRequest.cs
- HandleRef.cs
- SqlDelegatedTransaction.cs
- StrokeCollection.cs
- Transform3DGroup.cs
- GAC.cs
- WebPartConnection.cs
- Hyperlink.cs
- _BufferOffsetSize.cs
- SelectionItemPattern.cs
- NeutralResourcesLanguageAttribute.cs
- NullableDoubleMinMaxAggregationOperator.cs
- MenuItemStyleCollection.cs
- RtfToXamlLexer.cs
- StringValidatorAttribute.cs
- DefaultProfileManager.cs
- ModuleConfigurationInfo.cs
- CustomValidator.cs
- BamlLocalizableResource.cs
- RegexCharClass.cs
- HtmlInputPassword.cs
- DataGridViewImageColumn.cs
- SynthesizerStateChangedEventArgs.cs
- WebPartDescriptionCollection.cs
- RuntimeHelpers.cs
- WorkflowInlining.cs
- RenderDataDrawingContext.cs
- SamlAuthorizationDecisionStatement.cs
- SqlFlattener.cs
- FileUpload.cs
- AnonymousIdentificationModule.cs
- UITypeEditor.cs
- ToolboxBitmapAttribute.cs
- HwndSubclass.cs
- ExtenderHelpers.cs
- XmlTextReaderImplHelpers.cs
- ToolStripStatusLabel.cs
- FileDialogCustomPlacesCollection.cs
- PropertyDescriptorCollection.cs
- GrammarBuilderRuleRef.cs
- ReplyAdapterChannelListener.cs
- ToolStripHighContrastRenderer.cs
- PathData.cs
- WebPartManager.cs
- TemplateBindingExtensionConverter.cs
- Ray3DHitTestResult.cs
- ArgIterator.cs
- UDPClient.cs
- ArraySegment.cs
- Keyboard.cs
- ZipFileInfoCollection.cs
- RayHitTestParameters.cs
- XmlSortKey.cs
- SmiRequestExecutor.cs
- JsonQueryStringConverter.cs