Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / infocard / Service / managed / Microsoft / InfoCards / RoamingStoreFile.cs / 1 / RoamingStoreFile.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace Microsoft.InfoCards { using System; using System.Collections.Generic; using System.Text; using System.Xml; using System.Xml.Serialization; using System.IO; using System.Security.Cryptography.X509Certificates; using IDT = Microsoft.InfoCards.Diagnostics.InfoCardTrace; // // Summary: // Reads and writes the Roaming store xml file format. // internal sealed class RoamingStoreFile { Listm_infocards; public RoamingStoreFile( ) { m_infocards = new List ( ); } // // Summary: // Get the list of cards that will be written or were read. // public IList Cards { get { return m_infocards; } } public void Clear() { foreach( InfoCard icard in m_infocards ) { icard.ClearSensitiveData(); } m_infocards.Clear(); } // // Summary: // Encrypts and writes the data to the specified xml writer. // public void WriteTo( string password, XmlWriter writer ) { byte[] cipherValue = null; byte[] newSalt = null; using( MemoryStream tempStream = new MemoryStream( ) ) { XmlWriterSettings settings = new XmlWriterSettings( ); settings.OmitXmlDeclaration = true; settings.CloseOutput = false; settings.Encoding = Encoding.UTF8; using( XmlWriter eltWriter = XmlWriter.Create( tempStream, settings ) ) { eltWriter.WriteStartElement( XmlNames.WSIdentity.RoamingStoreElement, XmlNames.WSIdentity.Namespace ); foreach( InfoCard serialzable in m_infocards ) { serialzable.WriteXml( eltWriter ); } eltWriter.WriteEndElement( ); eltWriter.Flush(); } tempStream.Flush( ); tempStream.Seek( 0, SeekOrigin.Begin ); cipherValue = new byte[ RoamingStoreFileUtility.CalculateEncryptedSize( Convert.ToInt32( tempStream.Length ) ) ]; using( MemoryStream encryptedStream = new MemoryStream( cipherValue ) ) { RoamingStoreFileUtility.Encrypt( tempStream, encryptedStream, password, out newSalt ); encryptedStream.Flush( ); } } writer.WriteStartElement( XmlNames.WSIdentity.EncryptedStoreElement, XmlNames.WSIdentity.Namespace ); writer.WriteStartElement( XmlNames.WSIdentity.StoreSaltElement, XmlNames.WSIdentity.Namespace ); writer.WriteBase64( newSalt, 0, newSalt.Length ); writer.WriteEndElement( ); writer.WriteStartElement( XmlNames.XmlEnc.EncryptedData,XmlNames.XmlEnc.Namespace ); writer.WriteStartElement( XmlNames.XmlEnc.CipherData,XmlNames.XmlEnc.Namespace ); writer.WriteStartElement( XmlNames.XmlEnc.CipherValue,XmlNames.XmlEnc.Namespace ); writer.WriteBase64( cipherValue, 0, cipherValue.Length ); writer.WriteEndElement( ); writer.WriteEndElement( ); writer.WriteEndElement( ); writer.WriteEndElement( ); } // // Summary: // Reads and decrypts the xml stream using the specified password. // public void ReadFrom( string password, XmlReader reader ) { if( !reader.IsStartElement( XmlNames.WSIdentity.EncryptedStoreElement, XmlNames.WSIdentity.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile ) ) ); } if( !reader.ReadToDescendant( XmlNames.WSIdentity.StoreSaltElement, XmlNames.WSIdentity.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile ) ) ); } byte[] salt = new byte[ RoamingStoreFileUtility.SaltLength ]; reader.ReadElementContentAsBase64( salt, 0, salt.Length ); if( 0 != reader.ReadElementContentAsBase64( new byte[ 1 ], 0, 1 ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile ) ) ); } if( !reader.IsStartElement( XmlNames.XmlEnc.EncryptedData,XmlNames.XmlEnc.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile )) ); } if( !reader.ReadToDescendant( XmlNames.XmlEnc.CipherData,XmlNames.XmlEnc.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile )) ); } if( !reader.ReadToDescendant( XmlNames.XmlEnc.CipherValue,XmlNames.XmlEnc.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile ) ) ); } using( MemoryStream encrypted = new MemoryStream( 4096 ) ) { byte[] block = new byte[ 1024 ]; int bytesRead = 0; while( ( bytesRead = reader.ReadElementContentAsBase64( block, 0, block.Length ) ) > 0 ) { encrypted.Write( block, 0, bytesRead ); } encrypted.Flush( ); encrypted.Seek( 0, SeekOrigin.Begin ); using( MemoryStream decrypted = new MemoryStream( RoamingStoreFileUtility.CalculateDecryptedSize(Convert.ToInt32(encrypted.Length)) ) ) { RoamingStoreFileUtility.Decrypt( encrypted, decrypted, password, salt ); decrypted.Flush( ); decrypted.Seek( 0, SeekOrigin.Begin ); using( XmlReader decryptedReader = InfoCardSchemas.CreateReader( decrypted, reader.Settings ) ) { decryptedReader.Read( ); if( !decryptedReader.IsStartElement( XmlNames.WSIdentity.RoamingStoreElement, XmlNames.WSIdentity.Namespace ) ) { throw IDT.ThrowHelperError( new ImportException( SR.GetString( SR.InvalidImportFile ) ) ); } if( decryptedReader.ReadToDescendant( XmlNames.WSIdentity.RoamingInfoCardElement, XmlNames.WSIdentity.Namespace ) ) { do { InfoCard card = new InfoCard(); card.ReadXml( decryptedReader ); m_infocards.Add(card); decryptedReader.ReadEndElement( ); } while( decryptedReader.IsStartElement( XmlNames.WSIdentity.RoamingInfoCardElement, XmlNames.WSIdentity.Namespace ) ); } decryptedReader.ReadEndElement( );//RoamingStore } } } reader.ReadEndElement( );//CipherData // // Skip optional encryption properties element. // if( reader.IsStartElement( XmlNames.XmlEnc.EncryptionProperties, XmlNames.XmlEnc.Namespace ) ) { reader.Skip(); } reader.ReadEndElement( );//EncryptedData reader.ReadEndElement( );//EncryptedStore } } } // 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
- RayHitTestParameters.cs
- DockPatternIdentifiers.cs
- MoveSizeWinEventHandler.cs
- DataTable.cs
- NextPreviousPagerField.cs
- Tag.cs
- CornerRadiusConverter.cs
- ColorConvertedBitmap.cs
- HttpCookieCollection.cs
- ItemType.cs
- FileInfo.cs
- FloaterBaseParagraph.cs
- XsdBuildProvider.cs
- PropertyItemInternal.cs
- DiscardableAttribute.cs
- CopyNodeSetAction.cs
- WmlLinkAdapter.cs
- XmlUtil.cs
- Win32Native.cs
- PenContext.cs
- AdvancedBindingPropertyDescriptor.cs
- HideDisabledControlAdapter.cs
- SimpleBitVector32.cs
- BuildManager.cs
- SelectionGlyph.cs
- TextEmbeddedObject.cs
- OpCodes.cs
- DelegatingTypeDescriptionProvider.cs
- PrimitiveType.cs
- GridView.cs
- MtomMessageEncodingBindingElement.cs
- PersonalizationStateInfo.cs
- NonSerializedAttribute.cs
- Part.cs
- SafeCryptoHandles.cs
- XmlNamespaceManager.cs
- ParameterCollectionEditorForm.cs
- LogStore.cs
- _AuthenticationState.cs
- StructuredType.cs
- NetworkInformationPermission.cs
- DesignTimeParseData.cs
- TypeToken.cs
- ProcessStartInfo.cs
- RectKeyFrameCollection.cs
- FlowDocumentScrollViewer.cs
- DbParameterCollectionHelper.cs
- DrawingAttributeSerializer.cs
- TemplateControl.cs
- RootNamespaceAttribute.cs
- SqlDependencyUtils.cs
- Calendar.cs
- Point3DCollectionConverter.cs
- ViewBase.cs
- FileDialog.cs
- StringResourceManager.cs
- Pointer.cs
- System.Data_BID.cs
- TableParagraph.cs
- ReadWriteObjectLock.cs
- SR.cs
- StructuredTypeInfo.cs
- ScopedMessagePartSpecification.cs
- ReservationNotFoundException.cs
- GetIndexBinder.cs
- FileCodeGroup.cs
- Parameter.cs
- ProcessModelSection.cs
- EditorAttribute.cs
- XslAstAnalyzer.cs
- Clock.cs
- EncoderReplacementFallback.cs
- SimpleNameService.cs
- GeometryGroup.cs
- LinqExpressionNormalizer.cs
- DataGridColumnCollection.cs
- EventHandlingScope.cs
- MachineKeySection.cs
- OutKeywords.cs
- WindowsToolbar.cs
- LinkTarget.cs
- WindowInteropHelper.cs
- InvalidateEvent.cs
- ResourceExpressionBuilder.cs
- InheritablePropertyChangeInfo.cs
- RSACryptoServiceProvider.cs
- Pair.cs
- MyContact.cs
- DelegatingHeader.cs
- PcmConverter.cs
- SafeThemeHandle.cs
- SkinBuilder.cs
- ControllableStoryboardAction.cs
- GPPOINTF.cs
- SqlServer2KCompatibilityAnnotation.cs
- ListSourceHelper.cs
- WindowsFont.cs
- ContentElement.cs
- ReadOnlyKeyedCollection.cs
- sqlser.cs