Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / System / Security / Cryptography / ECDiffieHellmanCngPublicKey.cs / 1305376 / ECDiffieHellmanCngPublicKey.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== using System; using System.Runtime.Serialization; using System.Security; using System.Security.Permissions; using System.Diagnostics.Contracts; namespace System.Security.Cryptography { ////// Public key used to do key exchange with the ECDiffieHellmanCng algorithm /// [Serializable] [System.Security.Permissions.HostProtection(MayLeakOnAbort = true)] public sealed class ECDiffieHellmanCngPublicKey : ECDiffieHellmanPublicKey { [NonSerialized] private CngKey m_key; private CngKeyBlobFormat m_format; ////// Wrap a CNG key /// //// [System.Security.SecurityCritical] internal ECDiffieHellmanCngPublicKey(CngKey key) : base(key.Export(CngKeyBlobFormat.EccPublicBlob)) { Contract.Requires(key != null && key.AlgorithmGroup == CngAlgorithmGroup.ECDiffieHellman); Contract.Ensures(m_format != null); m_format = CngKeyBlobFormat.EccPublicBlob; // // We need to make a copy of the key to prevent the situation where the ECDiffieHellmanCng algorithm // object is disposed (this disposing its key) before the ECDiffieHellmanCngPublic key is disposed. // // Accessing the handle in partial trust is safe because we're not exposing it back out to user code // new SecurityPermission(SecurityPermissionFlag.UnmanagedCode).Assert(); m_key = CngKey.Open(key.Handle, key.IsEphemeral ? CngKeyHandleOpenOptions.EphemeralKey : CngKeyHandleOpenOptions.None); CodeAccessPermission.RevertAssert(); } ///// /// Format the key blob is expressed in /// public CngKeyBlobFormat BlobFormat { get { Contract.Ensures(Contract.Result() != null); Contract.Assert(m_format != null); return m_format; } } /// /// Clean up the key /// protected override void Dispose(bool disposing) { try { if (disposing) { if (m_key != null) { m_key.Dispose(); } } } finally { base.Dispose(disposing); } } ////// Hydrate a public key from a blob /// //// [System.Security.SecurityCritical] public static ECDiffieHellmanPublicKey FromByteArray(byte[] publicKeyBlob, CngKeyBlobFormat format) { if (publicKeyBlob == null) { throw new ArgumentNullException("publicKeyBlob"); } if (format == null) { throw new ArgumentNullException("format"); } using (CngKey imported = CngKey.Import(publicKeyBlob, format)) { if (imported.AlgorithmGroup != CngAlgorithmGroup.ECDiffieHellman) { throw new ArgumentException(SR.GetString(SR.Cryptography_ArgECDHRequiresECDHKey)); } return new ECDiffieHellmanCngPublicKey(imported); } } ///// /// Hydrate a public key from XML /// /// See code:System.Security.Cryptography.Rfc4050KeyFormatter#RFC4050ECKeyFormat for information /// about the XML format used. /// //// [System.Security.SecurityCritical] public static ECDiffieHellmanCngPublicKey FromXmlString(string xml) { if (xml == null) { throw new ArgumentNullException("xml"); } using (CngKey imported = Rfc4050KeyFormatter.FromXml(xml)) { if (imported.AlgorithmGroup != CngAlgorithmGroup.ECDiffieHellman) { throw new ArgumentException(SR.GetString(SR.Cryptography_ArgECDHRequiresECDHKey), "xml"); } return new ECDiffieHellmanCngPublicKey(imported); } } ///// /// Import the public key into CNG /// ///public CngKey Import() { Contract.Ensures(Contract.Result () != null); Contract.Assert(m_format != null); return CngKey.Import(ToByteArray(), BlobFormat); } /// /// Convert the key blob to XML /// /// See code:System.Security.Cryptography.Rfc4050KeyFormatter#RFC4050ECKeyFormat for information /// about the XML format used. /// public override string ToXmlString() { Contract.Ensures(!String.IsNullOrEmpty(Contract.Result())); if (m_key == null) { m_key = Import(); } return Rfc4050KeyFormatter.ToXml(m_key); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== using System; using System.Runtime.Serialization; using System.Security; using System.Security.Permissions; using System.Diagnostics.Contracts; namespace System.Security.Cryptography { /// /// Public key used to do key exchange with the ECDiffieHellmanCng algorithm /// [Serializable] [System.Security.Permissions.HostProtection(MayLeakOnAbort = true)] public sealed class ECDiffieHellmanCngPublicKey : ECDiffieHellmanPublicKey { [NonSerialized] private CngKey m_key; private CngKeyBlobFormat m_format; ////// Wrap a CNG key /// //// [System.Security.SecurityCritical] internal ECDiffieHellmanCngPublicKey(CngKey key) : base(key.Export(CngKeyBlobFormat.EccPublicBlob)) { Contract.Requires(key != null && key.AlgorithmGroup == CngAlgorithmGroup.ECDiffieHellman); Contract.Ensures(m_format != null); m_format = CngKeyBlobFormat.EccPublicBlob; // // We need to make a copy of the key to prevent the situation where the ECDiffieHellmanCng algorithm // object is disposed (this disposing its key) before the ECDiffieHellmanCngPublic key is disposed. // // Accessing the handle in partial trust is safe because we're not exposing it back out to user code // new SecurityPermission(SecurityPermissionFlag.UnmanagedCode).Assert(); m_key = CngKey.Open(key.Handle, key.IsEphemeral ? CngKeyHandleOpenOptions.EphemeralKey : CngKeyHandleOpenOptions.None); CodeAccessPermission.RevertAssert(); } ///// /// Format the key blob is expressed in /// public CngKeyBlobFormat BlobFormat { get { Contract.Ensures(Contract.Result() != null); Contract.Assert(m_format != null); return m_format; } } /// /// Clean up the key /// protected override void Dispose(bool disposing) { try { if (disposing) { if (m_key != null) { m_key.Dispose(); } } } finally { base.Dispose(disposing); } } ////// Hydrate a public key from a blob /// //// [System.Security.SecurityCritical] public static ECDiffieHellmanPublicKey FromByteArray(byte[] publicKeyBlob, CngKeyBlobFormat format) { if (publicKeyBlob == null) { throw new ArgumentNullException("publicKeyBlob"); } if (format == null) { throw new ArgumentNullException("format"); } using (CngKey imported = CngKey.Import(publicKeyBlob, format)) { if (imported.AlgorithmGroup != CngAlgorithmGroup.ECDiffieHellman) { throw new ArgumentException(SR.GetString(SR.Cryptography_ArgECDHRequiresECDHKey)); } return new ECDiffieHellmanCngPublicKey(imported); } } ///// /// Hydrate a public key from XML /// /// See code:System.Security.Cryptography.Rfc4050KeyFormatter#RFC4050ECKeyFormat for information /// about the XML format used. /// //// [System.Security.SecurityCritical] public static ECDiffieHellmanCngPublicKey FromXmlString(string xml) { if (xml == null) { throw new ArgumentNullException("xml"); } using (CngKey imported = Rfc4050KeyFormatter.FromXml(xml)) { if (imported.AlgorithmGroup != CngAlgorithmGroup.ECDiffieHellman) { throw new ArgumentException(SR.GetString(SR.Cryptography_ArgECDHRequiresECDHKey), "xml"); } return new ECDiffieHellmanCngPublicKey(imported); } } ///// /// Import the public key into CNG /// ///public CngKey Import() { Contract.Ensures(Contract.Result () != null); Contract.Assert(m_format != null); return CngKey.Import(ToByteArray(), BlobFormat); } /// /// Convert the key blob to XML /// /// See code:System.Security.Cryptography.Rfc4050KeyFormatter#RFC4050ECKeyFormat for information /// about the XML format used. /// public override string ToXmlString() { Contract.Ensures(!String.IsNullOrEmpty(Contract.Result())); if (m_key == null) { m_key = Import(); } return Rfc4050KeyFormatter.ToXml(m_key); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- X509PeerCertificateAuthentication.cs
- PartitionResolver.cs
- EntityTypeEmitter.cs
- DataGridColumnHeaderAutomationPeer.cs
- Win32KeyboardDevice.cs
- SqlHelper.cs
- ProjectionPruner.cs
- ExpressionBuilderContext.cs
- RuleSettingsCollection.cs
- TimeoutHelper.cs
- WebPartZoneBaseDesigner.cs
- DiscriminatorMap.cs
- SqlRowUpdatedEvent.cs
- HyperlinkAutomationPeer.cs
- MarkupProperty.cs
- AssemblyName.cs
- ECDsa.cs
- CodeDirectoryCompiler.cs
- WindowsIPAddress.cs
- FixedPage.cs
- DataTableClearEvent.cs
- ReferenceList.cs
- RunWorkerCompletedEventArgs.cs
- ExpressionValueEditor.cs
- X500Name.cs
- DataColumn.cs
- InstanceKey.cs
- SymDocumentType.cs
- PeerName.cs
- TimestampInformation.cs
- MailBnfHelper.cs
- DataControlFieldTypeEditor.cs
- Paragraph.cs
- PartitionedDataSource.cs
- LinqExpressionNormalizer.cs
- ToolStripProgressBar.cs
- ForEach.cs
- SrgsNameValueTag.cs
- EventRouteFactory.cs
- returneventsaver.cs
- AssemblyCacheEntry.cs
- KnownTypesHelper.cs
- TextAnchor.cs
- PersonalizationStateInfo.cs
- handlecollector.cs
- ExpressionBuilderCollection.cs
- SingleAnimationBase.cs
- SqlRowUpdatingEvent.cs
- HttpFormatExtensions.cs
- DataAccessor.cs
- HuffmanTree.cs
- DataGridViewRowHeaderCell.cs
- HyperLink.cs
- SynchronizedDispatch.cs
- Line.cs
- ClaimTypes.cs
- TrayIconDesigner.cs
- CLRBindingWorker.cs
- PackWebResponse.cs
- SiteMapSection.cs
- TextChangedEventArgs.cs
- MdiWindowListStrip.cs
- OleStrCAMarshaler.cs
- GB18030Encoding.cs
- ResXResourceWriter.cs
- Asn1IntegerConverter.cs
- XmlSchemaAttributeGroup.cs
- ReturnType.cs
- CompensableActivity.cs
- GridViewColumnCollection.cs
- Visual3D.cs
- Visitors.cs
- IImplicitResourceProvider.cs
- Expander.cs
- HexParser.cs
- BCLDebug.cs
- Point3DConverter.cs
- TagPrefixAttribute.cs
- CounterSample.cs
- XmlSerializerFactory.cs
- Transform3DGroup.cs
- Function.cs
- ProxyManager.cs
- ProcessHostMapPath.cs
- MessagePropertyFilter.cs
- Baml2006SchemaContext.cs
- CodeCatchClause.cs
- DefaultPropertyAttribute.cs
- CodeCatchClause.cs
- StorageEntityTypeMapping.cs
- LineMetrics.cs
- ValueTable.cs
- ProviderUtil.cs
- DatagridviewDisplayedBandsData.cs
- UrlPropertyAttribute.cs
- ISessionStateStore.cs
- WsatAdminException.cs
- SelectionUIHandler.cs
- Baml6Assembly.cs
- PrtCap_Base.cs