| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | using System;using Renci.SshNet.Common;using Renci.SshNet.Security.Chaos.NaCl;namespace Renci.SshNet.Security.Cryptography{    /// <summary>    /// Implements ECDSA digital signature algorithm.    /// </summary>    public class ED25519DigitalSignature : DigitalSignature, IDisposable    {        private readonly ED25519Key _key;        private bool _isDisposed;        /// <summary>        /// Initializes a new instance of the <see cref="ED25519DigitalSignature" /> class.        /// </summary>        /// <param name="key">The ED25519Key key.</param>        /// <exception cref="ArgumentNullException"><paramref name="key"/> is <see langword="null"/>.</exception>        public ED25519DigitalSignature(ED25519Key key)        {            if (key is null)            {                throw new ArgumentNullException(nameof(key));            }            _key = key;        }        /// <summary>        /// Verifies the signature.        /// </summary>        /// <param name="input">The input.</param>        /// <param name="signature">The signature.</param>        /// <returns>        /// <see langword="true"/> if signature was successfully verified; otherwise <see langword="false"/>.        /// </returns>        /// <exception cref="InvalidOperationException">Invalid signature.</exception>        public override bool Verify(byte[] input, byte[] signature)        {            return Ed25519.Verify(signature, input, _key.PublicKey);        }        /// <summary>        /// Creates the signature.        /// </summary>        /// <param name="input">The input.</param>        /// <returns>        /// Signed input data.        /// </returns>        /// <exception cref="SshException">Invalid ED25519Key key.</exception>        public override byte[] Sign(byte[] input)        {            return Ed25519.Sign(input, _key.PrivateKey);        }        /// <summary>        /// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.        /// </summary>        public void Dispose()        {            Dispose(disposing: true);            GC.SuppressFinalize(this);        }        /// <summary>        /// Releases unmanaged and - optionally - managed resources.        /// </summary>        /// <param name="disposing"><see langword="true"/> to release both managed and unmanaged resources; <see langword="false"/> to release only unmanaged resources.</param>        protected virtual void Dispose(bool disposing)        {            if (_isDisposed)            {                return;            }            if (disposing)            {                _isDisposed = true;            }        }        /// <summary>        /// Finalizes an instance of the <see cref="ED25519DigitalSignature"/> class.        /// </summary>        ~ED25519DigitalSignature()        {            Dispose(disposing: false);        }    }}
 |