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
- RegistryPermission.cs
- EncoderBestFitFallback.cs
- SplayTreeNode.cs
- DbConnectionHelper.cs
- Exceptions.cs
- RegistryConfigurationProvider.cs
- Converter.cs
- DataGridToolTip.cs
- ValidationError.cs
- QueryContinueDragEvent.cs
- CustomGrammar.cs
- COM2ExtendedUITypeEditor.cs
- ControlFilterExpression.cs
- XmlAnyElementAttribute.cs
- DisplayInformation.cs
- WmpBitmapEncoder.cs
- ListViewGroupItemCollection.cs
- AssemblyAssociatedContentFileAttribute.cs
- controlskin.cs
- LocationUpdates.cs
- ListBindingHelper.cs
- ParseHttpDate.cs
- Debug.cs
- CreateUserErrorEventArgs.cs
- AbstractSvcMapFileLoader.cs
- DbgCompiler.cs
- BinaryReader.cs
- EntityContainerEntitySet.cs
- Automation.cs
- BaseCodeDomTreeGenerator.cs
- PathSegmentCollection.cs
- WebServiceMethodData.cs
- RequestCacheEntry.cs
- ReceiveActivityDesignerTheme.cs
- ProcessRequestArgs.cs
- TypeExtension.cs
- ColorInterpolationModeValidation.cs
- ToolStripPanelRow.cs
- TextCompositionEventArgs.cs
- XmlNotation.cs
- EdmPropertyAttribute.cs
- handlecollector.cs
- ConditionedDesigner.cs
- AsyncDataRequest.cs
- ResourceWriter.cs
- WebPartExportVerb.cs
- WebConfigurationManager.cs
- ConfigurationStrings.cs
- XPathChildIterator.cs
- MouseButton.cs
- WmlImageAdapter.cs
- ToolStripLocationCancelEventArgs.cs
- LinqDataSourceView.cs
- InvalidateEvent.cs
- WpfSharedBamlSchemaContext.cs
- FixedFindEngine.cs
- LogAppendAsyncResult.cs
- MenuAdapter.cs
- AddInProcess.cs
- PointKeyFrameCollection.cs
- HwndMouseInputProvider.cs
- ObjectNavigationPropertyMapping.cs
- PermissionAttributes.cs
- DocumentsTrace.cs
- CallSiteHelpers.cs
- ISAPIRuntime.cs
- OleDbWrapper.cs
- RenamedEventArgs.cs
- ViewgenContext.cs
- CellTreeNodeVisitors.cs
- IntegrationExceptionEventArgs.cs
- EditorZone.cs
- DataGridCellsPanel.cs
- PeerInvitationResponse.cs
- BamlReader.cs
- DeviceSpecificDialogCachedState.cs
- CategoryValueConverter.cs
- PolyQuadraticBezierSegment.cs
- AutomationPeer.cs
- PostBackTrigger.cs
- ResXDataNode.cs
- BasicBrowserDialog.cs
- GuidConverter.cs
- TreeViewItemAutomationPeer.cs
- FastEncoderWindow.cs
- BindingOperations.cs
- PopupRoot.cs
- DataViewManagerListItemTypeDescriptor.cs
- HandlerBase.cs
- _SslStream.cs
- HttpDictionary.cs
- MethodAccessException.cs
- GlyphRunDrawing.cs
- Odbc32.cs
- ScrollPatternIdentifiers.cs
- WebMessageBodyStyleHelper.cs
- TreeNode.cs
- ItemList.cs
- SqlRewriteScalarSubqueries.cs
- NumberAction.cs