More .NET libraries
-
Rebex FTP
.NET FTP client
-
Rebex SSH Shell
.NET SSH Shell
-
Rebex Total Pack
All Rebex .NET libraries together
Release notes for Rebex SFTP for .NET
- Released
- November122024
7.0.9083 #
(build 9083 from 2024-11-12)
Support for .NET 9!
This release adds a new set of binaries targeting .NET 9. It supports all .NET 9 platforms:
- Windows (x64, x86, ARM64)
- Linux (x64, ARM32, ARM64)
- Android (x64, ARM32, ARM64)
- macOS (ARM64, x64)
- iOS/iPadOS/tvOS (ARM64)
R6.17 available as well
For customers who have not yet upgraded to version 7 of Rebex libraries, we published the R6.17 update with important fixes and enhancements. Version R6.x will be supported until November 2025.
Detailed list of changes:
- All: Added binaries targeting ,NET 9 on all supported platforms.
- Cryptography: Added workaround for EnvelopedData with unpadded RSA EncryptedKey.
- Cryptography: Added workaround for parsing CMS ASN.1 with redundant zeros at the end.
- Cryptography: Fixed common name validation logic in NativeCertificateEngine and EnhancedCertificateEngine when used stand-alone by custom code.
- Released
- October082024
7.0.9048 #
(build 9048 from 2024-10-08)
Maintenance release
This release resolves several issues and brings fixes and enhancements in the shared functionality.
Detailed list of changes:
- SFTP: Added Sftp.Settings.IgnoreCloseErrors option.
- SSH: Fixed less common variants of multi-factor authentication.
- SSH: Fixed SshSession.Authenticate(userName, password, privateKey) method that crashed when privateKey was null (since version 7.0).
- Cryptography: Added ValidationOptions.​DisableCertificateDownloads option (only supported on .NET 5 and higher).
- Cryptography: Fixed detection of support for ECDH with brainpool curves on iOS.
- Cryptography: Fixed padding issues in AsymmetricKeyAlgorithm.​GetKeyMaterialDeriver (did not affect Rebex libraries).
- Cryptography: Fixed wrong RSA public key format when saving private keys in new OpenSSH format.
- Cryptography: Improved handling of wrong (negative) serial numbers in X.509 certificates.
- Released
- June252024
7.0.8943 #
(build 8943 from 2024-06-25)
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
R6.16 available as well
For customers who have not yet upgraded to version 7 of Rebex libraries, we published the R6.16 update with important fixes and enhancements. Version R6.x will be supported until November 2025.
Detailed list of changes:
- SFTP: Fixed legacy serialization issues in .NET Standard 2.0 binaries on .NET Framework 4.7/4.8.
- TLS Core: Fixed certificate selection and curve selection in TLS 1.3.
- TLS Core: Fixed wrong TlsException.Status for some exceptions representing server-side alerts.
- Cryptography: Added support for issuing certificates signed with Ed25519.
- Cryptography: Fixed calculation of subject key identifier in certificate issuer API.
- Cryptography: Fixed rare wrong final calculation of Poly1305 hash when temporary storage for remaining data is bigger than input block size.
- Cryptography: Using AES/GCM instead of AES/CBC for new OpenSSH key format encryption.
- Released
- April082024
7.0.8865 #
(build 8865 from 2024-04-08)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- SCP: Added workaround for SCP in Cisco SSH server that interprets target directory as file name.
- SCP: Fixed handling of paths starting with "~/".
- SSH: SshPublicKey.LoadPublicKeys reads comments and does not fail on empty files.
- TLS Core: Added option to disable ClientHello padding. Added option to enable legacy SCSV mode.
- TLS Core: Fixed potential repeated clean-up of TLS 1.3 extensions that might cause strange exceptions in the following TLS connection.
- Cryptography: Added support for loading private keys in new OpenSSH key format encrypted using AES/GCM or ChaCha20/Poly1305.
- Released
- February192024
7.0.8816 #
(build 8816 from 2024-02-19)
SSH enhancements
Client-side SSH now supports a combination of password and keyboard-interactive authentication
and contains other improvements as well. For example, Session.Cipher.StrictKeyExchange
property on Sftp
or Ssh
objects can be used to determine whether
strict SSH key exchange (mitigating the 'Terrapin' weakness) has been used.
R6.15 available as well
For customers who have not yet upgraded to version 7 of Rebex libraries, we published the R6.15 update with important fixes and enhancements. Version R6.x will be supported until November 2025.
Detailed list of changes:
- SFTP: Added workaround for FileZilla Server Pro Enterprise which crashes its SSH session if it receives SFTP read request for 65493 bytes or more.
- SSH: Added SshCipher.StrictKeyExchange and SshServerInfo.​SupportsStrictKeyExchange properties.
- SSH: Added SshPrivateKey.​CreateFrom(PrivateKeyInfo) method.
- SSH: Added support for a combination of password and keyboard-interactive authentication.
- SSH: Improved SSH session and channel lifecycle logging.
- SSH: Using lower local SSH channel numbers for better log readability.
- TLS Core: Fixed invalid TLS 1.3 behavior for rare Poll/Receive call sequence on TlsSocket.
- TLS Core: Fixed possible deadlock in Receive or Poll methods when additional incomplete packet is received after close_notify in TLS 1.2 or earlier.
- Cryptography: Added low-level API for loading/saving PrivateKeyInfo with byte[] passwords.
- Cryptography: Added ObjectIdentifier.Encode method.
- Cryptography: Added support for loading PKCS #8 private keys with legacy RC4 algorithm.
- Cryptography: Added UseDer property to SignedData and EnvelopedData classes.
- Cryptography: PrivateKeyInfo.Save now uses SHA-2 instead of SHA-1 in PKCS #8 format with PBKDF2 derivation.
- Cryptography: Reduced memory footprint of CNG API interop layer.
- Released
- December202023
7.0.8755 #
(build 8755 from 2023-12-20)
Strict key exchange in SSH
Rebex SSH library now implements OpenSSH's strict KEX
protocol extension that addresses
a weakness in the SSH protocol that makes some OpenSSH ciphers vulnerable to Terrapin attack
(CVE-2023-48795).
The attack is only possible when one of the following OpenSSH ciphers is in use:
chacha20-poly1305@openssh.com
hmac-sha2-256-etm@openssh.com
hmac-sha2-512-etm@openssh.com
Fortunately, in practice, the actual impact of the weakness on most SSH implementation seems to be negligible. No version of Rebex SSH relies on RFC 8308 extension negotiation mechanism yet, so this weakness can only be used by an attacker to disrupt authentication, causing the SSH session to fail.
Strict key exchange extension is enabled by default.
It can be disabled using Settings.SshParameters.UseStrictKeyExchange
option.
Please note that this extension only resolves the weakness if both the client and server SSH implementation support it.
When connecting a vulnerable client to an updated server (or vice versa), Terrapin attack is still possible.
Improved Native AOT compatibility
This update improves compatibility with .NET 8's Native AOT deployment model, which makes it possible to compile applications to native code ahead-of-time (AOT). Most common features should already work in Native AOT mode.
Detailed list of changes:
- All: Improved compatibility with Native AOT in .NET 8.
- SFTP: Added Sftp.ResolvePath(string path) method.
- SFTP: Fixed 'not authenticated' instead of 'not connected' error message.
- SSH: Added support for PKCS #8 format to SshPublicKey constructor.
- SSH: Added support for strict key exchange extension (thwarts the so-called 'Terrapin attack').
- Common: Optimized memory usage of miscellaneous methods.
- Released
- November152023
7.0.8720 #
(build 8720 from 2023-11-15)
Support for .NET 8!
This release adds a new set of binaries targeting .NET 8. It supports all .NET 8 platforms:
- Windows (x64, x86, ARM64)
- Linux (x64, ARM32, ARM64)
- macOS (x64)
- Android
- iOS/tvOS
Detailed list of changes:
- All: Added a new set of binaries targeting .NET 8.0.
- SFTP: Increased range for SftpAttributes dates and fixed the error message.
- SSH: Added SshParameters.ChannelCloseTimeout property.
- Cryptography: Fixed behavior of certificate issuer API when no CRLs have been specified.
- Released
- September132023
7.0.8657 #
(build 8657 from 2023-09-13)
Maintenance release
This is a maintenance release that fixes minor issues.
Detailed list of changes:
- Networking: Fixed handling of IPv6 addresses in square brackets.
- SSH: Fixed behavior of Certificate flag in SshParameters.HostKeyAlgorithms.
- Released
- June292023
7.0.8581 #
(build 8581 from 2023-06-29)
First 7.0.* release!
This is the first release of 7.0.* series. It no longer uses the 'Rx.y' naming scheme, which was somewhat confusing.
The R6.x series will be supported until November 2025 and will receive fixes and security updates.
SSH agent support
OpenSSH Agent and PuTTY Pageant are now supported for SSH and SFTP client authentication.
Use the Login
method overload with SshAuthenticationAgent
argument.
Support for secp256k1 curve in SSH
Rebex SSH client and server libraries now support ECDH and ECDSA ciphers with secp256k1 curve (ecdh-sha2-1.3.132.0.10
and ecdsa-sha2-1.3.132.0.10
).
Support for Telnet Environment Option
Added support for Telnet Environment Option (RFC 1572).
AesGcm and ChaChaPoly1305 moved to Rebex.Security
AesGcm
and ChaChaPoly1305
classes were moved from Rebex.Common assembly to Rebex.Security.
If you are using these classes and don't have a Rebex Total Pack or Rebex Security license, please let us know.
Detailed list of changes:
- SFTP: Enabled Settings.GetFileOpenRemoteFirst option by default.
- Networking: Added SslSettings.SslRenegotiationMode option.
- Networking: No longer sending default domain in SSPI requests by defalt. Added SslSettings.UseDefaultDomain property.
- SSH: Added SshPublicKey.Parse method and a new overload for SshPublicKey.LoadPublicKeys.
- SSH: Added support for ECDH and ECDSA with secp256k1 curve ('ecdh-sha2-1.3.132.0.10' and 'ecdsa-sha2-1.3.132.0.10').
- SSH: Added support for SSH agents (OpenSSH agent and Pageant).
- SSH: Preferring ChaCha20/Poly1305 on platforms with HW intrinsics support.
- TLS Core: Added public API for TLS 1.3 and TLS 1.2 signature algorithms.
- TLS Core: Added public API for TLS 1.3 named groups and pre-shared key exchange modes configuration.
- TLS Core: Added support for Ed25519 in TLS 1.2 (already supported in TLS 1.3).
- TLS Core: Added support for modular Diffie-Hellman (FFDHE) in TLS 1.3.
- TLS Core: ClientHello is padded to 512 bytes to work around strange bugs in the erroneous TLS implementation on some servers.
- TLS Core: Disable client-initiated TLS renegotiation by default.
- TLS Core: Enabled ChaCha20/Poly1305 ciphers by default on .NET Core 3.1 / .NET 5 or higher.
- TLS Core: Changed the default order of cipher suites in ClientHello to more closely align with the best practices of the industry.
- TLS Core: In TLS 1.2, support for Renegotiation Indication Extension is annonced using renegotiation_info extension.
- TLS Core: The default selection of TLS 1.2 elliptic curves has been altered to more closely align with the best practices of the industry.
- TLS Core: TlsServerSocket now honors TlsOptions.DoNotCacheSessions flag when TLS 1.3 is negotiated.
- TLS Core: Updated default TLS 1.2 cipher preference order. Disabled 3DES by default. Added TlsCipherSuite.Common value.
- Cryptography: Added API for CRL distribution endpoints with multiple CRL entries.
- Cryptography: Added Certificate.Bind methods.
- Cryptography: Added CertificateStoreName.WebHosting enum value.
- Cryptography: Added CertificateStoreOpenFlags and corresponding CertificateStore constructors.
- Cryptography: AesGcm and ChaChaPoly1305 classes moved from Rebex.Common assembly to Rebex.Security.
- Cryptography: Certificate.Extensions collection is now read-only.
- Cryptography: Deprecated EncryptValue/DecryptValue methods in RSAManaged class.
- Cryptography: Fixed visibility of CertificateException legacy serialization constructor.
- Cryptography: Improved loading of Y-less legacy DSA keys in FIPS-only mode on .NET 6/7 in Windows.
- Common: Optimized internal Task.Run methods on old platforms.
- Common: Optimized internal WhenAll/WhenAny Task combinators on old platforms.
- Released
- June282023
R6.14 #
(version 6.0.8580 from 2023-06-28)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
What next for R6.x?
Version R6.x of Rebex libraries will be supported until November 2025 and will receive fixes and security updates. See R6.x release history for more information.
Detailed list of changes:
- All: Fixed problems in finalizer logic.
- SSH: Fixed missing end-of-lines in new OpenSSH key format.
- Cryptography: Fixed support for ECDSA private key formats with optional public key.
- Released
- June062023
R6.13 #
(version 6.0.8558 from 2023-06-06)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- Networking: Added support for IPv6 addresses to SOCKS5 proxy (client-side).
- Networking: Added workaround for systems where System.​Net.​Sockets.​Socket.​RemoteEndPoint does not work properly.
- Networking: Fixed formatting of IPv6 addresses for HTTP CONNECT proxies.
- Networking: Using 'Proxy-Connection' header instead of 'Connection' with HTTP CONNECT proxies.
- TLS Core: Disabled workaround for DHE padding bug in old versions of MS Schannel.
- TLS Core: Fixed server-side TLS curve selection on end-of-life platforms.
- Cryptography: Fixed lifecycle of AsymmetricKeyAlgorithm based on RSA CSP.
- Cryptography: Improved support for SignatureHashAlgorithm.MD5SHA1 in .NET 5 and higher in FIPS-only mode.
- Released
- April182023
R6.12 #
(version 6.0.8509 from 2023-04-18)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- SFTP: Improved workaround for windows size adjustment issue in Azure Blob Storage SFTP server.
- SCP: Fixed escaping of "$" character in SCP commands.
- SSH: Added workaround for an issue in 'srt SSH Server' that makes it reject RSA/SHA-2 public key authentication attempts.
- SSH: Fixed handling of SSH2 PUBLIC KEY quotation marks in SshPublicKey.
- SSH: Fixed handling of user name when performing single sign-on in .NET Core and .NET 5/6/7.
- TLS Core: Fixed client-side TLS cipher suite check and server-side TLS cipher selection.
- TLS Core: Fixed checking of selected elliptic curves.
- TLS Core: Fixed memory leak in server-side TLS session cache.
- Common: Fixed rare race condition in scheduled action infrastructure.
- Released
- January312023
R6.11 #
(version 6.0.8432 from 2023-01-31)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- Networking: Comment is no longer ignored when loading SSH2 public key into SshPublicKey.
- SSH: Fixed occasional StackOverflowException in SSH tunnel code (thrown when a large batch of consecutive asynchronous IO operations completes synchronously).
- TLS Core: Fixed handling of missing close_notify message in TLS 1.2 or earlier.
- Cryptography: Fixed CRL retrieval for certificate with multiple CRL distribution endpoints.
- Common: Fixed potential premature release of an unmanaged buffer in SSPI interop code.
- Common: Improved compatibility with Windows 2000.
- Released
- December022022
R6.10 #
(version 6.0.8372 from 2022-12-02)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- SFTP: Added workaround for an issue in Azure Blob Storage SFTP related to receive window size adjustment handling.
- SSH: Added workaround for an issue in Azure Blob Storage SFTP that makes it reject RSA/SHA-2 public key authentication attempts.
- TLS Core: Fixed TlsParameter.AcceptableAuthorities handling (can specify an empty list).
- Cryptography: Added workaround for broken X25519 implementation in early versions of Windows 10 (version 1507 and 1511).
- Common: Fixed Windows Extended Protection in 64-bit Windows applications.
- Released
- November082022
R6.9 #
(version 6.0.8348 from 2022-11-08)
Support for .NET 7!
This release adds a new set of binaries targeting .NET 7. It supports all .NET 7 platforms:
- Windows (x64, x86, ARM64)
- Linux (x64, ARM32, ARM64)
- macOS (x64)
- Android
- iOS/tvOS
Detailed list of changes:
- All: Added a new set of binaries targeting .NET 7.
- Cryptography: Fixed SHA-2 support on pre-SP3 versions of Windows XP.
- Released
- October252022
R6.8 #
(version 6.0.8334 from 2022-10-25)
SSE2 implementation of ChaCha20
Last year, we introduced a very fast AVX2 implementation of ChaCha20 encryption cipher. However, some older or mobile CPUs lack AVX2 support, and this is where the new SSE2 implementation will become useful and improved performance of ChaCha20/Poly1305 in TLS and SSH. (Just like AVX2, the new SSE2 implementation is only available on .NET Core 3.1 and .NET 5/6.)
Detailed list of changes:
- Networking: Improved timeout handling during TCP connect.
- TLS Core: Fixed handling of incomplete TLS 1.3 records.
- TLS Core: Further optimized TLS 1.3 core.
- TLS Core: Improved handling of invalid TLS 1.3 session tickets (PSKs).
- TLS Core: Reduced memory footprint and CPU usage of TLS 1.3.
- Cryptography: Added SSE2 implementation of ChaCha20 for .NET 5.0 or higher.
- Released
- October052022
R6.7 #
(version 6.0.8314 from 2022-10-05)
Fixed code signing (broken by DigiCert)
From September 14th to September 22nd, 2022, DigiCert's timestamping authority mistakenly issued a TSA certificate with a validity period of only one year. Unfortunately, this mistake means that code-signed Rebex assemblies from R6.6 release will no longer pass validation after February 28th, 2024.
Therefore, Rebex customers should upgrade from R6.6 as soon as possible to take advantage of the new TSA certificate's full 11-year validity period.
Detailed list of changes:
- All: This release is properly code-signed again. TSA certificate validity was too short in R6.6 due to DigiCert's mistake.
- SSH: Added workaround for SSH servers that claim to prefer 'ssh-rsa' for client public key authentication.
- Cryptography: Added Rebex.Common.Validator assembly.
- Released
- September162022
R6.6 #
(version 6.0.8295 from 2022-09-16)
Fixed space calculations in Sftp.GetFileSystemInfo
Sftp
object's GetFileSystemInfo
method has been fixed.
It used to returned wrong information for macOS-based SFTP servers.
New constructor for SshPrivateKey/SshPublicKey
SshPrivateKey
and SshPublicKey
feature a new constructor
that accepts an instance of AsymmetricKeyAlgorithm
.
Detailed list of changes:
- SFTP: Fixed free space calculation in Sftp.GetFileSystemInfo for macOS-based servers.
- SSH: Added new constructors to SshPrivateKey/SshPublicKey classes that accept AsymmetricKeyAlgorithm.
- SSH: Added support for ECDSA to SshPrivateKey(AsymmetricAlgorithm) constructor (on .NET Core 3.1 or higher).
- SSH: Fixed rare NullReferenceException when closing an SshSession.
- TLS Core: Added support for Windows Extended Protection (only available on Windows).
- Cryptography: Added GetPrivateKeyAlgorithm/​GetPublicKeyAlgorithm methods to Certificate class.
- Released
- July152022
R6.5 #
(version 6.0.8232 from 2022-07-15)
Support for more SSH extensions
Added support for server-sig-algs
SSH extension (RFC 8332)
and for SSH extension negotiation (RFC 8308).
Detailed list of changes:
- SFTP: Improved key-only variant of Login method when the server requests further authentication and AuthenticationRequest event has been registered.
- SCP: Improved key-only variant of Login method when the server requests further authentication and AuthenticationRequest event has been registered.
- SSH: Added support for 'server-sig-algs' SSH extension (RFC 8332).
- SSH: Improved logging of 'partial success' authentication responses.
- TLS Core: Added support for TLS extended master secret extension (RFC 7627).
- TLS Core: Fixed handling of NoRenegotiation alert.
- TLS Core: Fixed rare race condition when closing TLS 1.2 socket.
- Common: Improved internal asynchronous infrastructure for old platforms.
- Released
- May252022
R6.4 #
(version 6.0.8181 from 2022-05-25)
Support for .NET 6.0 on Android and iOS
Support for mobile platforms in .NET 6.0 has finally arrived, slightly masquaraded as .NET MAUI. Rebex libraries now support these new platforms as well.
Optimized AEAD ciphers in SSH
ChaCha20/Poly1305 and AES/GCM ciphers have been slightly optimized on all platforms.
Detailed list of changes:
- All: Added support for .NET 6.0 on Android.
- All: Added support for .NET 6.0 on iOS.
- SSH: Fixed behavior of TryPasswordFirst option with servers that support 'publickey' and 'keyboard-interactive' but not 'password'.
- SSH: Optimized AEAD ciphers in SSH.
- TLS Core: Optimized AEAD ciphers in TLS.
- TLS Core: Optimized CPU usage in TLS 1.3 data flow.
- TLS Core: Optimized scenario when the remote party requires TLS 1.2 (or lower TLS version) and TLS 1.3 is enabled.
- TLS Core: Optimized TLS 1.3 key derivation functions.
- Cryptography: Added support for NTLM plugin for non-Windows platforms.
- Cryptography: Added workaround for buggy RSACryptoServiceProvider in .NET 6.0 on Android.
- Cryptography: Enhanced workarounds for slightly misbehaved certificate validator in .NET 6.0 on Android.
- Cryptography: Fixed exporting of DSA keys on Windows XP SP3.
- Cryptography: Optimized ChaCha20Poly1305 internals.
- Cryptography: Optimized internal AEAD interfaces.
- Cryptography: Working around RSA private key access issue in .NET 6.0 on Android.
- Common: Improved inner exception rethrow logic on .NET Framework 3.5/4.0.
- Common: Optimized internal data buffer methods.
- Released
- March282022
R6.3 #
(version 6.0.8123 from 2022-03-28)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- SFTP: Added Settings.GetFileOpenRemoteFirst option. When enabled, the local file is only created by GetFile/Download methods after the remote file has been successfully opened.
- SFTP: Added Sftp.​Settings.​EnableDirectoryAsFileWorkaround option (workaround for AWS FTP Transfer with S3 storage that misreports some directories as files).
- SFTP: Added Sftp.​Settings.​EnableMissingCreateTimeWorkaround option.
- SFTP: Fixed Sftp.​Settings.​UseReadWriteModeForDownloads option behavior.
- SFTP: When appending/resuming in Download method, FileMode.Open is used instead of OpenOrCreate.
- Networking: Added ProxySocket.Bind(Socket) protected method to allow more customization.
- SSH: Improved workaround for very old versions of Bitvise server that don't properly handle SSH channel closing.
- TLS Core: Added TlsSocket.CloseAsync method (alias for DisposeAsync method).
- TLS Core: Fixed occasional (rare) premature termination of the TLS connection when a remote party does not support TLS 1.3.
- TLS Core: Improved protocol mismatch detection.
- TLS Core: Optimized asynchronous Send/Receive operation in TLS 1.3.
- Cryptography: Improved Poly1305 internals.
- Cryptography: Slightly optimized encrypt/decrypt operations in symmetric branch of the CNG/BCrypt interop layer.
- Cryptography: Small optimization in ARM (Advanced NEON SIMD) implementation of ChaCha20.
- Common: Fixed rare premature finalization of a buffer in SSPI interop that might lead to an AccessViolationException.
- Common: Improved internal asynchronous infrastructure.
- Released
- January242022
R6.2 #
(version 6.0.8060 from 2022-01-24)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- Networking: Fixed timeout handling during name resolution.
- TLS Core: Fixed handling of TLS 1.3 signature_algorithms_cert extension.
- TLS Core: Optimized temporary object usage in TLS 1.3 Send/Receive metods.
- Cryptography: Fixed releasing of CNG handles in AES/GCM interop (issue only present in R6.1 on Windows).
- Released
- January082022
R6.1 #
(version 6.0.8044 from 2022-01-08)
Maintenance release
This is a maintenance release that brings several enhancements and resolves some issues.
Detailed list of changes:
- All: Fixed compatibility of Rebex binaries for .NET Framework 4.0 with ASP.NET 4.5 or higher.
- TLS Core: Optimized receive operation in TLS 1.3.
- TLS Core: Slight optimizations in TLS 1.3 on modern platforms.
- Cryptography: Caching of CNG algorithm provider handles.
- Cryptography: Fixed Certificate.​GetSignatureHashAlgorithm() for certificates signed by Ed25519 authorities.
- Cryptography: Fixed unmanaged resource leak in CertificateStore.
- Cryptography: Optimized symmetric branch of Windows CNG (BCrypt) interop layer.
- Released
- November252021
R6.0 #
(version 6.0.8000 from 2021-11-25)
Support for .NET 6.0!
This release adds a new set of binaries targeting .NET 6.0. It supports all .NET 6.0 platforms:
- Windows (x64, x86, ARM64)
- Linux (x64, ARM32, ARM64)
- macOS (x64)
Please note that support for Android and iOS/tvOS in .NET 6.0 is still in preview mode. We will fully support these platforms as soon as the corresponding .NET 6.0 update is published.
Support for Visual Studio 2022
All Rebex libraries are now fully supported in Microsoft Visual Studio 2022.
Removed deprecated APIs
In this major release, we removed some APIs that have been deprecated for a very long time and seldom used. We will publish an article soon detailing these changes. In the meantime, if this affects you, please keep using release R5.7, and let us know. (R5.x will be supported until 2023-10-10.)
Support for ECDSA X.509 certificates in SSH
Added support for 'x509v3-ecdsa-sha2-nistp256', 'x509v3-ecdsa-sha2-nistp384' and 'x509v3-ecdsa-sha2-nistp521' SSH host key and client key algorithms (as specified by RFC 6187).
Updated default settings
We changed default values of some settings. For example, UTF-8 is now ubiquitous, so it makes sense to prefer it by default. Of course, you can still revert the corresponding settings to previous values.
Detailed list of changes:
- All: Added a new set of binaries targeting .NET 6.0.
- All: Removed several obsolete and deprecated APIs.
- All: Removed support for legacy ISerializable interface from binaries for .NET Standard.
- SFTP: Added Settings.EnableChecksumVerification option.
- SFTP: Changed default value of Sftp.Encoding to UTF-8.
- SCP: ScpSettings.​EnablePutFilesRemotePathWorkaround set to 'false' by default.
- SSH: Added support for SSH key algorithms based on ECDSA X.509 certificates (RFC 6187).
- Released
- November242021
R5.7 #
(version 5.0.7999 from 2021-11-24)
Support for .NET 6.0 and Windows 11
Windows 11 is now a supported platform.
Rebex assemblies targeting .NET Standard 2.1 now support .NET 6.0.
Support for PuTTY PPK3 key format
SshPrivateKey
class, PrivateKeyInfo
class and Certificate.SavePrivateKey
method now support PuTTY's new
PPK version 3 private key format.
Support for 'x509v3-rsa2048-sha256' SSH cipher
Added support for 'x509v3-rsa2048-sha256' SSH host key and client key algorithm (X.509 certificate with RSA key, as specified by RFC 6187).
Improved Deflate compression performance
Deflate compression performance has been improved (mostly on modern platforms). This improves performance of SSH layer (when compression is enabled).
Detailed list of changes:
- All: Added support for .NET 6.0 on Windows, Linux and macOS.
- All: Added support for Windows 11.
- SSH: Added support for PuTTY PPK3 format to SshPrivateKey.
- SSH: Added support for 'x509v3-rsa2048-sha256' SSH key algorithm (RSA X.509 certificates, RFC 6187).
- SSH: Added workaround for a server with broken SSH window size handling logic.
- SSH: Fixed handling of oversized data packets from servers with broken window size.
- TLS Core: Improved TLS 1.3 performance.
- Cryptography: Added more values to X.509 RevocationReason enum.
- Cryptography: Added support for private keys in PuTTY PPK3 format (uses Argon2 key derivation function).
- Cryptography: Added workaround for Google's CRLs with non-constructed explicit ASN.1 nodes.
- Released
- October262021
R5.6 #
(version 5.0.7970 from 2021-10-26)
Support for .NET 6.0 RC2
Rebex assemblies targeting .NET Standard 2.1 have been fully tested on .NET 6.0 RC2 and are suitable to be used in production on Microsoft's latest .NET platform ahead of the official release.
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
Detailed list of changes:
- All: Added support for .NET 6.0 RC2.
- SCP: Fixed compatibility of legacy Scp class with recent OpenSSH releases.
- TLS Core: Fixed possible NullReferenceException in TLS 1.2 socket after it has been closed.
- TLS Core: Improved handling of exceptions in TlsSocket.Send method.
- Cryptography: Fixed handling of RSAParameters without DP/DQ in AsymmetricKeyAlgorithm and PrivateKeyInfo.
- Cryptography: Fixed loading of encrypted keys with empty passwords in new OpenSSH format.
- Cryptography: Small optimization in AVX2 implementation of ChaCha20.
- Released
- August172021
R5.5 #
(version 5.0.7900 from 2021-08-17)
New binaries for .NET Core 3.1
We added a new set of binaries targeting .NET Core 3.1. We have already been supporting that platform since 2019 via .NET Standard 2.1. However, the new set of binaries utilizes .NET Core's hardware intrinsics API and features our fast ChaCha20/Poly1305 implementation that has been previously only available on .NET 5.0.
For an overview of available binaries and supported platforms, check out Rebex Support Lifecycle KB article.
Detailed list of changes:
- All: Added 'netcoreapp3.1' binaries.
- All: Fixed compatibility with UWP and .NET Native compiler.
- Released
- August052021
R5.4 #
(version 5.0.7888 from 2021-08-05)
Maintenance release
This release improves SFTP error reporting and resolves several issues in the shared functionality.
Detailed list of changes:
- SFTP: SFTP v4 error code are interpreted as unknown error in SFTP v3.
- Networking: Fixed casing in 'Basic' HTTP proxy authorization header.
- TLS Core: Fixed parsing of TLS 1.3 Certificate handshake message spanning multiple records.
- Cryptography: Fixed Certificate.FriendlyName setter in .NET 5.0 on non-Windows platforms.
- Released
- June182021
R5.3 #
(version 5.0.7840 from 2021-06-18)
Fixed FIPS-mode detection in .NET 4.8
This release fixes an issue in FIPS-mode detection routine that was not working properly in applications targeting .NET Framework 4.8 due to a change in the framework's behavior. This only affects applications targeting .NET Framework 4.8. Applications targeting earlier framework versions do not suffer from this issue even when running on .NET Framework 4.8.
If your application targets .NET Framework 4.8 and is supposed to honor system-wide FIPS mode settings, either upgrade to this release,
or set Rebex.Security.Cryptography.CryptoHelper.UseFipsAlgorithmsOnly
to System.Security.Cryptography.CryptoConfig.AllowOnlyFipsAlgorithms
in your application's startup code.
Detailed list of changes:
- SSH: Fixed race condition in OpenSSH-style compression startup code (occasionally caused connection failures during authentication with SSH compression was enabled).
- TLS Core: Added SslSettings.​SetPreferredSuites/​GetPreferredSuites methods to make it possible to specify client-side TLS cipher preference.
- TLS Core: Improved logging when remote party does not support TLS 1.3.
- TLS Core: Optimized TlsSocket.Negotiate method when TLS 1.3 is enabled but not supported by the remote side.
- TLS Core: Prevented 'unobserved' exceptions in task-based TLS 1.2 core.
- Cryptography: Added support for private keys using PBKDF2 with HMAC/SHA-2 (RFC 8018 / PKCS #5 v2.1).
- Cryptography: Fixed detection of FIPS-only systems on .NET Framework 4.8.
- Cryptography: Optimized creation of algorithm objects in CNG layer.
- Released
- May092021
R5.2 #
(version 5.0.7800 from 2021-05-09)
New ChaCha20Poly1305 class
This release features the new ChaCha20Poly1305
class that implements the 'combined mode' AEAD cipher
consisting of ChaCha20 stream cipher and Poly1305 authenticator,
as specified by RFC 7539.
Improved performance of AES/CTR ciphers in SSH
AES/CTR is now faster on all platforms.
Faster ChaCha20/Poly1305 on older platforms
We further improved performance of ChaCha20/Poly1305 in TLS and SSH on older platforms. It's not as fast as our .NET 5.0 implementation using AVX2 or Advanced NEON SIMD, but it's faster than ever before.
Detailed list of changes:
- Networking: Added support for SOCKS5 servers that respond with domain name.
- SSH: Optimized usage of ChaCha20/Poly1305 in SSH.
- Cryptography: Added ChaCha20Poly1305 class that implements ChaCha20/Poly1305 with an API that resembles .NET's AesGcm class.
- Cryptography: Added support for loading of ECDSA certificates from PFX/P12 files in .NET 5.0 and .NET Standard 2.1 on Linux and macOS.
- Cryptography: Added support for saving to PFX/P12 files for certificates with temporarily associated private keys in .NET 5.0 and .NET Standard 2.1 on Linux and macOS.
- Cryptography: AVX2 implementation of ChaCha20 releases old pre-generated keystream immediately after reinitialization.
- Cryptography: Clearing output data in AesGcm class when authentication tag is invalid.
- Cryptography: Fixed parsing of Cryptographic Message Syntax envelopes with unsupported OIDs.
- Cryptography: Improved ChaCha20/Poly1305 performance on .NET 3.5-4.6 and .NET Standard 2.x.
- Cryptography: Improved performance of AES/CTR ciphers (used in SSH).
- Common: Improved error handling when raising events via synchronization context.
- Released
- March032021
R5.1 #
(version 5.0.7733 from 2021-03-03)
Simplified release naming
We decided to drop the year from our release naming scheme. Instead of '2020 R5.1', this release is called just 'R5.1', and the forthcoming releases will use the same 'R5.x' naming scheme until the next major upgrade.
Faster ChaCha20/Poly1305 in .NET 5.0
By utilizing AVX2 (on Intel/AMD) or Advanced NEON SIMD (on ARM) via .NET's new hardware intrinsics API in .NET 5.0, we made our ChaCha20/Poly1305 implementation in SSH and TLS much faster. On ARM64, ChaCha20/Poly1305 is now even faster than Windows native AES/GCM.
This release improves ChaCha20/Poly1305 performance on older platforms as well, although not by such a big margin.
Detailed list of changes:
- All: Changed release naming scheme ('R5.1' instead of '2020 R5.1').
- Networking: Added workaround for rare WSAEWOULDBLOCK error on Mono in Socket.Connect.
- Networking: More meaningful exception is throw when attempting to use HTTP CONNECT proxy with NTLM authentication on platforms that don't support it.
- Networking: Optimized timeout infrastructure in ProxySocket.Connect.
- SSH: Added workaround for WingFTPServer server that uses 'ssh-rsa' with SHA-2 when client announces RSA/SHA-2 support.
- SSH: Fixed format of SshPublicKey.GetPublicKey() response for public keys initialized from PublicKeyInfo or AsymmetricAlgorithm.
- SSH: Fixed handling of unknown channel requests (not sending reply if not requested).
- TLS Core: Added VerifyMessage signature algorithm logging in TLS 1.3.
- TLS Core: Close/Dispose method called on TLS 1.3 socket ensures that all outstanding IO operations are canceled before the control is returned to the caller.
- TLS Core: Fixed possible rare NullReferenceException when closing TLS 1.3 session.
- TLS Core: Synchronous methods on TlsSocket wrap TaskCanceledException to TlsException.
- Cryptography: Added workaround to Certificate.LoadDer method to enable loading of certificates in PKCS #7 containers.
- Cryptography: Enhanced implicit operator for conversion of Certificate->X509Certificate2 to retain private keys on non-Windows platforms as well.
- Cryptography: Fixed Ed25519 PKCS #8 key structure (now compatible with OpenSSL).
- Cryptography: Optimized memory usage in symmetric encryption transformations based on Windows CNG API.
- Cryptography: Substantial speed-up of ChaCha20/Poly1305 (used in SSH and TLS). Utilizing AVX2 or Advanced NEON SIMD on .NET 5.0 (if available).
- Common: Accelerated common byte array operations in .NET 5.0 on devices with AVX2 support.
- Released
- November102020
2020 R5 #
(version 5.0.7620 from 2020-11-10)
Support for .NET 5.0!
This release adds a new set of binaries targeting .NET 5.0. It supports all .NET 5.0 platforms:
- Windows (x64, x86, ARM64)
- Linux (x64, ARM32, ARM64)
- macOS (x64)
Built-in Ed25519 support
We have already been supporting Ed25519 (EdDSA on edwards25519 curve) in SSH for several years,
but an external plugin was needed to make it work.
That is no longer case, and ssh-ed25519
SSH cipher works out-of-the-box.
New AES/GCM API
Our new Rebex.Security.Cryptography.AesGcm
class resembles .NET 5.0's class of the same name,
but it's available on all supported platforms including .NET Framework 3.5/4.0 and Mono 5/6.
Detailed list of changes:
- All: Added support for .NET 5.0 on all platforms.
- TLS Core: Added support for X.509 certificates with Ed25519 keys to TLS 1.3.
- TLS Core: Improved exception messages in TLS 1.3.
- Cryptography: Added built-in support for Ed25519 algorithm.
- Cryptography: Added Rebex.Security.Cryptography.AesGcm class (equivalent to .NET 5.0's AesGcm class, but available on all platforms including .NET Framework 3.5).
- Cryptography: Added SetOtherNames/GetOtherNames methods to CertificateInfo class ('Other Name' support in SANs).
- Cryptography: AsymmetricKeyAlgorithm.ImportKey method can initialize Ed25519 key from seed (in addition to private key).
- Cryptography: AsymmetricKeyAlgorithm.Register method made thread-safe.
- Cryptography: Deprecated CryptoHelper.ForceManagedAes property.
- Cryptography: Enhanced compatibility with unsupported legacy versions of CryptoAPI.
- Cryptography: Enhanced SignedData.Load(Stream) and EnvelopedData.Load(Stream) methods to support Base64-encoded format (PEM) as well.
- Cryptography: Enhanced workaround for RSA CSPs with lack of SHA-2 support.
- Common: Added SspiAuthentication.IsSupported method.
- Common: Enhanced EncodingTools helper class to always provide Encodings with implemented HeaderName, EncodingName and BodyName properties.
- Released
- September302020
2020 R4 #
(version 5.0.7579 from 2020-09-30)
Fully tested on .NET 5.0 RC1
Rebex assemblies targeting .NET Standard 2.1 have been fully tested on .NET 5.0 RC1 and are suitable to be used in production on Microsoft's latest .NET platform.
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
Detailed list of changes:
- All: Fixed several minor compatibility issues on .NET 5.0 RC1.
- Networking: Restored missing NetworkSession.InstanceId property.
- TLS Core: Fixed concurrent access in server-side TLS session cache.
- TLS Core: Fixed normalization of premaster secret in server-side ECDH calculations in TLS 1.2 and earlier.
- TLS Core: Updated TlsCipherSuite.Secure/Weak/Fast enum values. Updated TlsParameters.AllowedSuite default.
- Cryptography: Added Ed25519 support to Certificate class. (Not yet supported by the built-in certificate validator due to lack of support in Windows and .NET).
- Cryptography: Fixed handling of non-content data in Certificate(byte[]) constructor and CertificateChain.LoadP7b(Stream) / CertificateRevocationList.​Load(Stream) methods.
- Cryptography: Fixed parsing of constructed primitive ASN.1 types with more than two layers of nesting.
- Cryptography: Fixed version number in PKCS #10 CertificationRequest structure.
- Cryptography: Prohibited usage of Chacha20/Poly1305 in TLS 1.3 in FIPS-only mode. (Already prohibited in TLS 1.2 or earlier.)
- Cryptography: Updated RSAManaged constructor logic to make it suitable as a base for derived classes on .NET Framework in FIPS-compliant mode.
- Cryptography: Using Windows CNG API for Diffie-Hellman parameter generation on Windows 10 and Windows Server 2016/2019.
- Common: Optimized internal cancellation infrastructure on old platforms.
- Common: Removed usage of BinaryFormatter which has been found to be insecure.
- Common: Updated EncodingTools.GetEncoding method to prefer encodings provided by .NET.
- Released
- July142020
2020 R3 #
(version 5.0.7501 from 2020-07-14)
Binaries for .NET Standard 2.1
We added a new set of binaries targeting .NET Standard 2.1. They are suitable for .NET Core 3.1 and .NET 5.0 Preview 6, on Windows, Linux and macOS.
For an overview of available binaries and supported platforms, check out Rebex Support Lifecycle KB article.
Detailed list of changes:
- All: Added binaries targeting .NET Standard 2.1.
- SFTP: Added workaround for misbehaving SSH_FXP_STAT on DataPowerSSH servers (SftpSettings.​EnableBrokenDirectoryStatWorkaround option).
- SSH: Enhanced legacy group exchange autodetection.
- TLS Core: Added TlsSocket.ApplicationProtocol property to make it possible to determine protocol negotiated using ALPN extension.
- TLS Core: Always preferring RSA/SHA-2 for client certificate authentication in TLS 1.2.
- TLS Core: Disabled ciphers based on AES/CBC and SHA-2 in legacy versions of TLS (they are only specified by TLS 1.2).
- TLS Core: Fixed availability of TLS 1.3 session tickets (client side).
- TLS Core: Fixed handling of multiple concurrent Receive or Send method calls in TLS 1.3.
- TLS Core: Fixed handling of TLS 1.3 KeyUpdate handshake message.
- TLS Core: Fixed server name handling for TlsSocket instances created from an already-connected Socket.
- TLS Core: Fixed TlsException.Status to return ConnectionClosed for connection-closed errors.
- TLS Core: Fixed TlsException.Status to return Timeout for timeout errors.
- TLS Core: Fixed TlsSocket.ClientCertificate that returned an empty chain instead of null in some scenarios.
- TLS Core: Improved error message when server certificate is rejected in TLS 1.3.
- TLS Core: Improved error messages in TLS 1.3.
- TLS Core: Logging improvements.
- TLS Core: No longer sending 'internal error' alert to remote end on timeout.
- TLS Core: Optimized TLS 1.3 internals.
- TLS Core: TLS 1.3 initiates key update properly (before the AEAD limits are reached).
- TLS Core: Unified behavior of the Receive and ReceiveAsync methods across TLS versions.
- Cryptography: Fixed encoding of ECDSA signatures in PKCS #7 CertificationRequest structure.
- Cryptography: Memory usage optimizations in CNG layer.
- Cryptography: On Windows 10 and Windows Server 2016 or higher, Windows CNG API is used for classic Diffie-Hellman calculations instead of legacy Windows CryptoAPI.
- Cryptography: Optimized disposing of temporary keys in Certificate class.
- Released
- May242020
2020 R2 #
(version 5.0.7450 from 2020-05-24)
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
Detailed list of changes:
- SSH: Added new properties to SshCipher to make it possible to determine IDs of active ciphers.
- SSH: Added workaround for a weakness in legacy CBC ciphers.
- TLS Core: Enhanced TlsSocket.Timeout property to apply to subsequent Send, SendAsync, Receive and ReceiveAsync methods even when TLS is already active.
- TLS Core: Fixed availability of TLS 1.3 session ticket when the receive side of the connection has already been closed.
- TLS Core: Fixed behavior of server-side DoNotCacheSessions option (which previously led to connection failures).
- TLS Core: Fixed some cases of missing AggregateException unwrapping.
- TLS Core: Improved and unified behavior of TlsSocket Shutdown/ShutdownAsync methods when negotiation has not been started.
- TLS Core: Improved TLS exception reporting.
- TLS Core: Logging improvements.
- TLS Core: Optimizations in TLS 1.3 internals.
- TLS Core: Support for the TLS 1.3 record with empty application data payload and random padding.
- TLS Core: Unified TlsSocket.Cipher property behavior across TLS versions.
- Cryptography: Added ContentInfo.ToStream() method.
- Cryptography: Enhanced Certificate.LoadDerWithKey to support RSASSA-PSS and RSAES-OAEP for RSA keys.
- Cryptography: Fixed AsymmetricKeyAlgorithm.​GenerateDiffieHellmanParameters slowness (only affected the previous release).
- Cryptography: Improved AsymmetricKeyAlgorithm to support RSASSA-PSS and RSAES-OAEP with keys loaded via ImportKey method.
- Cryptography: Optimized Certificate and CertificateChain class to only consume native resources when needed.
- Cryptography: Optimized CNG handles cleanup.
- Released
- March252020
2020 R1.1 #
(version 5.0.7390 from 2020-03-25)
Reintroducing fast Diffie-Hellman on Xamarin.Android
Until 2019 R4.2, Rebex binaries for Xamarin.Android platforms used Android's cryptographic API for Diffie-Hellman calculations. However, this functionality is no longer available in current Rebex binaries targeting Xamarin.Android via .NET Standard 2.0. To make it possible to use the faster Diffie-Hellman implementation on Xamarin.Android again, we have added it to our native extensions library. Once enabled, it will make Diffie-Hellman key exchange in SSH as fast on Xamarin.Android as before.
Detailed list of changes:
- SFTP: Fixed an issue in GetItems() method that caused file system items with an unknown type to not be filtered according to the specified mask.
- Networking: Fixed rare race condition in TLS and SSH internals.
- TLS Core: Fixed breaking changes in the behavior of seldom-used parts of TlsSocket API.
- TLS Core: Fixed handling of OperationCanceledException in TLS 1.3 core.
- TLS Core: Improved TLS logging.
- Common: Added DiffieHellmanNative class to Rebex.Common.Native assembly (speeds up Diffie-Hellman calculations on Xamarin.Android).
- Released
- February212020
2020 R1 #
(version 5.0.7357 from 2020-02-21)
.NET Standard 2.0 on Xamarin.Android and Xamarin.iOS
Rebex binaries targeting .NET Standard 2.0 are now supported on Xamarin.Android and Xamarin.iOS. Previously-available binaries targeting specific Xamarin platforms have been deprecated, and .NET Standard 2.0 binaries should be used instead.
Note: Applications that require certificate validation
also need to use the new Rebex.Common.Native.dll
assembly which provides
validation of X.509 certificates on Xamarin.Android and Xamarin.iOS.
Native X25519 elliptic curve support on Windows 10
On Windows 10, Windows Server 2016 and Windows Server 2019, Rebex libraries using ECDH key exchange in TLS or SSH now support X25519 curve (also known as Curve25519) without any external plugins.
Better Elliptic Curve Diffie-Hellman support on Windows 10
On Windows 10, Windows Server 2016 and Windows Server 2019, Rebex libraries now fully supports ECDH key exchange without having to rely on external plugins and workarounds.
End of Standard Support for .NET Framework 2.0 and 3.0
2019 R4.2 was the last release to include support for .NET Framework 2.0 and 3.0 in the standard package. Customers using these platforms are advised to migrate to .NET Framework 3.5 SP1, which will enjoy mainstream support until 2023-10-10.
For customers who are unable to migrate, a Legacy Edition of Rebex libraries for .NET Framework 2.0/3.0 is available.
Deprecated .NET Core 1.0/1.1
.NET Core 1.1 and 1.0 became end-of-life platforms at 2019-06-27. In accordance with our framework support policy, they are no longer supported by Rebex libraries. Customers using these platforms are advised to migrate to .NET Core 2.1 or .NET Core 3.1.
Detailed list of changes:
- All: Binaries targeting .NET Standard 2.0 now support Xamarin.Android and Xamarin.iOS.
- All: Deprecated binaries targeting .NET Standard 1.5, Xamarin.Android and Xamarin.iOS.
- All: Fixed several occurences of culture-sensitive string formatting.
- All: Fixed several occurrences of wrong synchronization context.
- All: Mainstream edition no longer supports .NET Framework 2.0/3.0 and .NET Core 1.0/1.1.
- SFTP: Fixed handling of symbolic link source paths in non-recursive multi-file operation.
- SFTP: Unified GetConnectState() behavior across platforms.
- SSH: Added full support for Elliptic Curve Diffie-Hellman (ECDH) on Windows 10, Windows Server 2016 and Windows Server 2019.
- SSH: Added support for 'curve25519-sha256' key exchange cipher (equivalent to already-supported 'curve25519-sha256@libssh.org').
- SSH: Enhanced performance of ChaCha20-Poly1305 cipher ('chacha20-poly1305@openssh.com') in SSH client.
- SSH: Fixed possible deadlock in SSH client when processing incoming EOF packet while waiting for remote receive buffer size to increase.
- TLS Core: Added asynchronous methods to TlsSocket base class.
- TLS Core: Added SetSymmetricCipherSuites/​GetSymmetricCipherSuites methods to configure enabled TLS 1.3 cipher suites.
- TLS Core: Added support for ChaCha20-Poly1305 cipher suites to TLS 1.3 and 1.2.
- TLS Core: Fixed behavior of TlsSocket methods after Dispose has been called.
- TLS Core: Fixed behavior of TlsSocket.Shutdown.
- TLS Core: Improved argument checks in TlsSocket base class.
- TLS Core: Improved multi-pass parsing of the TLS 1.3 records.
- TLS Core: Many optimizations in TLS 1.3 core.
- Cryptography: Added full support for Elliptic Curve Diffie-Hellman (ECDH) on Windows 10, Windows Server 2016 and Windows Server 2019.
- Cryptography: Added native support for ECDH with X25519 curve on Windows 10, Windows Server 2016 and Windows Server 2019.
- Common: Internal optimizations.
- Released
- January152020
2019 R4.2 #
(version 5.0.7320 from 2020-01-15)
Maintenance release
This release solves several issues in the shared functionality.
Detailed list of changes:
- SSH: Fixed possible deadlock during SSH renegotiation (client-side).
- TLS Core: Fixed renegotiation in TLS 1.2 (has been broken since 2019 R4).
- Cryptography: Added workaround for RSA signatures shorter than the key size (.NET Core on Linux is unable to handle them).
- Cryptography: Fixed AsymmetricKeyAlgorithm.​GetRawPublicKey() key format when RSA via MS CNG is in use.
- Cryptography: Only known external plugins are allowed for enhanced security.
- Cryptography: Saving public key as well when saving X25519 private keys.
- Released
- December162019
2019 R4.1 #
(version 5.0.7290 from 2019-12-16)
.NET Core 3.1 support
.NET Core 3.1 is now supported on the following platforms:
- Windows (x64, x86, ARM32)
- Windows 10 IoT (x64, x86, ARM32)
- Linux (x64, ARM32)
- macOS (x64)
Detailed list of changes:
- All: Added support for .NET Core 3.1.
- All: Added support for Mono 6.x.
- SFTP: Fixed a possible deadlock when adjusting SSH channel window size during SSH renegotiation.
- Networking: Added missing 'buffer' argument check to some Send/Receive methods in ProxySocket/TlsSocket.
- Networking: Fixed unhandled ObjectDisposedException or misleading SocketException when ProxySocket.Connect aborted due to timeout.
- SSH: Added a workaround for a bug introduced in OpenSSH 8.0 that rejects 'sender channel' numbers in the upper half of uint32 range.
- SSH: Added SshEncryptionMode.AEAD (to replace SshEncryptionMode.GCM).
- SSH: Added support for ChaCha20-Poly1305 AEAD cipher ('chacha20-poly1305@openssh.com') to SSH client.
- TLS Core: Added support for RSASSA-PSS signatures in TLS 1.2 when TLS 1.3 has been enabled.
- TLS Core: Avoid unwanted truncation of outgoing TLS 1.3 messages when TlsSocket is disposed.
- TLS Core: Enhanced error message when no suitable curve is available.
- TLS Core: Fixed compatibility issue with Xamarin's "Sdk Assemblies Only" option.
- TLS Core: Fixed exception type to TlsException for TLS 1.3 errors.
- TLS Core: Fixed handling of TLS 1.3 PSK-KE.
- TLS Core: Fixed check of signature algorithm in TLS 1.3 CertificateVerify.
- TLS Core: Fixed occasional failure when negotiating TLS 1.2 or lower when TLS 1.3 is allowed.
- TLS Core: Fixed order of supported signature schemes in TLS 1.3 ClientHello message.
- TLS Core: Fixed parsing of fragmented TLS 1.3 handshake messages.
- TLS Core: Fixed parsing of the TLS 1.3 KeyShare extension.
- TLS Core: Fixed potential NullReferenceException when TLS 1.3 negotiation has been interrupted unexpectedly.
- TLS Core: Fixed selection of signature algorithm used in CertificateVerify handshake messages.
- TLS Core: Not announcing support for X.509 certificates with Ed25519 or RSASSA-PSS public key OID (not supported yet).
- TLS Core: Optimizations in TLS 1.3 internals.
- Cryptography: Added workaround for bad RSA/PSS signature algorithm identifiers with missing parameters.
- Cryptography: Enabled workaround for private key loading from Mono key store in .NET Standard edition on Mono.
- Cryptography: Enhanced 'Invalid key format' error message when loading a private key.
- Cryptography: Fixed serial number handling in CertificateIssuer to conform to RFC 5280 constraints.
- Common: Binaries for .NET Standard 1.5 now use System.Collections.NonGeneric instead of custom implementations.
- Common: Enabled Xamarin.Android workarounds in .NET Standard 2.0 edition.
- Common: Improved ISafeSerializationData support detection.
- Released
- October312019
2019 R4 #
(version 5.0.7244 from 2019-10-31)
Enhancement release
This release brings several enhancements and improvements, mostly in the shared functionality.
Detailed list of changes:
- SFTP: Improved behavior of stream-based PutFile methods with DisableProgressPercentage (stream length is no longer determined).
- TLS Core: Added support for ALPN TLS extension to TlsSocket.
- TLS Core: Added TlsBulkCipherMode.AEAD (to replace TlsBulkCipherMode.GCM).
- TLS Core: Removed support for two legacy unsecure anonymous ciphers (DH_anon_EXPORT_WITH_DES40_CBC_SHA and DH_anon_EXPORT_WITH_RC4_40_MD5).
- Cryptography: Added PkcsBase.LoadSignedOrEnvelopedData method (a replacement for deprecated PkcsBase.Load).
- Released
- September232019
2019 R3.2 #
(version 5.0.7206 from 2019-09-23)
.NET Core 3.0 support
This release introduces support for .NET Core 3.0 on the following platforms:
- Windows (x64, x86, ARM32)
- Windows 10 IoT (x64, x86, ARM32)
- Linux (x64, ARM32)
- macOS (x64)
Windows 10 IoT support
This release introduces support for .NET Core 3.0 on Windows 10 IoT on x64, x86 and ARM32 platforms.
Detailed list of changes:
- All: Added support for .NET Core 3.0.
- All: Added support for Windows 10 IoT (via .NET Core 3.0).
- SFTP: Added Settings.​PreferInteractiveAuthentication option (prefer 'keyboard-interactive' to 'password' authentication).
- SCP: Added Settings.​PreferInteractiveAuthentication option (prefer 'keyboard-interactive' to 'password' authentication).
- SSH: Added SshGssApiCredentials.AccountName property to make it possible to specify an account name to be passed to the SSH server.
- SSH: Added workaround for legacy WS_FTP 7.x servers that encode long SSH packets improperly.
- SSH: Fixed SshChannel.SendEof method not to send EOF when channel has already been closed.
- Common: Optimized internal Task infrastructure on old .NET platforms.
- Released
- August092019
2019 R3.1 #
(version 5.0.7161 from 2019-08-09)
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
Detailed list of changes:
- All: Added support for serialization on Xamarin.Android and Xamarin.iOS platforms.
- SFTP: Improved logging of single-item SSH_FXP_NAME responses.
- TLS Core: Modified TlsVersion.Any to only include TLS 1.0, 1.1 and 1.2.
- Cryptography: Fixed handling of user-supplied RSACng in AsymmetricKeyAlgorithm and SshPrivateKey on modern platforms.
- Released
- June282019
2019 R3 #
(version 5.0.7119 from 2019-06-28)
Support for .NET Standard 2.0 on Mono 5.14 and higher
Binaries of Rebex libraries targeting .NET Standard 2.0 are now also supported on Mono 5.14 and higher.
End of Standard Support for .NET Compact Framework 3.5 and 3.9
2019 R3 is the last release that includes support for .NET Compact Framework 3.5 and 3.9 in the standard package. Starting with 2019 R4, .NET CF 3.5/3.9 will only be supported with Legacy Editions, which will be available as separate products. See their release history.
Detailed list of changes:
- All: Binaries targeting .NET Standard 2.0 are now supported on Mono 5.14 or higher.
- SFTP: Fixed Sftp.KeepAlive() to update State and IsConnected properties on failure.
- SSH: Added SshPrivateKey.Generate(...) methods on .NET Compact Framework.
- SSH: Added workaround for broken EtM ciphers in OpenSSH 6.6.
- SSH: Enhanced GlobalScape SSH server detection.
- SSH: Enlarged upper limit for non-standard DSA keys to 8192 bits on .NET Framework and .NET Core.
- SSH: Fixed reporting of SSH_MSG_USERAUTH_GSSAPI_ERROR and SSH_MSG_USERAUTH_GSSAPI_ERRTOK responses.
- TLS Core: Added TlsCipherSuite.Fast enum value.
- TLS Core: Fixed a bug in server-side mode of TlsSocket that caused client certificate authentication to fail.
- TLS Core: Internal changes in the TLS layer (in preparation for the upcoming TLS 1.3 support on mainstream platforms).
- Cryptography: Added Certificate.GetPrivateKeyInfo() method.
- Cryptography: Added CertificateEngine.LocalMachine engine and CertificateEngine.Bind method.
- Cryptography: Added support for SHA-224 hash algorithm.
- Cryptography: Added support for X25519 key format (RFC 8410).
- Cryptography: Always using AES by default to encrypt PKCS #8 private keys.
- Cryptography: Meaningful error message for the CNG AEAD auth tag mismatch.
- Common: Optimized asynchronous continuations on modern platforms.
- Common: Upgraded Task infrastructure in Xamarin.Android binaries.
- Released
- May172019
2019 R2 #
(version 5.0.7077 from 2019-05-17)
Support for Visual Studio 2019
All Rebex libraries are now fully supported in Microsoft Visual Studio 2019.
Support for .NET Framework 4.8
.NET Framework 4.8 is a fully supported platform.
Native elliptic curve cryptography on Linux with .NET Core 2.1 or higher
On Linux, binaries for .NET Standard 2.0 now utilize OpenSSL elliptic curve routines via .NET Core 2.1 (or higher), making it possible to use ECDH and ECDSA ciphers in TLS/SSL and SFTP/SSH with no need of external plugins.
Detailed list of changes:
- All: Added support for .NET Framework 4.8 and Visual Studio 2019.
- All: Removed leftover Trace.Write logging.
- SSH: Added dummy support for SSH_MSG_EXT_INFO (RFC 8308).
- Cryptography: Added CertificationRequest.Save method.
- Cryptography: Added support for ECDSA and ECDH on .NET Core 2.1/.2.2 on Linux (no need for external plugins).
- Cryptography: Added workaround for broken export of RSA keys from the CNG providers on Windows 7.
- Cryptography: Added workaround for CRLs with redundant trailing data to CertificateRevocationList.
- Cryptography: Added workaround for legacy versions of Mono with lack of SHA-2 support.
- Common: Asynchronous infrastructure improvements.
- Released
- March282019
2019 R1 #
(version 5.0.7027 from 2019-03-28)
Improved platform support
This release adds three new sets of binaries targeting the following platforms:
- .NET Core 2.0/2.1/2.2 (via .NET Standard 2.0)
- .NET Framework 4.6.x/4.7.x
- .NET Framework 3.5 SP1
For an overview of available binaries and supported platforms, check out Rebex Support Lifecycle KB article.
API changes
In this release, we bumped the version to 5.0 and changed some parts of the API a bit. We removed parts of our API that have been deprecated for years, and we deprecated parts of our API that were considered outdated. Additionally, we made some missing methods available on Xamarin and .NET Standard 1.5 platforms as well.
These changes should only affect a minority of our users. If you are affected and need help, please contact us!
DSA deprecation in SFTP and SSH clients
Because DSA algorithm is now considered deprecated, we changed the preferred host key algorithm to RSA.
To revert to the previous behavior, set client.Settings.SshParameters.PreferredHostKeyAlgorithm
to SshHostKeyAlgorithm.DSS
.
MD5 deprecation in SshFingerprint
SshFingerprint
's ToString()
and ToArray()
methods
use SHA-256 now. To revert to previous behavior, specify SignatureHashAlgorithm.MD5
when calling these methods.
Optimized AES/GCM performance
Improved performance of AES/GCM ciphers in TLS and SSH protocols on .NET Compact Framework and non-Windows platforms.
Detailed list of changes:
- All: Added binaries targeting .NET Framework 3.5 SP1.
- All: Added binaries targeting .NET Framework 4.6 and higher.
- All: Added binaries targeting .NET Standard 2.0.
- All: Removed long-deprecated API. Deprecated legacy API.
- SFTP: Added SftpItemType.Fifo enum value.
- SFTP: Fixed SftpItem.Owner/Group properties that returned null (contrary to the documentation) when using SFTP v3.
- SFTP: GetItems() method changed to return items of unknown type instead of throwing an exception.
- Networking: Fixed passing of state to the callback method in ProxySocket.BeginConnect and TlsSocket.BeginConnect.
- SSH: Changed behavior of SshFingerprint.ToString() and .ToArray() to use SHA-256.
- SSH: Improved performance of AES/GCM ciphers on .NET Compact Framework and non-Windows platforms.
- SSH: RSA host keys are preferred to DSA host keys.
- SSH: SHA-512 is only used during SSH client authentication when the RSA key length allows it.
- SSH: SshParameters.MinimumRsaKeySize now applies to client RSA keys as well.
- SSH: Using standard form of Diffie-Hellman group exchange with GlobalScape servers.
- TLS Core: Fixed passing of state to the callback method in ProxySocket.BeginConnect and TlsSocket.BeginConnect.
- TLS Core: Improved performance of AES/GCM ciphers on .NET Compact Framework and non-Windows platforms.
- Cryptography: Fixed behavior of HMAC mode in KeyMaterialDeriver.​DeriveKeyMaterial method.
- Cryptography: Fixed garbage collection issue with PFX-based certificate keys on non-Windows platforms.
- Cryptography: Fixed handling of shared secred padding in AsymmetricKeyAlgorithm.​GetKeyMaterialDeriver.​
- Cryptography: Fixed possible NullReferenceException in CertificationRequest.​GetAlternativeHostnames method.
- Common: Fixed Certificate.Associate with permanent bind on .NET Compact Framework to ensure the key is not garbage-collected.
- Common: LocalItem constructor no longer fails on items with invalid paths.
- Released
- December212018
2018 R4 #
(build 6930 from 2018-12-21)
Support for yet another OpenSSH key encryption
Added support for new OpenSSH keys with AES-CTR encryption.
Detailed list of changes:
- Networking: ProxySocket and TlsSocket implement IDisposable now.
- Networking: Added workaround to ProxySocket for ObjectDisposedException in Socket.ConnectAsync on .NET Core for macOS.
- SSH: Enhanced legacy group exchange autodetection.
- SSH: Fixed handling of Ssh.Encoding property.
- SSH: Fixed SshPublicKey(PublicKeyInfo) constructor that only accepted RSA or DSA keys.
- SSH: Fixed Verbose logging of interactive authentication.
- SSH: Changed SshParameters.MinimumRsaKeySize from 1024 to 1023 bits.
- TLS Core: Improved server certificate usage check.
- TLS Core: Improved TLS logging.
- Cryptography: Added support for 'BEGIN RSA PUBLIC KEY' keys (PKCS #1 / RFC 3447) to PublicKeyInfo.
- Cryptography: Added support for IP addresses in Subject Alternative Name certificate extension.
- Common: Added support for new OpenSSH key format with AES-CTR encryption.
- Common: Fixed possible certificate validation failures on some versions of Xamarin.Android.
- Released
- October262018
2018 R3 #
(build 6874 from 2018-10-26)
Password-hiding in Verbose logging mode
Communication logs created with Verbose
level no longer contain authentication credentials,
which makes it more convenient and safer to share them with others.
Support for 'fsync@openssh.com' extension
Added support OpenSSH's fsync
extension that makes it possible to ensure that modified file data has been
written to disk. To enable this feature, use Sftp.Settings.EnableFileSync
property.
Added Sftp.CreateLink method
The new CreateLink
method supports both symbolic links and hard links. For hard-links,
the server must support OpenSSH's hardlink@openssh.com
extension.
Connection-establishing API for .NET CF
Added very simple connection-establishing API for .NET Compact Framework (Rebex.Net.ConnectionManagement
namespace).
Detailed list of changes:
- All: Added password-hiding in Verbose logging mode.
- All: Added experimental support for Mono on Windows.
- All: Fixed messages of some ObjectDisposedException objects.
- SFTP: Added support for 'fsync@openssh.com' SFTP extension (enable using Sftp.Settings.FileSyncOnUpload property).
- SFTP: Added Sftp.CreateLink method (needs 'hardlink@openssh.com' extension support to create hard links).
- SFTP: Fixed minor race condition in Dispose method.
- Networking: Added simple connection manager API on .NET Compact Framework (Rebex.Net.ConnectionManagement namespace).
- Networking: Report a meaningful error message when .NET Compact Framework's 'not a socket' issue is encountered.
- SSH: Added SshParameters.MaximumPacketSize property.
- SSH: Fixed Login not to block Dispose in Sftp, Scp and Ssh classes.
- SSH: Using UTF-8 at SSH protocol level by default in Sftp, Scp and Ssh classes.
- SSH: Added logging of SSH channel window size adjustments.
- SSH: Fixed decompression in encrypt-then-mac (EtM) MAC mode.
- TLS/SSL: TLS cipher suite being negotiated is logged as soon as possible.
- Cryptography: CertificateStore implements IEnumerable<Certificate>.
- Cryptography: Proper error is reported when trying to validate ECDSA certificates on Mono.
- Common: Added optimized thread pool on .NET Compact Framework.
- Released
- September032018
2018 R2.1 #
(build 6821 from 2018-09-03)
Enhancements and bugfixes
This is a maintenance release with several bugfixes and enhancements.
Detailed list of changes:
- SFTP: Fixed aborting of Sftp object's Connect method when Dispose method has been called.
- Networking: Added Proxy.HttpUserAgent property to make it possible to specify User-Agent for HTTP CONNECT proxies.
- Networking: ProxySocket methods now throw ObjectDisposedException when disposed.
- SSH: Fixed data buffering when raising SshChannel.ExtendedDataReceived event.
- Cryptography: Optimized certificate signature validation on .NET Compact Framework.
- Released
- June292018
2018 R2 #
(build 6755 from 2018-06-29)
New fully supported platform: .NET Core on macOS
This release adds full support for .NET Core 2.x on macOS.
Enhancements and bugfixes
Enhancements and bugfixes in the shared functionality.
Detailed list of changes:
- All: Added support for .NET Core on macOS.
- SFTP: Improved Sftp.GetList() logging.
- SFTP: Fixed Download() method for filenames starting with backslash on Unix-like servers.
- Networking: Closed ProxySocket objects throw more meaningful exception.
- SSH: Added support for additional formats to SshPublicKey.
- SSH: Fixed possible bug in SshPublicKey loading.
- SSH: Added SshPrivateKey.GetPrivateKeyInfo() method.
- TLS/SSL: Added SslSettings.​SslServerCertificateValidationOptions and SslCertificateValidationEventArgs.​Options properties.
- Cryptography: Added workaround for eToken CSP private key operations.
- Cryptography: Fixed possible 'Unexpected key algorithm' error in AsymmetricKeyAlgorithm.
- Cryptography: Fixed Certificate.​GetSignatureHashAlgorithm() for RSASSA-PSS certificates
- Cryptography: RSACryptoServiceProvider usability detection made more compatible.
- Cryptography: Fixed CertificateStore.Exists on .NET Core.
- Cryptography: Fixed Certificate.HasPrivateKey for non-silent keys.
- Cryptography: Fixed potential security vulnerability in RSAManaged class (proper padding check in signature verification).
- Common: Fixed compatibility with AWS Lambda.
- Released
- April252018
2018 R1.1 #
(build 6690 from 2018-04-25)
New fully supported platform: .NET Core on Linux
This release adds full support for .NET Core 2.x on Linux.
Detailed list of changes:
- All: Added support for .NET Core on Linux.
- SFTP: Added SftpListItemReceivedEventArgs.​UserState property.
- SSH: Fixed handling of invalid data packets claiming to contain more data than their payload length.
- TLS/SSL: Fixed error raising in TlsSocket's EndSend/EndReceive methods.
- Cryptography: Enhanced error message when trying to use signing-only RSA certificate for decryption.
- Cryptography: Fixed private key exporting on .NET Core on Linux.
- Cryptography: Fixed retrieval of certificate with bound keys from store on .NET Core on Linux.
- Cryptography: Fixed possible NullReferenceException in built-in custom certificate validator on .NET Compact Framework. Could occur using CRL validation.
- Cryptography: Fixed DSAManaged.ExportParameter method that failed to export parameters with missing Seed.
- Cryptography: Added CertificateEngine.​BuildChain(Certificate) method.
- Cryptography: Current CertificateEngine's BuildChain method is now used in CMS (PKCS #7) SignedData and EnvelopedData.
- Cryptography: Added Certificate.Tag property to make it possible to associate custom objects with a particular Certificate instance.
- Cryptography: Enhanced logging in built-in custom certificate validator on .NET Compact Framework.
- Released
- April012018
2018 R1 #
(build 6666 from 2018-04-01)
Additional SSH ciphers
Client-side SSH now supports AES/GCM ciphers and EtM MAC ciphers compatible with OpenSSH.
Detailed list of changes:
- SFTP: Added Sftp.Settings.CustomCommand property.
- SFTP: Added workaround for GlobalScape servers that have issues with long data blocks.
- SSH: Added support for AES/GCM ciphers ('aes128-gcm@openssh.com' and 'aes256-gcm@openssh.com') to SSH client.
- SSH: Added support for EtM MAC ciphers ('hmac-sha2-256-etm@openssh.com' and 'hmac-sha2-512-etm@openssh.com') to SSH client.
- TLS/SSL: Log deprecation warning when using SSL 3.0, which is disabled by default and should no longer be used at all.
- TLS/SSL: Added SslSettings.​SslRenegotiationExtensionEnabled option.
- TLS/SSL: Added SslSettings.​SslServerNameIndicationEnabled option.
- Cryptography: Added CryptographicCollection<T> as a base for cryptographic collection classes.
- Cryptography: Fixed possible NullReferenceException inCertificateRevocationList.​GetRevocationReason() method.
- Cryptography: Fixed PFX saving on Mono.
- Cryptography: Fixed "Unable to load DLL 'Bcrypt.dll'" error on Linux with .NET Core.
- Cryptography: Added EnhancedCertificateEngine to .NET Compact Framework version to make it possible to supply custom root certification authorities.
- Common: Enabled Certificate/​CertificateChain.​LoadPfx with AlwaysCng option on .NET Compact Framework 3.9.
- Common: Fixed rare race condition in possibly leading to NullReferenceException on .NET Core and UWP platforms.
- Common: Fixed COMException in CertificateChain.BuildFrom method on experimental UWP platform.
- Common: Built-in custom certificate validator on .NET CF no longer unnecessarily validates signature of root CA certificates that are trusted by the OS.
- Released
- January112018
2017 R6.3 #
(build 6586 from 2018-01-11)
Maintenance release
This is a maintenance release with enhancements in the shared functionality.
Detailed list of changes:
- Cryptography: Added support for RSAES-OAEP with input parameter (label).
- Cryptography: Added support for RSAES-OAEP with mismatched hash algorithms.
- Cryptography: Fixed initialization of EncryptionAlgorithm property in MailMessage.Recipients collection items.
- Cryptography: Added support for RSASSA-PSS with mismatched hash algorithms.
- Cryptography: Fixed CNG private key conversion workaround.
- Released
- December212017
2017 R6.2 #
(build 6565 from 2017-12-21)
Faster AES on Windows
Rebex libraries now use Windows CNG for AES symmetric encryption algorithm when available. CNG implementation of AES is faster and takes advantage of AES-NI instructions.
Checksum support in multi-file SFTP transfers
Sftp
object's Upload
and Download
methods support
ActionOnExistingFiles.OverwriteDifferentChecksum
, making it possible
to use SFTP's checksum and hashing functionality
to determine which files were changed.
Please note that this functionality is only supported by servers that implement the "file-check"
extension.
Detailed list of changes:
- SFTP: Added support for ActionOnExistingFiles.​OverwriteDifferentChecksum to Upload/Download methods.
- Networking: ProxySocket constructor requires a connected socket now.
- SSH: Added SshParameters.​UseLegacyGroupExchange option to make it possible to force using legacy or standard form of SSH Diffie-Hellman group exchange packet.
- SSH: Enhanced legacy group exchange autodetection.
- TLS/SSL: Fixed handling of duplicate suites in ClientHello packets.
- Cryptography: Added CertificateChain.LoadDer method to load a chain of Base64-encoded certificates.
- Cryptography: Fast CNG implementation of AES (which takes advantage of AES-NI instructions) is used when available.
- Cryptography: Added workaround for broken X509Certificate.GetPublicKey() on Mono 5.4.
- Cryptography: Added a workaround for GPG's gpgsm utility that required some SignedData fields to be DER-encoded.
- Released
- November202017
2017 R6.1 #
(build 6534 from 2017-11-20)
Remote file system information
Sftp
object now features GetFileSystemInfo
method,
which makes it possible to determine free space
and other information about a remote file system drive.
Please note that this functionality only works with servers that support
"space-available"
or statvfs@openssh.com
extension.
Native elliptic curve cryptography on Windows Embedded Compact 2013
Rebex libraries now use Windows CNG MS CNG API on .NET Compact Framework 3.9 / Windows Embedded Compact 2013, making it possible to use ECDH and ECDSA ciphers in TLS/SSL and SFTP/SSH with no need of external plugins.
Detailed list of changes:
- SFTP: Added Sftp.GetFileSystemInfo method to determine free space and other drive information.
- SFTP: Fixed a bug that caused the client not to ask for access time attribute in SFTP v4 (most servers sent the attribute despite this).
- SFTP: Added workaround for ProFTPd 1.3.6's mod_sftp which sends broken response when CREATETIME attribute has been requested.
- SSH: Added SshPublicKey.LoadPublicKeys method that supports loading OpenSSH's 'authorized_keys' files.
- Cryptography: Enhanced custom CRL downloader for .NET Compact Framework to handle all 3xx redirect codes.
- Cryptography: Enhanced Certificate.LoadDer to handle files with multiple certificates (loads the first one).
- Cryptography: Enabled usage of MS CNG API in .NET Compact Framework 3.9 edition on Windows Embedded Compact 2013 when appropriate.
- Cryptography: Fixed detection of AES/GCM support.
- Cryptography: Fixed detection of native Brainpool and secp256k1 support.
- Cryptography: Added 'params' to CertificateInfo.​SetExtendedUsave/​SetAlternativeHostnames methods.
- Cryptography: Fixed null handling in CertificateInfo.MailAddress.
- Cryptography: Fixed empty block processing in AES/GCM.
- Common: Added workaround for broken Encoding.ASCII encoder on legacy Mono platforms.
- Common: Enhanced SSPI error reporting.
- Common: Fixed platform info in logs on macOS.
- Released
- October252017
2017 R6 #
(build 6508 from 2017-10-25)
Maintenance release
This is a maintenance release with several improvements, bugfixes and workarounds.
Detailed list of changes:
- All: Added support for DSA key generation on .NET Core on Windows.
- SFTP: Fixed SFTP extension info parser (used to fail with some charsets).
- Networking: Fixed PortRange binding (an issue introduced in previous release).
- Networking: Fixed ReceiveBufferSize/SendBufferSize propagation (an issue introduced in previous release). This was observed to cause slowdown on Windows platform in some scenarios.
- Networking: Fixed handling of IP-based host names in proxy name resolving routine (an issue introduced in previous release).
- TLS/SSL: Added support for AES/GCM to TLS.
- TLS/SSL: Added TlsCipherSuite.Weak enum.
- Cryptography: Added support for RSAES-OAEP encryption to EnvelopedData/RecipientInfo objects (CMS / PKCS #7).
- Cryptography: Added support for RSAES-OAEP encryption to Encrypt/Decrypt methods in Certificate and AsymmetricKeyAlgorithm classes.
- Cryptography: Added support for DSA key generation on .NET Core 1.1 on Windows.
- Cryptography: Added support for RSASSA-PSS signatures to SignMessage/VerifyMessage methods in Certificate and AsymmetricKeyAlgorithm classes.
- Cryptography: Enhanced environment info logging.
- Cryptography: Fixed KeySize property of RSAManaged and DSAManaged to return the proper size for key sizes that are not evenly divisible by 8.
- Cryptography: Added support for RSASSA-PSS signatures to SignedData/SignerInfo objects (CMS / PKCS #7).
- Cryptography: Added support for legacy MD4 algorithm.
- Cryptography: Fixed saving of Brainpool keys (used wrong OID).
- Cryptography: Fixed handling of ED25519 keys in PrivateKeyInfo.
- Cryptography: Fixed CertificateStore private key saving on Mono.
- Common: Environment info is now logged when creating an instance of FileLogWriter.
- Released
- September082017
2017 R5 #
(build 6461 from 2017-09-08)
New fully supported platforms: .NET Core 1.1 and 2.0 on Windows
This release adds full support for .NET Core 2.0 and 1.1 on Windows. Support for .NET Core on Linux and macOS is still experimental.
Support for .NET Standard 1.5, 1.6 and 2.0 (on .NET Core 1.1 and 2.0)
All Rebex libraries support .NET Standard 1.5, 1.6 and 2.0 on .NET Core 1.1 and 2.0. Support for other platforms (such as .NET Standard on .NET 4.6.x or higher) is still experimental.
Detailed list of changes:
- All: Added support for .NET Core 1.1 and 2.0 on Windows.
- Networking: Added support for "http://" URLs in Proxy.Host.
- Cryptography: Added HTTP redirect handling to CRL downloader on .NET Compact Framework.
- Cryptography: Added workaround to enable SHA-2 on legacy operating systems (such as pre-SP3 Windows XP).
- Cryptography: Using ASN.1 GeneralizedTime for dates greater than 2050.
- Cryptography: Enhanced logging of some SSPI errors.
- Cryptography: Added workaround for invalid or empty HTTP header names.
- Common: Enabled SHA-2 support workaround for legacy RSA providers.
- Common: Using custom IBM 437 encoding on .NET Compact Framework.
- Released
- August042017
2017 R4.1 #
(build 6426 from 2017-08-04)
Maintenance release
This is a maintenance release with several improvements, bugfixes and workarounds in the shared functionality.
Detailed list of changes:
- Cryptography: Enhanced RSAES-OAEP support.
- Cryptography: Added CertificateStore.Add method (replacement for deprecated CertificateStore.AddCertificate method).
- Cryptography: Added KeySetOptions.PreferCng and KeySetOptions.AlwaysCng options.
- Cryptography: Fixed AsymmetricKeyAlgorithm.Dispose method.
- Cryptography: Fixed AsymmetricKeyAlgorithm.CreateFrom method (always honors the ownsAlgorithm argument now).
- Released
- June302017
2017 R4 #
(build 6391 from 2017-06-30)
Support for CNG Key Storage Providers
Rebex Certificate
class now fully supports RSA, DSA and ECDSA private keys stored in Windows CNG Key Storage
Providers.
Detailed list of changes:
- All: Deprecated .NET Compact Framework 2.0, Windows (Store) 8.0 and Windows (Store/Phone) 8.1 platforms.
- All: Lots of improvements in experimental .NET Core / .NET Standard edition.
- SFTP: Enhanced error reporting of failed SFTP subsystem request.
- SFTP: Added workaround for Titan SFTP server which incorrectly handles uploaded blocks of 65535/65534 bytes.
- SSH: Added SshParameters.CompressionLevel option to make it possible to specify the desired compression level for SSH.
- SSH: Deprecated SshPrivateKey.CreateSignature, VerifySignature and an old variant of the SshPrivateKey.Save method.
- SSH: Added SshPublicKey.GetPublicKeyInfo() method.
- SSH: Added SshException.GetServerInfo() method to make it possible to determine lists of ciphers supported by the server when SSH negotiation fails.
- Cryptography: Added support for certificates with private keys stored in CNG Key Storage Providers.
- Cryptography: Compatibility enhancements in Certificate public/private key operations and AsymmetricKeyAlgorithm class.
- Cryptography: Added Certificate.GetPublicKeyInfo() method.
- Cryptography: Fixed PublicKeyInfo.GetKeySize() method that used to throw an exception for ECDSA and ED keys.
- Cryptography: Added native support for secp256k1, Brainpool P-256 R1, P-384 R1 and P-512 R1 on Windows 10 and Windows Server 2016.
- Cryptography: Fixed default hash algorithm detection in SignMessage/VerifyMessage methods in Certificate and AsymmetricKeyAlgorithm classes.
- Cryptography: Experimental support for CMS (PKCS #7) decryption with RSA/OAEP/SHA-1 (RSAES-OAEP defined by RFC 3447).
- Cryptography: Fixed 'Unexpected PFX length' error when exporting 4096-bit RSA certificates into PFX/P12 file.
- Released
- May092017
2017 R3 #
(build 6339 from 2017-05-09)
NuGet packages
Rebex libraries just got official NuGet packages!
If you have an active subscription, you will get NuGet packages as part of Rebex libraries. These are supposed to be added to your private NuGet repository.
Rebex packages are available at NuGet.org as well.
Experimental support for .NET Standard 1.5 and NET Core
This release adds experimental support for .NET Core (or rather .NET Standard 1.5/1.6) to all Rebex libraries.
In addition to .NET Core on Windows, Linux and macOS, .NET Standard edition of Rebex libraries can be used on any platform with .NET Standard 1.5 support. This currently includes .NET 4.6.2 and .NET 4.7, and hopefully other platforms soon.
Please note that 'experimental' support means that this edition has not yet reached the 'mainstream' support phase, and the API is subject to change. Any feedback is greatly appreciated.
Support for .NET Framework 4.7
.NET Framework 4.7 is a fully supported platform.
Detailed list of changes:
- All: Added NuGet packages.
- All: Added experimental support for .NET Core and .NET Standard 1.5.
- All: Added workaround for a breaking change in Exception.Data on recent Xamarin.Android.
- All: Added support for .NET Framework 4.7.
- SFTP: Added Scp.Settings.ProcessCommand property to make it possible to customize the 'scp' command before it is sent to the server.
- SFTP: Added Sftp.GetHomeDirectory() method to make it possible to easily determine current user's home directory.
- SFTP: Optimized GetCurrentDirectoryAsync() method.
- Cryptography: Enhanced error messages in AsymmetricKeyAlgorithm.
- Cryptography: Custom certificate validator now behaves like MS CryptoAPI validator when dealing with RSA key sizes shorter than 1024 bits; MD5 signature hash algorithm is always considered to be weak for non-root certificates.
- Cryptography: Added support for .PFX/.P12 saving on .NET Compact Framework (requires Windows CE 5.0 or later).
- Common: Fixed incorrect handling of CNG RSA keys.
- Released
- March222017
2017 R2 #
(build 6291 from 2017-03-22)
SSH client authentication using RSA with SHA-2
All Rebex libraries utilizing our SSH library now support client public/private key authentication based on RSA with SHA-2:
rsa-sha2-256
rsa-sha2-512
ssh-rsa-sha256@ssh.com
Support for Visual Studio 2017
All Rebex libraries are now fully supported in Microsoft Visual Studio 2017. Older Visual Studio versions (2008 and higher) and .NET Framework versions (2.0 and higher) are still supported as well.
Minor ISocket API changes
Legacy parts of ISocket
interface were moved into ISocketExt
interface.
If you implemented a custom transport layer using the ISocket
API, make sure to implement ISocketExt
instead when
upgrading to this release.
Seldom-used static methods in CryptoHelper
class were removed. If you need any of them, please let us know.
Detailed list of changes:
- All: Mono 2.10 is no longer supported. (Mono 3.x and 4.x still supported.)
- SFTP: Added Sftp.Settings.SkipDuplicateItems option (set to true by default).
- Networking: Added logging of environment and platform information.
- Networking: Enhanced target address logging when connecting.
- Networking: HTTP core provides better inner exceptions on errors.
- Networking: Legacy members of custom transport layer API moved from ISocket to ISocketExt.
- Networking: Fixed ProxySocket.Connect(...) on Mono 2.10.
- SSH: Enhanced cipher mismatch error reporting during SSH negotiation to produce informative error messages.
- SSH: Added GetSupportedMacAlgorithms/​GetSupportedEncryptionAlgorithms/​GetSupportedKeyExchangeAlgorithms static methods to SshParameters.
- SSH: Added support for client key authentication using 'rsa-sha2-256', 'rsa-sha2-512' and 'ssh-rsa-sha256@ssh.com' algorithms.
- SSH: Added OpenSSH-style fingerprint support to SshFingerprint class.
- TLS/SSL: Added support for Elliptic Curve DSA to TLS 1.2/1.1/1.0.
- TLS/SSL: Fixed unexpected connection closure handling in TlsSocket.
- TLS/SSL: Fixed handling of Timeout value in TlsSocket.Receive.
- Cryptography: Added support for Elliptic Curve DSA to Certificate/​CertificateChain/​CertificateIssuer classes.
- Cryptography: SignMessage/VerifyMessage methods added to AsymmetricKeyAlgorithm.
- Cryptography: Renamed KeyDerivationOptions class to KeyDerivationParameters.
- Cryptography: Removed seldom-used static methods from CryptoHelper.
- Cryptography: CertificateIssuer class made available on .NET Compact Framework.
- Cryptography: Fixed TLS 1.0/1.1 on FIPS-only Windows with disabled UseFipsAlgorithmsOnly.
- Cryptography: Enhanced CertificateIssuer API.
- Cryptography: Fixed PrivateKeyInfo.KeyAlgorithm that returned non-standard values for some ECDSA keys.
- Cryptography: Fixed handling of padding in ECDSA private keys stored using the new OpenSSH format.
- Cryptography: Fixed weak algorithm detection in .NET Compact Framework custom certificate verifier.
- Released
- February082017
2017 R1 #
(build 6249 from 2017-02-08)
Support for the new OpenSSH key format
Our SSH based libraries can now save private keys using the new OpenSSH key format (Base64-encoded keys with "BEGIN OPENSSH PRIVATE KEY" header).
Detailed list of changes:
- SFTP: Enlarged default transfer queue lengths.
- SCP: Fixed ScpTransferProgressEventArgs.Id property.
- Networking: Added workaround for a breaking change in Exception.Data on recent Xamarin.iOS.
- Networking: TlsSocket.Timeout modifies the underlying ISocket.Timeout as well now.
- Networking: Slightly enhanced certificate rejection reason reporting in TLS.
- Networking: Enhanced ProxySocket connection initialization.
- SSH: Added EnsureKeyAcceptable option that instructs SSH client to announce public key to the server before performing key authentication.
- SSH: Added support for saving private keys in new OpenSSH key format (Base64-encoded keys with "BEGIN OPENSSH PRIVATE KEY" header).
- SSH: Added support for "rsa-sha2-256" and "rsa-sha2-512" host key algorithms.
- SSH: Added support for "diffie-hellman-group14-sha256", "diffie-hellman-group15-sha512" and "diffie-hellman-group16-sha512" key exchange algorithms.
- TLS/SSL: Added support for Renegotiation Indication Extension (RFC 5746).
- TLS/SSL: Preferred TLS/SSL ciphers can be now defined (using TlsParameters.SetPreferredSuites method).
- TLS/SSL: Added check for private key accessibility when starting server-side TLS.
- Cryptography: Added support for ValidationOptions.UseCacheOnly on .NET CF.
- Cryptography: Substantially optimized CRL parsing code used by enhanced certificate validator on .NET Compact Framework.
- Released
- December192016
2016 R3 #
(build 6198 from 2016-12-19)
Elliptic curve cryptography in SSH
All Rebex libraries utilizing our SSH library now support SSH key exchange algorithms based on Elliptic Curve Diffie-Hellman (ECDH) algorithm and SSH host key algorithms based on Elliptic Curve DSA (ECDSA) and Edwards-curve DSA (EdDSA) algorithms:
ecdh-sha2-nistp256
ecdh-sha2-nistp384
ecdh-sha2-nistp521
curve25519-sha256@libssh.org
ecdsa-sha2-nistp256
ecdsa-sha2-nistp384
ecdsa-sha2-nistp521
ssh-ed25519
Please note that external plugins might be needed for some of those algorithms or curves on some platforms.
New OpenSSH key format support
SshPrivateKey
and PrivateKeyInfo
objects can read server and client keys utilizing
the new OpenSSH key format (Base64-encoded keys with "BEGIN OPENSSH PRIVATE KEY"
header).
This format is usually used to store ED25519 or ECDSA keys.
Remote checksum calculation
Sftp
object now features GetChecksum
methods,
making it possible to retrieve a checksum or hash of a remote file (or part of it).
Together with new LocalItem.GetChecksum
methods, this makes it easily possible to reliably detect changed files.
Please note that this functionality only works with servers that support the "file-check"
extension.
Fine-tuning enabled ciphers in SSH
Previously, SshParameters
only made it possible to enable/disable groups of ciphers.
Now, it's possible to fine-tune the list of supported algorithms, including their preferred order (client-side only) using
SetKeyExchangeAlgorithms
, SetHostKeyAlgorithms
, SetEncryptionAlgorithms
and SetMacAlgorithms methods
.
Please note that KeyExchangeAlgorithms
, HostKeyAlgorithms
,
EncryptionAlgorithms
and MacAlgorithms
properties still apply - a cipher is only used
when it is enabled by both the method and property.
Disabled weak algorithms in SSH
Several legacy ciphers are now disabled by default: diffie-hellman-group1-sha1
, blowfish-ctr
,
blowfish-cbc
, arcfour256
, arcfour128
, arcfour
.
Use SshParameters.KeyExchangeAlgorithms
and SshParameters.EncryptionAlgorithms
to enable them.
Weak RSA server host keys shorter than 1024 bits are now rejected by default.
Use SshParameters.MinimumRsaKeySize
property to specify a custom key size.
Detailed list of changes:
- SFTP: Added Sftp.GetChecksum methods (only for servers that support the "file-check" extension).
- SFTP: Changed Sftp.GetStream in UWP edition to use .NET API instead of Windows Store API.
- SFTP: ServerKey property added to Sftp/Scp objects, providing server public host key of the server.
- Networking: Enhanced and optimized HTTP/HTTPS client core.
- Networking: Connect/Listen methods on ProxySocket/TlsSocket objects now throw an exception when called twice on the same socket.
- Networking: Added SocketInformation constructor.
- SSH: Added support for "ecdh-sha2-nistp256", "ecdh-sha2-nistp384", "ecdh-sha2-nistp521" and "curve25519-sha256@libssh.org" key exchange algorithms (plugins might be needed on some platforms).
- SSH: Added support for saving keys in new OpenSSH key format (Base64-encoded keys with "BEGIN OPENSSH PRIVATE KEY" header).
- SSH: Added SetKeyExchangeAlgorithms, SetHostKeyAlgorithms, SetMacAlgorithms methods to SshParameters object to make it possible to fine-tune the list of enabled SSH ciphers.
- SSH: Legacy Diffie-Hellman group exchange is only used with legacy SSH servers.
- SSH: Added SshSession.ServerInfo property to make it possible to determine ciphers supported by the SSH server.
- SSH: Added SshPublicKey.KeySize property.
- SSH: Added SshParameters.MinimumRsaKeySize property specifying to connect only to SSH servers with RSA server key of given size or higher.
- SSH: Added support for "ecdsa-sha2-nistp256", "ecdsa-sha2-nistp384", "ecdsa-sha2-nistp521" and "ssh-ed25519" host key algorithms (plugins might be needed on some platforms).
- SSH: Disabled weak SSH ciphers by default (they can still be enabled explicitly).
- SSH: Check availability of associated private key when adding a certificate-based server host key.
- SSH: Fixed possible NullReferenceException when closing SSH client from another thread just before receiving data.
- TLS/SSL: Added support for Elliptic-Curve based TLS ciphers (TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256, TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA, TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384, TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA, TLS_ECDHE_RSA_WITH_RC4_128_SHA) with NIST P-256/P-384/P-521, Curve 25519 and Brainpool P256R1/P384R1/P512R1 curves. Plugins are needed for some of those.
- TLS/SSL: Server name is now passed to TLS server during negotiation (use TlsParameters.CommonName to override it).
- TLS/SSL: Fixed TlsCipherSuite.All to include all recently added cipher suites.
- TLS/SSL: All legacy 'EXPORT1024' ciphers are now prohibited by default in addition to already-prohibited 'EXPORT' ciphers (unless AllowVulnerableSuites option is enabled).
- TLS/SSL: Fixed issues with some legacy TLS/SSL ciphers (all of them were already disabled by default).
- TLS/SSL: Enhanced error reporting in server-side TLS/SSL library.
- Cryptography: Improved ASN.1 time node parser.
- Cryptography: Added support for certificate validation on Universal Windows Platform.
- Cryptography: Added custom X.509 certificate validator for .NET Compact Framework with full SHA-2 support on all platforms.
- Cryptography: Fixed parsing of 'Intended Usage' extension when 'Decipher Only' was specified.
- Cryptography: Added static Create method to SHA256Managed/​SHA384Managed/​SHA512Managed classes on .NET Compact Framework.
- Cryptography: ValidationResult.ErrorCode deprecated and replaced with NativeErrorCode.
- Cryptography: Optimized memory usage in CMS/PKCS #7 (SingedData/EnvelopedData classes).
- Cryptography: Added missing argument checks to CertificateIssuer methods.
- Cryptography: Added support for Base64-encoded files with CRLF end-of-line sequences to CertificateChain.LoadP7b method.
- Cryptography: Fixed HMAC calculation based on SHA-384 and SHA-512 on NET Compact Framework and Mono platforms.
- Cryptography: Added Rebex.​Security.​Certificates.​CertificateEngine class to make it possible to implement custom X.509 chain building and validation engines.
- Common: Added ConsoleLogWriter for Xamarin platforms.
- Common: Added Rebex.TeeLogWriter class that makes it possible to log to multiple log writers.
- Common: Added LocalItem.GetChecksum methods and related types.
- Released
- August262016
2016 R2.2 #
(build 6083 from 2016-08-26)
Maintenance release
This update brings several improvements, workarounds and bugfixes.
Detailed list of changes:
- SSH: Enhanced handling of errors in FingerprintCheck event handlers.
- TLS/SSL: Fixed a rare issue in abbreviated TLS/SSL negotiation handling.
- Cryptography: Added CheckCertificate/​GetIssuingDistributionPoint methods to CertificateRevocationList class and ValidateRevocationList method to Certificate class.
- Cryptography: Enhanced SHA-2 support check on .NET Compact Framework.
- Cryptography: Fixed SHA-2 support in AsymmetricKeyAlgorithm.SignHash on Windows Server 2008 (and possibly other old platforms).
- Common: Added workaround for broken FileStream.SetLength on some .NET Compact Framework platforms.
- Released
- July282016
2016 R2.1 #
(build 6054 from 2016-07-28)
Maintenance release
This is a maintenance release with enhancements and fixes in the shared functionality.
Detailed list of changes:
- Networking: Fixed ProxySocket.ToEndPoint to throw a more meaningful exception for entries with no IP addresses.
- TLS/SSL: Fixed unreadable TLS debug log messages on Xamarin platforms.
- TLS/SSL: Added workarounds for bugs in Microsoft Schannel implementation of DHE_RSA_* ciphers related to incorrect padding processing.
- Cryptography: Fixed AsymmetricKeyAlgorithm.SignHash (in 2016 R2, it falls back to RSAManaged without trying to use RSACryptoServiceProvider first).
- Cryptography: Fixed CertificateIssuer.​IssueRevocationList method that ignored signatureHashAlgorithm argument and always used SHA-1.
- Common: FileLogWriter on Windows Store 8.x / Universal Windows Platform is now thread-safe.
- Common: Fixed LocalItem(string) constructor on Windows Store 8.x / Universal Windows Platform.
- Common: Added workaround for broken handling of surrogate pairs when converting to "iso-8859-1" using System.Text.Encoding on Mono 4.x.
- Released
- June302016
2016 R2 #
(build 6026 from 2016-06-30)
Support for Xamarin June 2016 Update
June 2016 update of Xamarin.iOS/Xamarin.Android/Xamarin.Mac introduced a breaking change in Mono.Security API that broke compatibility with Rebex libraries. This issue has been solved in this release.
SHA-2 for all supported .NET Compact Framework platforms
SHA-1 is currently being deprecated (applies to X.509 certificates, TLS/SSL and SSH), which poses a problem for legacy .NET Compact Framework platforms based on editions of Windows CE with no native SHA-2 support. To make solutions for these platforms compatible with current TLS/SSL and SSH serves, we added a custom implementation of SHA-2 for these legacy platforms.
Additional SSH host key algorithms
Support for 'x509v3-sign-dss', 'ssh-rsa-sha256@ssh.com' and 'x509v3-sign-rsa-sha256@ssh.com' host key algorithms has been added to SFTP, SCP, SSH and File Server libraries.
Detailed list of changes:
- SFTP: Improved Disconnect method on .NET CF to make sure the connection is closed gracefully.
- Networking: Increased default receive buffer size on Windows 8 and higher. Added related Proxy properties to make this configurable.
- Networking: ProxySocket object's Connect method now uses the timeout value specified by the Timeout property.
- SSH: Added support for additional server authentication algorithms ('x509v3-sign-dss', 'ssh-rsa-sha256@ssh.com' and 'x509v3-sign-rsa-sha256@ssh.com').
- SSH: Disabled hmac-sha96 SSH cipher in FIPS mode (it's not compliant).
- SSH: Fixed error handling in queued background calls (mostly applies to session renegotiation).
- SSH: Fixed renegotiation handling to allow renegotiation while authenticating.
- SSH: Fixed DSA client certificate authentication.
- SSH: Enhanced interactive authentication support to handle uppercase password prompts.
- TLS/SSL: Enhanced SHA-2 support for .NET Compact Framework. SHA-256, SHA-384 and SHA-512 are now supported even on platforms with no native SHA-2 support.
- TLS/SSL: Added Settings.SslSession property to allow resuming specific TLS/SSL sessions.
- TLS/SSL: Fixed record layer 'protocol version' handling.
- TLS/SSL: Enhanced Diffie-Hellman key exchange logging.
- Cryptography: Fixed detection of native SHA-2 support in .NET Compact Framework version.
- Cryptography: Added support for more variants of OpenSSL/OpenSSH (SSLeay) key files.
- Cryptography: Fixed Certificate.Associate to work with DSA keys.
- Cryptography: Added CrlNumber property to CertificateRevocationList object.
- Cryptography: Added support for SHA-2 certificates to Certificate.VerifyHash in .NET Framework 2.0 on Windows with FIPS-compliant mode enabled.
- Cryptography: Certificate.LoadPfx and CertificateChain.LoadPfx methods now specify Exportable options by default (in addition to UserKeySet).
- Cryptography: Added workaround for RSA implementations that reject rare signatures shorter than the key size.
- Common: Enhanced SSPI error messages.
- Common: Fixed LogWriterBase.Level default value.
- Common: Fixed compatibility issue in Xamarin edition (caused by a breaking change in June 2016 update of Xamarin).
- Released
- February102016
2016 R1.1 #
(build 5885 from 2016-02-10)
Experimental assemblies for Xamarin.Mac
Added experimental binaries of most Rebex libraries (FTP/SSL, SFTP, File Server, Secure Mail, ZIP, Time, Security) for Xamarin.Mac platforms. They are suitable for targeting Xamarin.Mac Mobile Framework and Xamarin.Mac .NET 4.5 Framework projects.
Maintenance release
Experimental binaries of most Rebex libraries (FTP/SSL, SFTP, File Server, Secure Mail, ZIP, Time, Security) for the Xamarin.Mac platform are now available. They are suitable for targeting both Xamarin.Mac Mobile and Xamarin.Mac .NET 4.5 Framework projects.
Maintenance release
This release includes several hotfixes.
Detailed list of changes:
- SSH: Fixed seldom-used SshSession.Connect(string, int) method that was freezing since 2016 R1.
- SSH: Added workaround for older version of Bitvise server that don't properly handle SSH channel closing.
- SSH: Fixed handling of multi-line SSH banner messages.
- SSH: Fixed a bug in SSH channel window size adjustment.
- SSH: Fixed potential NullReferenceException error in SshSession.Dispose method.
- TLS/SSL: Disabled any usage of MD5 in TLS 1.2 to prevent SLOTH attacks.
- Released
- January112016
2016 R1 #
(build 5855 from 2016-01-11)
Experimental assemblies for Windows Store Apps
Experimental binaries of many Rebex libraries (SFTP, FTP/SSL, Time, ZIP, File Transfer Pack, Terminal Emulation) for "Windows 8 Store", "Windows 8.1 PCL", and "Windows Universal Platform" are now available. The are suitable for "Store Apps" targeting Windows 8.0, Windows 8.1, Windows Phone 8.1, Windows 10, Windows 10 Mobile and Windows 10 IoT.
Mitigation of Logjam attacks
Check for minimum allowed Diffie-Hellman key size (1024 bits) has been added to SSH and TLS/SSL to mitigate Logjam attacks.
The minimum value can be changes using Settings.SslMinimumDiffieHellmanKeySize
or Settings.SshParameters.MinimumDiffieHellmanKeySize
.
Server certificate authentication in SSH
Rebex SFTP, Terminal Emulation and File Server now support X.509 certificate host key algorithm, making it possible to authenticate servers using a certificate instead of public key.
Detailed list of changes:
- All: Added workaround for Xamarin.Android whose Dns.GetHostEntry resolves 'localhost' to device's external IP address.
- All: Rebex assemblies are now signed with SHA-256 signatures in addition to legacy SHA-1 signatures.
- SFTP: Enhanced error message reported by ChangeDirectory when trying to change into a non-existing directory.
- Networking: Fixed a bug in SOCKS4/SOCKS5 response reading code that triggered an infinite loop with buggy proxy servers.
- Networking: Enhanced DNS resolution error messages.
- SSH: Enhanced interactive authentication support to make it possible to use AuthenticationRequest event to ask for username and password.
- SSH: Enhanced rejected authentication logging and error reporting.
- SSH: Fixed compatibility with old versions of OpenSSH (2 and 3).
- SSH: Fixed a bug that could cause a deadlock in packet sending routine.
- SSH: Added SshParameters.​MinimumDiffieHellmanKeySize value (set to 1024 by default to mitigate Logjam attacks).
- SSH: SshPrivateKey constructor's 'password' argument made optional.
- SSH: No exception is thrown when the server aborts connection instead of closing it (unless a packet is being received).
- SSH: Enhanced 'no common algorithms' error message.
- SSH: Refactored SSH core to handle multi-thread scenarios more efficiently.
- SSH: Added certificate-based constructor to SshPublicKey class.
- SSH: Added support for certificate-based server authentication (using 'x509v3-sign-rsa algorithm').
- SSH: Fixed misleading error message when user interactive authentication attempt is rejected.
- SSH: Added support for one additional 'keyboard-interactive' authentication prompt ('Password for [user@server]:').
- SSH: Added Settings.PostponeChannelClose option to enable workaround for servers that send channel data or exit code after the channel has been closed.
- SSH: Added EnableSignaturePadding option that forces signature padding (workaround for SSH servers that got signature padding wrong).
- SSH: Added logging of debug messages received from SSH server.
- TLS/SSL: TLS 1.2 made compatible with Microsoft's implementation.
- TLS/SSL: Fixed client certificate authentication in TLS 1.2.
- TLS/SSL: Added Settings.​SslMinimumDiffieHellmanKeySize value (set to 1024 by default to mitigate Logjam attacks).
- TLS/SSL: Added reliable detection of SHA-2 certificate support.
- Cryptography: Enhanced cryptographic provider initialization error message.
- Cryptography: Added workaround for PuTTY keys with bad data at the end.
- Common: Fixed multi-file operations to never modify input FileSet's BasePath.
- Common: ThreadPool is now used to handle background operations instead of a custom implementation.
- Common: Enhanced multithread operation support in log writers.
- Released
- August242015
2015 R4.1 #
(build 5715 from 2015-08-24)
Fixed Xamarin mobile platform detection
Fixed platform detection code on Xamarin.iOS and Xamarin.Android.
Detailed list of changes:
- All: Fixed platform detection on Xamarin.Android and Xamarin.iOS.
- All: Version and platform added to assembly description.
- Released
- August092015
2015 R4 #
(build 5700 from 2015-08-09)
Support for Windows 10, .NET Framework 4.6 and Visual Studio 2015
All Rebex libraries now ship with full support for Windows 10, .NET Framework 4.6 and Microsoft Visual Studio 2015. Older Visual Studio versions (2005 and higher) and .NET Framework versions (2.0 and higher) are still supported as well.
Faster TLS/SSL and SSH negotiation on Xamarin.Android
Our SSH and TLS/SSL libraries now use Java-based Diffie-Hellman on Xamarin.Android, which substantially speeds up SSH and TLS/SSL negotiation when Diffie-Hellman algorithm is used.
Detailed list of changes:
- All: Enhanced platform detection code.
- SFTP: Fixed Sftp.AbortTransfer to support value type states.
- SFTP: DownloadBufferSize, DownloadQueueLength, UploadBufferSize and UploadQueueLength added to Sftp.Settings.
- SFTP: Added workaround for a bug in GlobalScape 7.1.x which sends erroneous empty data packets to the client.
- SFTP: Fixed ObjectDisposedException that might have occurred when an SSH channel has been closed in a certain way.
- SCP: Fixed treatment of additional special characters in remote paths.
- SSH: Added Settings.TryPasswordFirst and Settings.​WaitForServerWelcomeMessage workarounds to Scp and Ssh.
- SSH: Added support for message authentication algorithms based on SHA-2 on .NET Compact Framework (when supported natively).
- SSH: Fixed NullReferenceException thrown by some SshSession properties (such as IsConnected) when not connected.
- SSH: SHA-2 is now the preferred message authentication algorithm.
- SSH: Added logging of SSH packet header data on decoding error.
- SSH: Added support for larger SSH packets.
- TLS/SSL: Unified status handling in ValidatingCertificate events and ICertificateVerifier interface.
- TLS/SSL: Enhanced TLS/SSL version mismatch handling.
- Cryptography: Fixed final empty block handling in Twofish/Blowfish/ArcTwo TransformFinalBlock with PKCS #7 padding.
- Cryptography: SSH and TLS/SSL now use Java-based Diffie-Hellman objects on Xamarin.Android platform to speed up negotiation.
- Common: Fixed end-of-line sequences in LogWriterBase, optimized FileLogWriter.
- Common: Added workaround for broken ASN.1 time values with the second part of "60".
- Released
- April152015
2015 R3.1 #
(build 5584 from 2015-04-15)
Detailed list of changes:
- SSH: Disabled legacy "arcfour" SSH cipher by default.
- SSH: Fixed a bug that caused an algorithm list set by Settings.​SshParameters.​SetEncryptionAlgorithms to be ignored in FIPS-compliant mode.
- Released
- April082015
2015 R3 #
(build 5577 from 2015-04-08)
Maintenance release
This update brings several enhancements and bugfixes.
Detailed list of changes:
- All: Fixed Version property of Ftp, Imap, Pop3, Scp, Sftp, Smtp and Ssh classes to return a proper version number. Changed Ftp.Version to a static propery to match the other objects.
- SCP: Added missing Scp.Login(SshGssApiCredentials) method and related events.
- SSH: Enhanced some authentication error messages.
- TLS/SSL: Disabled ciphers based on RC4 to prevend Bar Mitzvah attack on TLS/SSL.
- Cryptography: Enhanced weak signature algorithm detection during certificate validation on Xamarin.iOS.
- Common: Connect methods no longer require FileIOPermission (used to determine the assembly version for a log).
- Released
- March172015
2015 R2 #
(build 5555 from 2015-03-17)
Maintenance release
This update brings several enhancements and bugfixes.
Detailed list of changes:
- SCP: Fixed escaping of round brackets in remote paths.
- TLS/SSL: Added support for TLS 1.2.
- TLS/SSL: Added support for AES ciphers with SHA-256 checksums.
- TLS/SSL: Disabled legacy 'exportable' ciphers (by default) to prevent FREAK security exploit.
- Cryptography: Added support for SSLeay private keys with AES-256-CBC encryption.
- Cryptography: Fixed broken HashSize property in SHA-2 CSP on .NET Compact Framework.
- Released
- February022015
2015 R1 #
(build 5512 from 2015-02-02)
Support for Xamarin Unified API
Added support for the new Unified API. This includes unified 32-bit and 64-bit platform support and makes it simple to share code between iOS and Mac.
Detailed list of changes:
- All: Added support for Xamarin.iOS unified API.
- SFTP: Added Sftp.Settings.LogChecksums option that makes it easily possible to log checksums of uploaded files.
- SFTP: Fixed listing of root-level wildcard paths.
- SFTP: Added Sftp.CreateSymlink method.
- Released
- December182014
2014 R3 #
(build 5466 from 2014-12-18)
Legacy SSL 3.0 disabled by default in TLS/SSL-enabled libraries.
TLS 1.1 is now used by default in TLS/SSL-enabled libraries. Legacy SSL 3.0 support is disabled by default because it is no longer considered secure. Its use is strongly discouraged after disclosure of POODLE Attack.
Maintenance release
This update brings several improvements, workarounds and bugfixes.
Detailed list of changes:
- All: Added more overloads to asynchronous Connect and Login methods.
- All: Removed legacy Connect methods and enumerations from Xamarin.iOS and Xamarin.Android version (should never have been there).
- SFTP: Added workaround for Axway's strangely-behaved SSH_FXP_OPENDIR command.
- SFTP: Added workaround for WS_FTP's problematic SSH_FXP_REALPATH command.
- SFTP: Enhanced SFTP client to work nicely with Rebex File Server.
- SSH: Enhanced SshPublicKey constructor to accept base64-encoded public key data.
- SSH: Added workaround for wrong SSH_MSG_USERAUTH_PK_OK packet in Cisco SSH.
- TLS/SSL: TLS 1.1 is now used by default in TLS/SSL-enabled libraries. Legacy SSL 3.0 support is disabled by default.
- TLS/SSL: Added experimental support for AES and Twofish based anonymous ciphers.
- Cryptography: Fixed SymmetricKeyAlgorithm.Padding for non-CBC modes.
- Cryptography: Added support for base-64 encoded P7B certificate chains.
- Cryptography: Changed padding of parameters exported by DSAManaged.ExportParameters to match DSACryptoServiceProvider.
- Cryptography: Added AsymmetricKeyAlgorithm.PublicOnly property.
- Cryptography: Added workaround for non-working HMACSHA256/384/512 on some FIPS-only systems.
- Cryptography: Added CertificateExtension.​EnhancedKeyUsage method Useful when constructing certificate requests using CertificateRequest object.
- Cryptography: Fixed DiffieHellmanManaged.KeySize that sometimes reported shorter bit lengths.
- Cryptography: Several new AsymmetricKeyAlgorithm-based methods added to Certificate and CertificationRequest.
- Common: Added LocalItem.Attributes property.
- Common: PKCS #12 key loading routines changed to not persist keys in Windows key storage by default.
- Common: Added ConsoleLogWriter, a console-based log writer class.
- Released
- July032014
2014 R2 #
(build 5298 from 2014-07-03)
Maintenance release
This update brings several improvements, workarounds and bugfixes.
Detailed list of changes:
- All: Eliminated "Unknown heap type" warnings in Mono.
- SFTP: Added Sftp.​Settings.​DisableRealPathWorkaround option to disable workaround for WS_FTP SSH_FXP_REALPATH bug.
- SFTP: Added workaround for SFTP servers that report duplicate extensions.
- Networking: Enhanced logging of failed certificate validation errors.
- Networking: Fixed ProxySocket's Connect method behavior with disabled timeout.
- TLS/SSL: Enhanced TlsVersion and TlsCipherSuite parameters checking.
- TLS/SSL: Fixed alert names in TlsException messages.
- Cryptography: Added Load, Save and Generate methods to PrivateKeyInfo and PublicKeyInfo classes.
- Cryptography: Enhanced CertificationRequest class to support request generating in addition to parsing.
- Cryptography: Fixed behavior with disabled UseFipsAlgorithmOnly on FIPS-only systems.
- Released
- February262014
2014 R1 #
(build 5171 from 2014-02-26)
Maintenance release
This update brings several improvements, workarounds and bugfixes.
Detailed list of changes:
- All: Various small low-level optimizations.
- SFTP: Added Sftp.​Settings.​TreatUnknownItemsAsFiles property (workaround for SFTP serves that return invalid item type values).
- Networking: Added static NetworkSession.DefaultLogWriter property to make it easily possible to set a shared log writer for all Ftp/​Sftp/​Imap/​Smtp/​Pop3/​Scp/​Ssh/​SshSession objects.
- Networking: Enhanced logging capabilities of ProxySocket class (Socket4/Socks5 proxies).
- SSH: Added support for SHA-2 (SHA-256 and SHA-512) message authentication codes.
- SSH: Enhanced CTR mode workaround for OpenSSH 4.x.
- SSH: Fixed missing MAC algorithm ID in SshCipher.ToString().
- SSH: Standard form of SSH_MSG_KEX_DH_GEX_REQUEST packets is used with recent OpenSSH servers instead of its legacy form.
- TLS/SSL: Added new Certificate-based CertificateRequestHandler.​CreateRequestHandler overloads.
- Cryptography: Fixed a bug in MD5SHA1 signature validation on .NET Compact Framework.
- Cryptography: Fixed AES CSP availability detection in FIPS-compliant mode.
- Cryptography: Fixed sorting of PKCS #7 signature attributes.
- Cryptography: Added support for AES-128-CBC SSLeay private keys.
- Cryptography: Added workaround for certificates and keys in Base64-encoded format ending with a zero octet.
- Common: Assemblies made more obfuscator-friendly.
- Common: Fixed null value comparisons in FileSystemItemComparer.
- Released
- December022013
2013 R3 #
(build 5085 from 2013-12-02)
Support for Xamarin.iOS and Xamarin.Android
Rebex libraries now support Xamarin.iOS and Xamarin.Android, making it possible to target iPad/iPhone and Android devices! (The only exception is the Terminal Emulation library whose TerminalControl object relies heavily on Windows Forms and is only available for Windows and Linux at the moment.)
Support for .NET Compact Framework 3.9
In addition to .NET CF 2.0 and 3.5, we now support .NET CF 3.9 as well. This makes it possible to target Windows Embedded Compact 2013, Microsoft's latest incarnation of Window CE.
Assemblies for every supported platform for all
With every purchase, you now get binaries for all supported platforms. Users with active support contract were upgraded for free. This will make it easy to embrace the new trends - we offer a single API that works with .NET, .NET Compact Framework, Mono, Xamarin.iOS and Xamarin.Android.
Support for Visual Studio 2013
All Rebex libraries now ship with full support for Microsoft Visual Studio 2013. Older Visual Studio versions (2005 and higher) and .NET Framework versions (2.0 and higher) are still supported as well.
Detailed list of changes:
- All: Xamarin.iOS and Xamarin.Android officially supported in all libraries except Rebex Terminal Emulation.
- All: .NET Compact Framework 3.9 officially supported.
- All: Visual Studio 2013 officially supported.
- SFTP: SftpBatchTransferException made obsolete (use SftpException instead).
- SFTP: Fixed timeout handling in Sftp.Connect method.
- SFTP: Added Sftp.​Settings.​DisablePathNormalization option.
- SFTP: Added Sftp.Setting.RecheckItemExistence option to verify remote item existence before using it.
- SFTP: Fixed assignment of default reaction in response to a problem encountered during Upload/Download methods.
- SCP: Upload and Download methods added to Scp object to replace PutFiles and GetFiles methods.
- Networking: On Windows 8 and 8.1, larger TCP receive buffer size is used by default. The default value caused low transfer speeds in many cases with FTP and SFTP.
- Networking: Added IsAuthenticated and IsConnected properties to NetworkSession (Ftp, Sftp, Scp, Imap, Smtp, Pop3, Ssh and SshSession objects).
- Networking: Added support for digest authentication to HTTP CONNECT proxies.
- Networking: Fixed ProxySocket.BeginSend and BeginReceived methods which used to fail in some scenarios.
- SSH: Added support for additional formats to SshPublicKey/SshPrivateKey object's SavePublicKey method and SshPublicKey constructor.
- SSH: Enhanced error checking to report a more meaningful error instead of "Invalid decoder state" in case of some connection failures.
- SSH: Enhanced GSSAPI/Kerberos support to be compatible with OpenSSH.
- SSH: Added Kerberos ticket delegation support.
- SSH: Added GSSAPI/Kerberos support to .NET CF version of SSH core.
- Cryptography: Changed Certificate.FindCertificates method not to include subordinate CAs in the search by default.
- Cryptography: Fixed CertificateStore.Exists on non-Windows platforms.
- Cryptography: Added workaround for opening certificate stores in .NET CF that don't exist yet.
- Cryptography: Added workaround for problem with DSA certificate in .PFX importing code on Windows Embedded Compact 2013.
- Cryptography: Added .NET CF support for Certificate.Associate(privateKey, permanentBind)
- Cryptography: Added Certificate.​GetAuthorityKeyIdentifier() method.
- Cryptography: Changed SignerInfo and SignerInfo objects to use NULL parameters for hash algorithms (in order to match RSACryptoServiceProvider behavior).
- Common: Added FileLogWriter.Path to replace FileLogWriter.Filename.
- Common: Added LocalItem.ComputeCrc32() method.
- Common: Signed and encrypted message parsing made more compatible with broken messages.
- Released
- August202013
2013 R2 #
(build 4981 from 2013-08-20)
Maintenance release
This update adds support for IPv6 hostnames with zone IDs.
Detailed list of changes:
- Networking: Added support for IPv6 hostnames with zone IDs.
- TLS/SSL: Added workaround for MS FTP's TLS 1.1 bug in close_notify handling.
- Released
- July292013
2013 R1 #
(build 4959 from 2013-07-29)
Official support for Mono
All Rebex libraries now officially support Mono, an open source, cross-platform, implementation of C# and the CLR that is binary compatible with Microsoft .NET Framework. The same assemblies that work on Windows now work on Mono in Linux or Apple OS X as well.
Unified FTP and SFTP item comparers
Although FtpItemCollection
and SftpItemCollection
objects have been derived from
a shared base class since the introduction of IFtp
(a common interface for SFTP and FTP/SSL), a common base class for FtpItemComparer
and SftpItemComparer
has been missing. In this release, we added FileSystemItemComparer
to fix this inconvenience.
Detailed list of changes:
- All: Added support for Mono.
- All: Fixed finalizers that used to call state-changed events in some cases.
- SFTP: GetItems now returns links instead of resolved items.
- SFTP: Sftp.Settings.RestoreDateTime now applies to PutFile and GetFile methods as well.
- SFTP: Fixed handling of broken links when deleting.
- SFTP: Added default error messages for SFTP v4 errors.
- SFTP: Added Sftp.​Settings.​TimeComparisonGranularity property.
- SFTP: Added Sftp.​Setting.​DisableFxpStatWorkaround property.
- SFTP: Fixed FingerprintCheck, BannerReceived and AuthenticateRequest events in Sftp and Scp.
- SFTP: Added Sftp.KeepAlive() method.
- SFTP: Sftp.GetConnectionState() method made more reliable.
- SFTP: When using TransferMethod.Move, only successfully transferred files are deleted.
- SFTP: Fixed SftpItem.Name to return "/" instead of "" for the root folder.
- SFTP: Fixed two event calls in file listing methods that did not use the proper synchronization context.
- SFTP: GetList and GetInfo return a path in the Path property.
- SFTP: Added support for restoring creation date/time on upload.
- SFTP: Enhanced multi-file operation logging.
- SFTP: Added FileSystemItemComparer to replace FtpItemComparer and SftpItemComparer.
- SFTP: Multi-file operations fixed to work properly with '.'-based FileSets.
- SFTP: Several options shared by Ftp and Sftp objects added to IFtpSettings.
- SFTP: Fixed Delete("dir/.") that used to delete "dir" as well.
- Networking: Added support for HTTP CONNECT proxy communication logging.
- SSH: Dispose and Disconnect methods added to SshSession object and Close method deprecated.
- SSH: SshSession now throws exceptions with ConnectionClosed status on closed connections.
- SSH: Fixed SshException.Data["ProtocolCode"] and .Data["ProtocolMessage"] values.
- SSH: Added verbose logging of raw data during welcome message exchange.
- SSH: Fixed FingerprintCheck, BannerReceived and AuthenticateRequest events in Ssh.
- TLS/SSL: SslInsertEmptyFragments property added to SslSettings.
- TLS/SSL: Fixed null TlsParameters.Certificate handling in server-side TlsSocket.
- Cryptography: Added support for anyExtendedKeyUsage attribute (in X.509 certificates).
- Cryptography: Added DiffieHellmanCryptoServiceProvider class.
- Cryptography: Added PrivateKeyFormat.RawPkcs8 format for PrivateKeyInfo.Save and PrivateKeyInfo.Encode methods.
- Cryptography: RSAManaged.VerifyHash returns false on error.
- Cryptography: Fixed ArcTwoTransform to treat EffectiveKeySize of 0 as "current KeySize".
- Cryptography: HMAC fixed to use block length of 128 for algorithms with hashes larger than 256 bits.
- Cryptography: Fixed certificate verification to better handle server certificate with missing common name (used to throw NullReferenceException).
- Cryptography: Fixed handle leak in CertificateStore constructor.
- Common: Enhanced workaround for Stream.Seek on .NET CF.
- Common: FileLogWriter enhanced to log assembly version when opening log file.
- Common: Added missing PublicKeyInfo() constructor.
- Common: Added FileSet.​ContainingDirectoriesIncluded option.
- Common: Added workaround for instances of FileStream that return "[Unknown]" name.
- Common: EncodingTools support IBM437 charset on all platforms.
- Common: Added CertificateFindOptions.None.
- Common: Added FileSystemItemCollection.UsePath property.
- Released
- November122012
2012 R3 #
(build 4700 from 2012-11-12)
Official support for Visual Studio 2012
All Rebex libraries now ship with full support for Microsoft Visual Studio 2012. Samples and tutorials were updated for a new project file format. Older Visual Studio and .NET Framework versions are still supported too.
Task-based asynchronous methods
The major change is the addition of new Task-based asynchronous methods to .NET 4.0/4.5 variant of our libraries. This brings our API up-to-date with the current trends and makes it possible to utilize the new await keyword available in .NET 4.5 and Visual Studio 2012. Finally, asynchronous programming became easy and seamless. Check out some of the updated samples to see this in action!
Events now using SynchronizationContext
Previously, events raised by asynchronous methods were running in a background thread, making them hard to use in GUI applications. Now, events are raised using the SynchronizationContext captured when the asynchronous method was started, which basically means the events will run on application's GUI thread, making it possible to update application's controls directly from the event code.
Detailed list of changes:
- All: Added .NET 4.x-style task-based asynchronous methods to objects previously using .NET 1.x-style Begin/End asynchronous pattern.
- All: Asynchronous method events are raised using the current synchronization context for the asynchronous operation.
- All: Added options to force the old-style event behavior (not using the current synchronization context).
- All: Added Rebex.Legacy namespace to .NET 4.x builds to allow compiling code that uses old-style asynchronous methods.
- All: Added official support for Visual Studio 2012.
- SFTP: Added Sftp.Settings.RestoreDateTime property to make it possible to restore source date/time on target.
- SFTP: Removed unused SftpBatchTransferOperation.​FileDataBlockProcessed value.
- SFTP: Changed Sftp.PutFile(..., string, long, long) behavior to truncate remote path when zero remote offset is specified (corresponds to Sftp.PutFile(..., string) behavior). Added Sftp.​Settings.​DisablePutFileZeroOffsetTruncate option to force old behavior.
- SFTP: Fixed ActionOnExistingFiles.​ResumeIfPossible behavior to skip existing files if already transferred.
- SFTP: Multi-file operation events always report absolute paths.
- SFTP: Enhanced source path checking in multi-file operations.
- SFTP: Fixed argument checks in GetStream/​GetUploadStream/​GetDownloadStream methods.
- SFTP: Added Rename value to ActionOnExistingFiles enum (used in Upload/Download methods).
- SFTP: Events Traversing, TransferProgressChanged, DeleteProgressChanged and ProblemDetected added into Sftp to make it possible to get notified about significant actions and to be able to react to a problem in multi-file operations.
- SCP: Added connected-check to Scp object methods.
- SCP: Changed default SCP upload packet size from 32KB to 8KB (the former size was too big for some servers).
- SCP: Added workaround for SCP in OpenSSH 4.x that doesn't accept quoted paths.
- Networking: NetworkSessionException is now the base class for all network protocol exceptions.
- Networking: Task-based asynchronous methods added to IFtp interface.
- Networking: Removed several Socket.Available calls, resulting in higher speed and Windows Azure compatibility.
- Networking: Events Traversing, TransferProgressChanged, DeleteProgressChanged and ProblemDetected added into IFtp to make it possible to get notified about significant actions and to be able to react to a problem in multi-file operations.
- SSH: Better error message for unsuccessful keyboard-interactive fallback workaround.
- SSH: Enhanced "Invalid decoder state" error reporting.
- SSH: Added support for diffie-hellman-group-exchange-sha256 key exchange algorithm.
- SSH: Added SshPublicKey class, SshSession.ServerKey property and FingerprintCheck.ServerKey property (to make it possible to determine server host key in addition to fingerprint).
- TLS/SSL: Fixed a bug in server-side TLS/SSL that caused it to fail when session resuming was enabled.
- TLS/SSL: Fixed TlsException serialization that failed for some errors.
- TLS/SSL: Fixed a bug that caused problems with TLS/SSL in FIPS-only mode.
- Cryptography: Fixed a bug in TransformFinalBlock method of Rebex.Security.Cryptography ciphers that caused interoperability issues with CryptoStream.
- Cryptography: Fixed PKCS#7 padding check in built-in ciphers.
- Cryptography: Added EncodingTools class that adds support for all the charsets needed on all platforms.
- Cryptography: Added auto-detection of a bug in unpatched .NET Framework 3.5's AesCryptoServiceProvider object.
- Cryptography: Implicit ObjectIdentifier(string) constructor added.
- Cryptography: Fixed CryptoHelper.CreateAlgorithm to return CSP version of SHA-2 hash algorithms when available.
- Cryptography: Fixed CertificateFinder property behavior to keep old certificates if no certificates are found by the new finder.
- Cryptography: Server certificate verification routine now allows certificates with '*.domain.net' names to be used for 'domain.net' in addition to '*.domain.net'.
- Cryptography: Fixed a bug in private key decryption routine which failed with keys encrypted with PKCS #12 key derivation algorithm.
- Common: Fixed P/Invokes in NTLM/Kerberos code.
- Common: AddRange method added to file item collections.
- Common: FIPS 140-2 compliant mode enhancements.
- Common: Fixed certificate validation issue on Windows XP and Windows Server 2003.
- Common: Added Certificate.Thumbprint property.
- Common: Fixed a bug in certificate chain building routine that caused it to ignore additional stores in some cases.
- Released
- June112012
2012 R2 #
(build 4546 from 2012-06-11)
Client certificate authentication in SFTP & SSH
Although SFTP/SSH usually use password-based or public-key-based authentication, some servers support X.509 client certificate authentication as well. Unfortunately, not all servers support this, and those which do use a variety of different protocol extensions to achieve it. In this release, we have added client certificate authentication compatible with VanDyke VShell server. If it doesn't work with your server, please let us know.
Detailed list of changes:
- SFTP: Added support for POSIX rename ('posix-rename@openssh.com' extension).
- SFTP: Fixed a bug in Sftp.GetFiles which caused an ArgumentOutOfRangeException on some servers.
- SFTP: SftpItem uses UTC time for range checks (previously there were problems with times close to 1970-01-01).
- SFTP: Added Download/Upload(string, string) method overload.
- SFTP: Added Sftp.GetItems(string, ...) methods.
- Networking: UseLargeBuffers option added into IFtpSettings.
- SSH: Added SshPrivateKey(AsymmetricAlgorithm) constructor that makes it possible to initialize it from RSACryptoServiceProvider/​DSACryptoServiceProvider (useful for SmartCard-based keys).
- SSH: Fixed wrong handling of large remote SSH channel window sizes (used by mod_sftp server).
- SSH: Client certificate authentication added (compatible with VanDyke VShell server).
- SSH: ZLIB support announced even when not preferred (without that, we were unable to connect to servers that refuse uncompressed sessions).
- SSH: Fixed a bug that causes a misleading error to be reported on immediately-closed connections.
- SSH: Added workaround for mod_sftp/0.9.7 which occasionally produces broken DSA signatures.
- TLS/SSL: Fixed a misleading error message which was reported when certificate revocation status could not be checked.
- TLS/SSL: When ProtocolVersion error occurs, data received prior to it is logged.
- Cryptography: Fixed local/UTC time comparison in Certificate.IsTimeValid.
- Cryptography: Added implicit conversion between Certificate object and X509Certificate/X509Certificate2 objects.
- Cryptography: Enhanced compatibility with Mono on non-Windows platforms - Certificate validation now works!
- Cryptography: Support for saving .PFX/.P12 files added to Certificate.Save method.
- Cryptography: Added new overloads of Certificate.Associate that make it possible to permanently bind the private key to the certificate.
- Cryptography: Added Certificate.FriendlyName property.
- Cryptography: Fixed Certificate.SignHash method which used to fail on .NET Framework 2.0 when an associated key was used for MD5SHA1 signature generation.
- Cryptography: Fixed MD5Managed.HashSize property which used to return 0.
- Cryptography: Certificate.HasPrivateKey code in .NET CF version changed to behave identically to .NET version.
- Common: Added FileSet.Flatten option (makes it possible to ignore source directory structure and copy all files into single target directory).
- Common: Enhanced error reporting of file-path-based methods.
- Common: Added LocalItem and LocalItemCollection classes (used by FileSet.GetLocalItems method).
- Released
- March012012
2012 R1 #
(build 4444 from 2012-03-01)
Libraries DLLs have been renamed
We found out that the DLL naming scheme we decided to use back in 2003 was no longer sustainable and decided to change it.
Instead of Rebex.Net.Ssh.dll
, Rebex.Net.SecureSocket.dll
, Rebex.Net.ProxySocket.dll
and Rebex.Security.dll
,
we now have Rebex.Common.dll
and Rebex.Networking.dll
.
Most of the other DLLs were renamed as well during the process (Rebex.Net.Ftp.dll
became Rebex.Ftp.dll
, for example).
We are sorry for any inconvenience this may have caused, but an alternative solution - introduction of a new DLL for shared functionality - would not be hassle-free either.
Fortunately, in order to upgrade to the new version, most customers will only need to remove references to the old DLLs and add references to the new ones because the API is still backward-compatible.
New multi-file methods in Rebex SFTP and FTP/SSL
FTP/SSL and SFTP got several new methods: Upload, Download, Delete and GetItems. The first two are replacements for PutFiles/GetFiles (and support move operation in addition to copy), Delete makes it possible to delete multiple files (or even a directory tree) at once and GetItems makes it possible to retrieve a list of files for the whole directory tree in one call.
Common API for SFTP and FTP/SSL (experimental)
Lot of our customers have been asking for a common API capable of both SFTP and FTP/SSL. Even though Ftp and Sftp objects provide a very similar API, they are still two distinct classes and writing code that can use either of them was hard. Now, it got much better with the introduction of IFtp interface.
Faster Blowfish and Twofish algorithms for Rebex SFTP and Rebex SSH Shell
Bruce Schneier's Blowfish and Twofish symmetric encryption algorithms are a popular choice for SSH communication encryption. Although we have been already supporting both for a few years, we developed a new managed implementation that is substantially faster than the old one.
Detailed list of changes:
- All: SecurityRuleSet.Level2 is used for .NET 4.0 binaries.
- All: Added a Stream.Flush() call after each Stream.Seek() or Stream.Position call in .NET Compact Framework (workaround for .NET CF FileStream bug).
- SFTP: Auto-resume capability added for PutFiles/GetFiles methods.
- SFTP: Added workarounds for another SFTP server where SSH_FXP_STAT and SSH_FXP_REALPATH commands (used by many Rebex SFTP methods) don't always work (for aliased directories, for example).
- SFTP: Added workaround for ChangeDirectory problems with WS_FTP server.
- SFTP: OpenSSH on a Unix-like OS is now detected properly.
- SFTP: Fixed a bug in PutFiles method that caused incorrect behavior when a root-based masked path was specified.
- SFTP: Changing Sftp's or Scp's LogWriter now changes the underlying SshSession's LogWriter as well.
- SFTP: Added SftpOptions.UseSmallPackets option that reportedly solves speed issues in some rare circumstances.
- SFTP: It's now possible to call Sftp.Login again if it fails.
- SFTP: Added TryPasswordFirst option to try "password" authentication first and "publickey" later (by default, the opposite order is used).
- SFTP: New values related to Upload, Download, Delete and GetItems methods added to SftpBatchTransferOperation enum.
- SFTP: String comparison methods use StringComparison.Ordinal.
- SFTP: New Download, Upload, Delete and GetItems methods added to Sftp object (along with associated enums and classes).
- SFTP: Added Sftp.Settings property that replaces and extends Sftp.Options.
- SFTP: Sftp object implements IFtp interface to make it easier to write code which works with both FTP and SFTP.
- SFTP: Multi-file operations optimized by omitting existence check of items found during the operation.
- Networking: Socket.NoDelay is used by default in non-CF version of Rebex libraries.
- SSH: Fixed error handling in SshSession.OpenTcpIpTunnel method that caused troubles when multiple channels were active at the same time.
- SSH: SshChannel no longer attempts to adjust window size after the channel has been closed.
- TLS/SSL: Fixed non-working TlsSocket.BeginSend and BeginReceive methods.
- Cryptography: Certificate.Save and Certificate.SavePrivateKey methods added, along with a corresponding variant of Certificate.LoadDerWithKey.
- Cryptography: PKCS #7 writer changed to use a more compatible variant of EncryptedContent in EncryptedContentInfo structure. This solves interoperability issues with Entrust CSP and signed messages.
- Cryptography: Added ObjectIdentifier.ToArray(bool useDer) method.
- Cryptography: CertificateChain.LoadP7b method added (used for loading .P7B certificate chains).
- SSH: Added SshParameters.​PreferredHostKeyAlgorithm property.
- SSH: Added SshChannel.PassEnvironmentVariable method.
- SSH: Fixed NullReferenceException during simultaneous channel close/read.
- SSH: Fixed a deadlock that may have occurred when using multiple SSH channels from multiple threads.
- SSH: Fixed a race condition that may have occurred when sending and reading from a single SSH channel at the same time.
- SSH: Removed SshParameters.Options property because it was ignored and only present by mistake.
- SSH: Added SshParameters.​SetEncryptionAlgorithms method to specify exact list and order of allowed SSH ciphers. Corresponding GetEncryptionAlgorithms method added as well.
- Cryptography: Faster Blowfish and Twofish algorithms.
- Cryptography: SubjectPublicKeyInfo.Load method now supports binary keys.
- Cryptography: Removed lots of CryptoApi dependencies from Certificate code.
- Cryptography: 4096-bit DSA keys (used by some SSH servers) are no longer rejected.
- Cryptography: Diffie-Hellman and DSA algorithms fall back to managed ModPow calculation on .NET CF with missing "Enhanced DSA and Diffie-Hellman" CSPs.
- Cryptography: Added Certificate.​Associate(PrivateKeyInfo) method.
- Cryptography: Certificates associated with a private key using Associate method now support MD5SHA1 hash algorithm and suitable for TLS/SSL client certificate authentication.
- Common: Fixed a bug in TraceLogWriter that caused an additional newline to be written at the end of each message.
- Common: Added FileSystemItem and FileSystemItemCollection classes.
- Common: Better readability in Verbose-level logs.
- Common: Thread ID added to all log messages.
- Released
- March092011
2.0.4086.0 #
(build 4086 from 2011-03-09)
Detailed list of changes:
- SSH: Added workaround for old SSH servers that miscalculate HMAC-SHA1 keys.
- SSH: Added SshParameters.AuthenticationMethods to make it possible to only enable desired authentication methods.
- SSH: SendEof method added to SshChannel to make it possible to achieve plink-like functionality.
- SSH: Fixed a bug in SSH channel window size adjustment code which could cause a timeout on servers which send oversized packets.
- SSH: Fixed a bug that prevented SSH key renegotiation requests from being processed, resulting in a timeout.
- SSH: Abort flag checking messages removed from Debug log.
- Released
- February112011
2.0.4060.0 #
(build 4060 from 2011-02-11)
Detailed list of changes:
- SFTP: Bandwidth throttling support in Rebex SFTP through Sftp object's MaxUploadSpeed/MaxDownloadSpeed properties.
- SFTP: SetFileDateTime in SFTP v4 is now compatible with WS_FTP.
- SFTP: Sftp object's AbortTransfer method now properly cancels operations that are just about to start as well.
- SFTP: Added SftpItemComparer class to ease sorting of SftpItemCollection items.
- SFTP: Added workarounds to Sftp.GetStream method SFTP servers that don't support the Append mode.
- SFTP: BytesTotal and ProgressPercentage properties added to Sftp.TransferProgress event arguments.
- SFTP: Added workarounds for several SFTP servers where SSH_FXP_STAT and SSH_FXP_REALPATH commands (used by many Rebex SFTP methods) don't always work (for aliased directories, for example).
- SFTP: Sftp.PutFiles method (in ThrowExceptionOnLinks mode) correctly detects the links in Windows 7 which were not detected previously.
- SFTP: Added a workaround for SFTP server that sent duplicate filenames in their listings.
- SCP: GetFiles and PutFiles methods added to Scp object to make it possible to transfer multiple files or a whole directory tree in one call.
- Cryptography: Added a new overload of SshPrivateKey.Save to make it possible to save keys in SSLEay/OpenSSH format (in addition to PuTTY .ppk and PKCS #8 formats).
- Cryptography: Added CertificateChain.Save method to save the chain in .p7b format.
- Cryptography: Fixed a bug in DistinguishedName object that caused the elements of string representation of DNs to be reversed.
- Cryptography: Added CryptoHelper.ForceManagedAes flag as a workaround to .NET's leaking AesCryptoServiceProvider.
- SSH: AuthenticationRequest event added to make it possible to deal with all kinds of "keyboard-interactive" authentication prompts.
- SSH: Fixed a possible race condition that might have occurred when using the same SshSession instance from multiple threads.
- SSH: Enhanced automated "keyboard-interactive" authentication to support more variants of password prompt.
- SSH: Fixed a bug in ZLIB decompression routines.
- SSH: SshSession.Encoding property added.
- SSH: Added SshOptions.​WaitForServerWelcomeMessage option.
- SSH: Updated SFTP to detect, read and skip unexpected malformed packets which used to throw a "Message with invalid length xxx was received." exception when trying to login.
- Released
- July202010
2.0.3854.0 #
(build 3854 from 2010-07-20)
Detailed list of changes:
- SFTP: Added Sftp.GetStream method that makes it possible to open a readable/writable/seekable stream of a remote file.
- SFTP: Sftp class inherits from NetworkSession base class that implements some common properties.
- SFTP: Added SftpOption.​UseReadWriteModeForDownloads.​
- SFTP: Added ProtocolVersion property to Sftp class.
- SFTP: SftpItemCollection.GetEnumerator is now an implementation of IEnumerable<SftpItem>.
- SFTP: Fixed a DateTime range check in SftpAttributes.Modified and .Created which was performed before the conversion to UTC.
- SFTP: Better error handling in GetFiles/PutFiles methods.
- SSH: Added support for aes*-ctr and 3des-ctr ciphers.
- SSH: In FIPS-only mode, a CryptoAPI implementation of AES is used if available.
- SSH: SshSession class inherits from NetworkSession base class that implements some common properties.
- SSH: SshChannel.ExtendedDataReceived event added to make it possible to receive extended data.
- Released
- May202010
2.0.3793.0 #
(build 3793 from 2010-05-20)
Detailed list of changes:
- All: Packages for .NET 4.0 and Visual Studio 2010 now available.
- SFTP: Fixed a bug that caused "/" local path argument of PutFiles/GetFiles methods to be treated as current directory.
- SFTP: Added Sftp.Bind and Scp.Bind method to make it possible to bind the SFTP or SCP object to existing SSH session.
- SFTP: A full local path is passed in SftpBatchTransferProgressEventArgs.
- SFTP: SftpTransferProgressEventArgs now contain RemotePath and LocalPath when available.
- SFTP: SftpBatchTransferException is now serializable.
- SFTP: Queued data packets are no longer written to the output stream after download operation has been aborted.
- SSH: Added a workaround for a server that announces support for "password" authentication but requires "keyboard-interactive" instead.
- SSH: Fixed a bug in ZLIB compression routines that caused compatibility problems with GlobalScape and BitVise servers when compression was enabled.
- SSH: Fixed a bug that caused SSH session to hang if a broken (incomplete) SSH packet arrived (rare).
- Released
- March112010
2.0.3723.0 #
(build 3723 from 2010-03-11)
Detailed list of changes:
- SFTP: A more meaningful exception is thrown when a directory path is passed to Sftp.GetFile method instead of file path.
- SFTP: Added support for getting and setting file creating date (only works with servers that support SFTP v4).
- SFTP: Fixed SSH_FXP_READ packet logging code that caused some packets not to appear in the communication log.
- SFTP: Added a workaround for servers where SSH_FXP_STAT command doesn't work correctly on directories.
- SFTP: Fixed a bug in GetFile method that caused it to hang if length was specified.
- SFTP: Added SftpBatchTransferOptions.XCopy batch transfer mode. This is an alternative form of FtpBatchTransferOptions.Recursive that traverses all subdirectories but only transfers files that match the specified mask.
- SFTP: Fixed PutFiles method to accept all kinds of root paths (such as "c:", "c:/", or "c:\" - previously, only "c:\." worked).
- SFTP: SftpTransferProgressEventArgs.​BytesPerSecond property added that contains the estimated current speed.
- SFTP: HierarchyRetrieve events are no longer raised when only a single file is transferred.
- SFTP: Added experimental SftpOptions.UseLargeBuffers to use larger internal buffers (doesn't seem to make substantial difference on most systems).
- SFTP: Data-block-receiving routines optimized to write directly to the output stream without a round-trip through a temporary buffer.
- SFTP: Fixed a bug that made it impossible to call Sftp.GetFiles method on a root directory.
- SFTP: Sftp.TransferProgress event is called less often on high-speed connections now (several times per second is sufficient).
- ProxySocket: The underscore character is now allowed in hostnames (this is non-standard, but used by Windows).
- ProxySocket: FileLogWriter is capable of logging into a single file from multiple applications now.
- ProxySocket: ProxySocket.Send behavior changed to always send all the data or fail.
- Cryptography: Added Certificate.LoadDerWithKey method to make it possible to easily load certificates with private keys in external file (Unix-style).
- Cryptography: Support for PKCS #7 EnvelopedData encrypted using RC2 with effective key length not equal to key data length.
- Cryptography: Fixed a bug in EnvelopedData class that cause a NullReferenceException to be raised when unsupported encryption algorithm is encoutered.
- Cryptography: Internal ModPow method optimized.
- Cryptography: Key generation support removed from RSAManaged a DSAManaged. No part of any of our libraries ever used it at it was prohibitively slow anyway.
- SSH: Added SshFingerprint.Compute and SshFingerprint.FromBase64String methods to make it possible to easily calculate a fingerprint of the supplied public key.
- SSH: ZLIB compression is now switched off by default (caused problems with some servers).
- SSH: Client KEX_INIT packet is sent without waiting for the server side one (this is the only proper behavior).
- SSH: Added SshSession.KeepAlive method to make it possible to periodically "ping" the SSH connection to keep it working and detect failures.
- Released
- October272009
2.0.3588.0 #
(build 3588 from 2009-10-27)
Detailed list of changes:
- SFTP: SFTP v4 support added.
- SFTP: Fixed a bug in CreateDirectory/ChangeDirectory workaround for CoreFTP.
- SFTP: Added workaround for ProFTPd's mod_sftpd SSH_FXP_REALPATH command that fails for newly created directories.
- ProxySocket: Proxy object now has Encoding property that makes it possible to specify character set to be used for parsing server responses.
- ProxySocket: ProxySocketException.ErrorCode property now returns HTTP and Socket4/Socks5 error codes when available.
- ProxySocket: SspiAuthentication and GssApiProvider classes added that provide GSSAPI/SSPI functionality.
- Cryptography: Certificate's CRL distribution point list can be accessed using GetCrlDistributionPoints method.
- SSH: Fixed a bug in ArcFour cipher implementation that made it unusable.
- SSH: Fixed a bug that caused an SSH welcome message to be parsed incorrectly when split across multiple packets.
- SSH: Added support for ZLIB transfer compression.
- Released
- July152009
2.0.3484.0 #
(build 3484 from 2009-07-15)
Detailed list of changes:
- SSH: Fixed a bug in GSSAPI authentication that caused it to work improperly in 32bit .NET Framework.
- Released
- July102009
2.0.3479.0 #
(build 3479 from 2009-07-10)
Detailed list of changes:
- SFTP: IEnumerable<T> support added to collections for .NET Framework 2.0 and higher.
- Cryptography: .PFX/P12 private key file loading support for Windows Mobile 5 and newer.
- Cryptography: Added support for signatures based on SHA-2 (SHA-256, SHA-384 and SHA-512).
- Cryptography: If .NET Framework 3.5 is available, a new and much faster AES implementation is used instead of RijndaelManaged.
- Cryptography: Behavior of certificate finders in CMS/PKCS #7 was enhanced - embedded certificates are always searched now.
- SSH: Support for GSSAPI authentication (gssapi-with-mic) added. Kerberos (not on .NET CF) and NTLM mechanisms are supported. MS SSPI is used as an underlying authentication provider.
- SSH: SshFingerprint class extended to support multiple hash algorithms.
- SSH: Added BannerReceived event that ca be used to receive banner messages sent by the server.
- SSH: Added FingerprintCheck event as an alternative way to check server fingerprint.
- SSH: Support for authentication using both username/password and public key at the same time made compatible with Maverick SSHD server.
- Released
- May202009
2.0.3428.0 #
(build 3428 from 2009-05-20)
Detailed list of changes:
- SFTP: Added support for transfer compression through a plugged-in library.
- SFTP: Upload and download speed enhanced a lot using the pipelining approach.
- SFTP: UTF-8 encoding is used by default for WS_FTP server.
- SFTP: Upload and download buffer size changed from 32K to 28K because the original size resulted in two packets being sent.
- SFTP: Fixed a misleading error message that occurs when both password and public key authentication is required by the server but the clients only supply one of the credentials.
- SFTP: Added several workarounds for CoreFTP server's SFTP implementation that suffers from numerous bugs such as missing file attributes or half-working SSH_FXP_REALPATH command.
- SFTP: Fixed a bug in GetFiles and PutFiles method that caused a wrong path to be used when a filename only was specified or when a root path was specified.
- SCP: Compatibility enhancements in Scp object's PutFile method.
- SCP: Added a workaround for Bitvise's SCP that closes the SCP channel too early.
- SSH: Added FIPS 140-2 compliant mode that is automatically enabled on systems where only compliant algorithms are allowed.
- SSH: Added a new exception status - PasswordChangeRequired - that is used when a password change is required before authentication can be successfully completed.
- Released
- February142009
2.0.3333.0 #
(build 3333 from 2009-02-14)
Detailed list of changes:
- SFTP: Detection of GlobalScape server enhanced to properly detect more versions.
- SCP: Scp.Logger renamed to Scp.LogWriter to match the other objects including Sftp.
- SCP: Fixed improper handling of the first success response.
- ProxySocket: Fixed a bug in Socks4/Socks5 proxy code that made it impossible to use FTP in active mode with these proxies.
- Cryptography: CertificateStore.FindCertificate overloads that accept DistinguishedName now search for certificates signed by intermediate CAs as well.
- Cryptography: Enhanced treatment of empty passwords in the PFX loader.
- Cryptography: Certificates with SubjectAlternativeName extension marked as critical are now treated as not having any e-mail address assigned to them if no e-mail address is found in the extension data.
- Cryptography: Fixed a bug in DiffeHellmanManaged.​ImportParameters method that made it impossible to import key with all parameters filled.
- SSH: Banner message is now logged when using the LogWriter functionality.
- SSH: Added workaround for badly-formed DSA signature produced by SSH Secure Shell 3.1.0 (and possibly other versions).
- SSH: Added a workaround to the Compact Framework version for VanDyke VShell server that sends primes that are one bit longer than expected.
- Released
- January122009
2.0.3300.0 #
(build 3300 from 2009-01-12)
Detailed list of changes:
- SFTP: Added PutFiles and GetFiles method to make it possible to transfer multiple files easily by transferring a whole directory tree or use wildcards.
- SFTP: Setting ServerType property to Unix now causes '\' not to be treated as a directory separator for the remote server.
- SFTP: A better exception is now thrown by a method that has been terminated by calling Dispose from another thread.
- SFTP: Packages for .NET Compact Framework 3.5 added.
- SFTP: Asynchronous operations now use a thread pool.
- SFTP: Asynchronous method threads are now named.
- SCP: Added Scp class to make it possible to transfer files using the legacy SCP protocol.
- Cryptography: Added support for reading and setting private key comment.
- Cryptography: Added RootCertificate and LeafCertificate properties to CertificateChain class.
- Cryptography: Added GetCommonName method to DistinguishedName class.
- Cryptography: Added IEnumerator support to CertificateChain.
- Cryptography: Added Equals method to DistinguishedName class.
- Cryptography: Fixed a bug in OID decoding routine that cased it to occasionally hang on broken input data.
- Cryptography: Added new Certificate.LoadPfx to make it possible to load keys into machine store.
- Cryptography: Fixed a problem in Certificate.Decrypt method that made the decryption fail with some rare certificates.
- Cryptography: Added Certificate.Associate method to make it possible to associate a RSA/DSA crypto service provider with access to a private key with a certificate.
- SSH: Added support for saving PuTTY private keys.
- SSH: Added ChangePassword method to SshSession class to make it possible to change user password.
- SSH: Added support for servers that don't require a password.
- SSH: Fixed a bug in SshSession that caused problems when multiple channels through the same SSH session were used at the same time.
- Released
- July232008
1.5.3127.0 #
(build 3127 from 2008-07-23)
Detailed list of changes:
- SFTP: GetList, GetRawList and GetNameList enhanced to support wildcards. However, they are processed at the client side because SFTP can't do that at the protocol level.
- SSH: Fixed a problem in RSA private key reader that caused an error with some keys.
- SSH: Enhanced packet reader to support oversized SSH packets.
- Released
- June142008
1.5.3087.0 #
(build 3087 from 2008-06-14)
Detailed list of changes:
- ProxySocket: New ISocket interface to make it possible to easily implement custom transport layers.
- ProxySocket: Fixed an unhandled exception that occurred during a failed connection to a proxy specified by an IP address.
- SFTP: Enhanced initial folder detection to be compatible with more servers.
- SFTP: Added detection for FTP and SSL servers that are often mistaken with SFTP to produce better exception messages.
- SFTP: Fixed incorrect ChangeDirectory method behavior with empty path argument.
- SFTP: Fixed a problem that caused SftpException.Status property to have a incorrect value in some cases.
- SFTP: Added hostname validity checking to Connect method.
- SFTP: Added experimental support for CR/CRLF conversion of text files.
- SSH: Fixed an internal static method that was not thread safe.
- SSH: PuTTY keys with no password are now supported as well (previously, only PuTTY keys with passwords worked).
- SSH: Added SSH tunneling capabilities.
- Released
- December062007
1.5.2896.0 #
(build 2896 from 2007-12-06 )
Detailed list of changes:
- All: Packages for .NET Framework 3.5 and Visual Studio 2008 now available.
- Released
- November112007
1.5.2871.0 #
(build 2871 from 2007-11-11)
Detailed list of changes:
- SFTP: Fixed a bug in GetInfo and GetFileLength methods that caused an invalid length to be reported for files larger than 4GB.
- SSH: Changed the authentication routine to be compatible with servers that require a banner message to be sent to the client.
- SSH: Fixed a bug in block receiving code that occurred when a block of certain invalid length was received.
- SSH: Added support for loading PuTTY private keys.
- Cryptography: Added support for loading PuTTY private keys.
- Released
- August302007
1.5.2800.0 #
(build 2800 from 2007-08-30)
Detailed list of changes:
- SFTP: Default command and response encoding changed to Encoding.Default instead of standard UTF-8, because a survey of SFTP servers showed that none of them in fact uses UTF-8.
- SFTP: Added support for authentication using both username/password and public key at the same time.
- SSH: Added support for Blowfish and Twofish ciphers.
- SSH: Added support for authentication using both username/password and public key at the same time.
- Cryptography: Added support for Blowfish and Twofish ciphers.
- Cryptography: Added new CertificateIssuer class for certificate creation.
- Cryptography: Added new CertificateChain-based certificate finder.
- Cryptography: Certificate revocation list is now available in EnvelopedData and SignedData classes.
- Cryptography: When the CertificateFinder property is changed in EnvelopedData and SignedData Certificate, the new finder is now immediately used to find any missing certificates.
- Cryptography: Several serialization bugs in EnvelopedData and SignedData classes were fixed.
- Cryptography: Certificate class has a new Extensions property that makes the extension collection accessible.
- Cryptography: Various other changes that do not affect the FTP protocol.
- Released
- May242007
1.5.2700.0 #
(build 2700 from 2007-05-24)
Detailed list of changes:
- SFTP: Added ListItemReceived event. This makes it possible to display the list items as they are received, to filter them or to abort the transfer based on previously received items.
- SFTP: Response receive buffer enlarged to support messages that are slightly over the maximum allowed length, and better error reporting for those that are too large.
- SFTP: Added another workaround for WeOnlyDo's wodFTPD (FreeFtpD) server that is unable to report the correct file datetime if the local and remote time zones are not the same.
- Cryptography: CertificateFinder can now be changed even after an EnvelopedData or SignedData has been loaded.
- Released
- April202007
1.3.2666.0 #
(build 2666 from 2007-04-20)
Detailed list of changes:
- SFTP: Added SetFileDateTime method.
- SFTP: Added FileExists and DirectoryExists methods.
- SFTP: Added workaround to GetInfo method for WeOnlyDo SFTP server that reports missing files as access denied.
- SFTP: GetConnectionState no longer fails on disconnected objects.
- SFTP: Added GetUploadStream and GetDownloadStream methods for stream-based remote file access.
- SSH: Client no longer announces key exchange and encryption methods that are not supported on its current platform.
- SSH: Speed drop caused by ineffective data receiving loop was fixed.
- SSH: Fixed a bug that caused any extra key-exchange to fall.
- Released
- March062007
1.0.2621.0 #
(build 2621 from 2007-03-06)
Detailed list of changes:
- SFTP: IPv6 support with .NET Framework 1.1/2.0/3.0 and .NET Compact Framework 2.0.
- SSH: Fingerprint property added to SshPrivateKey class.
- Released
- January112007
1.0.2567.0 #
(build 2567 from 2007-01-11)
Detailed list of changes:
- Cryptography: Added PrivateKeyInfo class and an ability to load and save private keys.
- Cryptography: Fixed a bug in DSAManaged class that made impossible to use keys of some sizes.
- Cryptography: Random big integer generator optimized.
- Cryptography: Several typos in documentation fixed.
- SFTP: Added support for RSA and DSA public key authentication.
- SFTP: Added workaround for ShellFTP server that has a bad habit of dropping SSH sessions after the SFTP session is closed.
- SSH: Added support for RSA and DSA public key authentication.
- SSH: Added support for Diffie-Hellman Group Exchange authentication (RFC 4419).
- SSH: Fixed a bug that caused Timeout value to be ignored when waiting for the server's initial message.
- SSH: SshFingerprint class made serializable.
- Released
- December122006
1.0.2537.0 #
(build 2537 from 2006-12-12)
Detailed list of changes:
- SFTP: Initial public release.