Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Base / MS / Internal / IO / Zip / ZipIOCentralDirectoryDigitalSignature.cs / 1 / ZipIOCentralDirectoryDigitalSignature.cs
//------------------------------------------------------------------------------ //------------- *** WARNING *** //------------- This file is part of a legally monitored development project. //------------- Do not check in changes to this project. Do not raid bugs on this //------------- code in the main PS database. Do not contact the owner of this //------------- code directly. Contact the legal team at ‘ZSLegal’ for assistance. //------------- *** WARNING *** //----------------------------------------------------------------------------- //----------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // This is an internal class that enables interactions with Zip archives // for OPC scenarios // // History: // 11/19/2004: IgorBel: Initial creation. // 09/14/2005: BruceMac: Disable creation of signatures and throw on parse if signature found: // If we encounter archive with encrypted and /or signed data we consider those as // “invalid OPC packages”. Even in case when client application has never requested // read/write operations with the encrypted and/or signed area of the archive. Motivations include: // 1. Security based // 2. It is inappropriate to silently ignore digital signatures because this may lead to users // assuming that the signature has been validated when in fact it has not. // //----------------------------------------------------------------------------- using System; using System.IO; using System.Diagnostics; using System.Collections; using System.Runtime.Serialization; using System.Windows; namespace MS.Internal.IO.Zip { internal class ZipIOCentralDirectoryDigitalSignature { #if false internal static ZipIOCentralDirectoryDigitalSignature CreateNew() { ZipIOCentralDirectoryDigitalSignature record = new ZipIOCentralDirectoryDigitalSignature (); return record; } #endif internal static ZipIOCentralDirectoryDigitalSignature ParseRecord(BinaryReader reader) { // this record is optional, so let's check for presence of signature rightaway //let's ensure we have at least enough data to cover _fixedMinimalRecordSize bytes of signature if ((reader.BaseStream.Length - reader.BaseStream.Position) < _fixedMinimalRecordSize) { return null; } UInt32 signatureValue = reader.ReadUInt32(); if (signatureValue != _signatureConstant) { return null; } //at this point we can assume that Digital Signature Record is there // Convention is to throw throw new NotSupportedException(SR.Get(SRID.ZipNotSupportedSignedArchive)); // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled ZipIOCentralDirectoryDigitalSignature record = new ZipIOCentralDirectoryDigitalSignature (); record._signature = signatureValue; record._sizeOfData = reader.ReadUInt16(); record._signatureData = reader.ReadBytes(record._sizeOfData ); record.Validate(); return record; #endif } // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled internal void Save(BinaryWriter writer) { writer.Write(_signatureConstant); writer.Write(_sizeOfData); if (_sizeOfData > 0) { writer.Write(_signatureData , 0, _sizeOfData); } writer.Flush(); } internal long Size { get { return _fixedMinimalRecordSize + _sizeOfData; } } #endif private ZipIOCentralDirectoryDigitalSignature() { } // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled private void Validate () { if (_signature != _signatureConstant) { throw new FileFormatException(SR.Get(SRID.CorruptedData)); } if (_sizeOfData != _signatureData.Length) { throw new FileFormatException(SR.Get(SRID.CorruptedData)); } } #endif private const long _fixedMinimalRecordSize = 6; private const UInt32 _signatureConstant = 0x05054b50; // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled private UInt16 _sizeOfData; private UInt32 _signature = _signatureConstant; private byte[] _signatureData = null; #endif } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ //------------- *** WARNING *** //------------- This file is part of a legally monitored development project. //------------- Do not check in changes to this project. Do not raid bugs on this //------------- code in the main PS database. Do not contact the owner of this //------------- code directly. Contact the legal team at ‘ZSLegal’ for assistance. //------------- *** WARNING *** //----------------------------------------------------------------------------- //----------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // This is an internal class that enables interactions with Zip archives // for OPC scenarios // // History: // 11/19/2004: IgorBel: Initial creation. // 09/14/2005: BruceMac: Disable creation of signatures and throw on parse if signature found: // If we encounter archive with encrypted and /or signed data we consider those as // “invalid OPC packages”. Even in case when client application has never requested // read/write operations with the encrypted and/or signed area of the archive. Motivations include: // 1. Security based // 2. It is inappropriate to silently ignore digital signatures because this may lead to users // assuming that the signature has been validated when in fact it has not. // //----------------------------------------------------------------------------- using System; using System.IO; using System.Diagnostics; using System.Collections; using System.Runtime.Serialization; using System.Windows; namespace MS.Internal.IO.Zip { internal class ZipIOCentralDirectoryDigitalSignature { #if false internal static ZipIOCentralDirectoryDigitalSignature CreateNew() { ZipIOCentralDirectoryDigitalSignature record = new ZipIOCentralDirectoryDigitalSignature (); return record; } #endif internal static ZipIOCentralDirectoryDigitalSignature ParseRecord(BinaryReader reader) { // this record is optional, so let's check for presence of signature rightaway //let's ensure we have at least enough data to cover _fixedMinimalRecordSize bytes of signature if ((reader.BaseStream.Length - reader.BaseStream.Position) < _fixedMinimalRecordSize) { return null; } UInt32 signatureValue = reader.ReadUInt32(); if (signatureValue != _signatureConstant) { return null; } //at this point we can assume that Digital Signature Record is there // Convention is to throw throw new NotSupportedException(SR.Get(SRID.ZipNotSupportedSignedArchive)); // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled ZipIOCentralDirectoryDigitalSignature record = new ZipIOCentralDirectoryDigitalSignature (); record._signature = signatureValue; record._sizeOfData = reader.ReadUInt16(); record._signatureData = reader.ReadBytes(record._sizeOfData ); record.Validate(); return record; #endif } // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled internal void Save(BinaryWriter writer) { writer.Write(_signatureConstant); writer.Write(_sizeOfData); if (_sizeOfData > 0) { writer.Write(_signatureData , 0, _sizeOfData); } writer.Flush(); } internal long Size { get { return _fixedMinimalRecordSize + _sizeOfData; } } #endif private ZipIOCentralDirectoryDigitalSignature() { } // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled private void Validate () { if (_signature != _signatureConstant) { throw new FileFormatException(SR.Get(SRID.CorruptedData)); } if (_sizeOfData != _signatureData.Length) { throw new FileFormatException(SR.Get(SRID.CorruptedData)); } } #endif private const long _fixedMinimalRecordSize = 6; private const UInt32 _signatureConstant = 0x05054b50; // Zeus PS 3: disable creation/parsing of zip archive digital signatures #if ArchiveSignaturesEnabled private UInt16 _sizeOfData; private UInt32 _signature = _signatureConstant; private byte[] _signatureData = null; #endif } } // 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
- WebPartCollection.cs
- TextRangeBase.cs
- EventLogPropertySelector.cs
- AnnotationComponentChooser.cs
- MetadataUtil.cs
- WindowsAuthenticationEventArgs.cs
- DataGridCommandEventArgs.cs
- SQLUtility.cs
- SetMemberBinder.cs
- ObjectMemberMapping.cs
- BooleanSwitch.cs
- Path.cs
- CursorInteropHelper.cs
- _TransmitFileOverlappedAsyncResult.cs
- EmptyStringExpandableObjectConverter.cs
- activationcontext.cs
- NavigatorOutput.cs
- DbXmlEnabledProviderManifest.cs
- OrderToken.cs
- StylusTip.cs
- EventLogPermissionEntry.cs
- SessionStateItemCollection.cs
- MdiWindowListStrip.cs
- ReverseQueryOperator.cs
- SchemaTypeEmitter.cs
- BinHexEncoder.cs
- DataGridTextBox.cs
- XmlDocumentType.cs
- DataControlCommands.cs
- HeaderCollection.cs
- RectangleGeometry.cs
- SafeRegistryHandle.cs
- ChineseLunisolarCalendar.cs
- ISAPIRuntime.cs
- ContextInformation.cs
- FormDesigner.cs
- FormatConvertedBitmap.cs
- OperationAbortedException.cs
- FilterQueryOptionExpression.cs
- SplitterPanel.cs
- PeerResolverMode.cs
- ReadOnlyNameValueCollection.cs
- EntityDataSourceContextCreatedEventArgs.cs
- EmptyEnumerator.cs
- WebPartCollection.cs
- DefaultAssemblyResolver.cs
- TextEditorMouse.cs
- ChangePasswordDesigner.cs
- Material.cs
- DBCSCodePageEncoding.cs
- AdRotatorDesigner.cs
- MsmqInputChannelListener.cs
- ReadOnlyState.cs
- DataGridColumnDropSeparator.cs
- SqlClientWrapperSmiStream.cs
- LinqTreeNodeEvaluator.cs
- KnownBoxes.cs
- TitleStyle.cs
- UInt64Storage.cs
- ColumnClickEvent.cs
- CannotUnloadAppDomainException.cs
- TransactionProxy.cs
- WebDisplayNameAttribute.cs
- Stopwatch.cs
- ListBoxItemAutomationPeer.cs
- SQLDateTimeStorage.cs
- StringPropertyBuilder.cs
- PrimitiveXmlSerializers.cs
- XmlSchemaSimpleContentRestriction.cs
- XmlDataLoader.cs
- ObjectCacheSettings.cs
- ReadOnlyHierarchicalDataSourceView.cs
- DataSourceSelectArguments.cs
- BinaryParser.cs
- DataSourceExpressionCollection.cs
- MessageBox.cs
- AtomServiceDocumentSerializer.cs
- login.cs
- StrongTypingException.cs
- Request.cs
- DebugView.cs
- ZipArchive.cs
- Stack.cs
- CqlQuery.cs
- X509SecurityToken.cs
- SafeRightsManagementQueryHandle.cs
- DocumentPage.cs
- CompensatableTransactionScopeActivityDesigner.cs
- DoubleIndependentAnimationStorage.cs
- XamlRtfConverter.cs
- ClientEndpointLoader.cs
- VisualProxy.cs
- ScrollData.cs
- RunClient.cs
- DataBindingCollectionConverter.cs
- TypeElement.cs
- TextContainerChangedEventArgs.cs
- DecimalFormatter.cs
- CallTemplateAction.cs
- DescendantQuery.cs