Skip to content

Releases: signalapp/libsignal

v0.65.3

21 Jan 20:38
Compare
Choose a tag to compare
- Net/Android: Expose new ChatConnection API that uses new connectivity internals to Java
- Net: Migrate CDSI to new connectivity internals also used by ChatConnection
- Net: Migrate DNS to new connectivity internals also used by ChatConnection
- Android: Update Gradle 8.9 and Android Gradle Plugin 8.7.3, matching Signal Android

v0.65.2

15 Jan 23:57
Compare
Choose a tag to compare
- Backup validator: fix too-strict check on payment-related messages

v0.65.1

15 Jan 18:47
Compare
Choose a tag to compare
- Several backup validator improvements:
  - Stricter checking of group messages.
  - Stricter validation of update messages.
  - Stricter validation of author references.
  - Stricter validation of payment notifications.
  - Performance optimizations for common message patterns.
  - Updates to backup protobuf definition.

- Networking changes:
  - Fixed a bug triggered by quickly connecting then disconnecting a chat
    connection.
  - Reduce the number of SNIs used when trying to connect using domain fronting.
  - Log on some important chat events.
  - Add a tag to log messages to distinguish the source of each.

- Key Transparency:
  - Sync with recent server protocol changes.

v0.65.0

07 Jan 22:51
Compare
Choose a tag to compare
- Added a validity-checking function to AccountEntropyPool.

- Rust: The EC key types have been moved to libsignal_core::curve.
  They are still exported through libsignal_protocol as before, but a
  few of the signatures have changed.

- The libsignal-net ChatConnection APIs have been exposed to Swift.
  These will eventually replace the ChatService APIs.

- libsignal-net: enabled support for Ed25519 TLS certificates

- Fixed username printing for discriminators under 10

- Many backup validator improvements
  - Require a Self recipient
  - Disallow IDs of 0
  - Disallow timestamps not representable by JS Date
    (more than 100,000,000 days from the epoch)
  - Chat.pinnedOrder of 0 is no longer treated as "unpinned"
  - Stricter checking of many messages

- Key transparency: the "monitor" API has been exposed to Java.

- Removed support for the old AuthCredential versions

- Removed SVR3 from all app bridges

- Changed the representation of pointers in the Swift (ffi) bridge
  layer. This has always been considered an unstable interface, but if
  you're using it anyway, you'll need to adjust for the new types that
  are more Swift-friendly.

v0.64.1

06 Dec 21:50
Compare
Choose a tag to compare
- Backups: Support BackupInfo.currentAppVersion and firstAppVersion fields

v0.64.0

06 Dec 17:15
Compare
Choose a tag to compare
- Improve the performance of both the online and whole-file backup validation
  methods.

- Add a CLI utility to "scramble" backups by removing the most obvious
  identifying information.

- Import various backup validation proto changes, and tighten validation of
  distribution lists to disallow duplicate entries.

- Java: the key transparency Store abstraction has been reworked.

- The version of our `boring` dependency is now v4.13.0, which incorporates the
  changes of the upstream project through the same version.

v0.63.0

22 Nov 22:59
Compare
Choose a tag to compare
- Introduce OnlineBackupValidator, while accepts serialized protobuf
  frames rather than processing an entire file at once.

- Swift: SignalError.backupValidation was **removed** in favor of
  MessageBackupValidationError, which it was essentially redundant
  with.

- ChatService will soon be replaced by ChatConnection, currently
  experimentally available in Node. (All of the networking-related
  APIs are still even more subject to change than the rest of
  libsignal.

- The Node library now requires ES2021.

- Methods issuing older AuthCredential formats were deprecated and
  will be removed in a future release.

- Support for the CDSI option 'return_acis_without_uaks' was removed;
  it was already ignored by the service.

- Further backup validator proto updates and performance improvements,
  including use of an extra worker thread for pipelining entire-file
  processing. ChatItem errors will now include the dateSent timestamp.

- Further work on both key transparency and libsignal-net.

v0.62.0

13 Nov 21:09
Compare
Choose a tag to compare
- Android: AuthenticatedChatService can now receive messages via the
  ChatListener interface. (This is a breaking change if you were
  previously constructing AuthenticatedChatService.)

- Further backup validator updates:
  - Allow PNI-only contacts
  - Allow Chat.muteUntilMs of INT64_MAX ("mute forever")
  - Update Backup.proto (several fields now use `optional`)
  - Suppress repeated warnings about the same timestamp field
  - Buffer the input stream for all app languages

- SHA-2 performance improved on 64-bit Android, iOS, macOS, and Linux

- Rust: Add ServiceId::to_protocol_address (thanks, @rubdos!)

Note: though some key transparency APIs have been exposed to Android,
they are not yet finalized.

v0.61.0

06 Nov 23:12
Compare
Choose a tag to compare
- Net: Chat now throws RateLimitedError/RetryLaterException when the server requests a retry
- Node: Switched from yarn to npm to align with other Signal projects
- Android: Split ChatService into Unauthenticated.. and AuthenticatedChatService for platform consistency
- Attest: Removed unused IAS attestation code and tests
- Backup: Made timestamps optional for AttachmentLocator:uploadTimestamp and ChatItem:dateServerSent

v0.60.2

31 Oct 20:14
Compare
Choose a tag to compare
- Add BackupKey.deriveThumbnailTransitEncryptionKey
- Backup validator: Allow "unknown" restrictions for call links