4 **Attention**: Now requires native libsignal-client version
0.30.0
6 ## [0.11.11] - 2023-05-24
7 **Attention**: Now requires native libsignal-client version
0.25.0
10 - New
`--text-style` and
`--quote-text-style` flags for
`send` command
13 - Fixed migration of older account files
14 - Fix deleting old unregistered recipient
16 ## [0.11.10] - 2023-05-11
17 **Attention**: Now requires native libsignal-client version
0.23.1
20 - Support for receiving and sending edit messages with
`--edit-timestamp`
22 ## [0.11.9.1] - 2023-04-23
25 - Fix build with Java
20
27 ## [0.11.9] - 2023-04-22
30 - Workaround issue with linking to newer app versions
32 ## [0.11.8] - 2023-04-05
35 - Added file attachment attributes to JSON output (Thanks @signals-from-outer-space)
38 - Scrub E164 number from dbus paths
39 - Fix sending large text messages to multiple recipient
40 - Fix deleting old group in dbus mode
41 - Fix issue with unknown identity serviceId
44 - Relaxed Content-Type check in http daemon mode (Thanks @cedb)
46 ## [0.11.7] - 2023-02-19
47 **Attention**: Now requires native libsignal-client version
0.22.0
50 - Fix issue with missing pni identity key
51 - Fix graalvm sqlite issue (Thanks @Marvin A. Ruder)
52 - Fix issue with forgetting recipient
55 - Allow JSON-RPC commands without account param if only one account exists
57 ## [0.11.6] - 2022-12-18
60 - Allow using data URIs for updateGroup/updateProfile
61 - New alive check endpoint for http daemon (Thanks @ced-b)
64 - Registration with voice verification now works if no system locale is set
65 - Fixed retrieving attachments in JSON RPC mode (Thanks @ced-b)
67 ## [0.11.5.1] - 2022-11-09
70 - Fix updating from older signal-cli version
72 ## [0.11.5] - 2022-11-07
73 **Attention**: Now requires native libsignal-client version
0.21.1
76 - Add
`--http` flag to
`daemon` command to provide a JSON-RPC http endpoint (
`/api/v1/rpc`). (Thanks @ced-b)
77 - The
`receive` method is now also available in JSON-RPC daemon mode, for polling new messages.
78 - Add
`getAttachment` command to get attachment file base64 encoded. (Thanks @ced-b)
79 - Add
`--disable-send-log` to disable the message send log.
80 - Add
`--story` to
`sendReaction` command, to react to stories.
81 - Add
`--story-timestamp` and
`--story-author` to
`send` command, to reply to stories.
82 - Add
`--max-messages` to
`receive` command, to only receive a certain number of messages.
85 - Send long text messages as attachment instead. This matches the behavior of the official clients.
86 - Store attachments with a file extension, for common file types.
88 ## [0.11.4] - 2022-10-19
91 - Approve/Refuse group join requests, using same interface as adding/removing members
92 - Add --ignore-stories flag to prevent receiving story messages
95 - Fixed issue with receiving messages that can't be decrypted
96 - Do not discard incoming group join messages
99 - Add code to receive new PNI after change number
101 ## [0.11.3] - 2022-10-07
104 - Fix sending messages to groups (in non-daemon mode)
105 - Fix updating from older signal-cli version
106 - Fix issue with handling decryption error message
107 - Fix graalvm native build (Thanks @bentolor)
109 ## [0.11.2] - 2022-10-06
112 - Update user agent version to work with new Signal-Server check
114 ## [0.11.1] - 2022-10-05
117 - Fix sending group messages
118 - Fix store migration issue on Windows
119 - Fix building fat jars
121 ## [0.11.0] - 2022-10-02
122 **Attention**: Now requires native libsignal-client version
0.20.0
125 - Changed meaning of
`-v` flag from
`--version` to
`--verbose`.
126 So now extended logging can be achieved with
`-vv`.
127 - Remove deprecated fallback to reading from stdin if no message body is given.
128 To read a message from stdin, use the
`--message-from-stdin` flag.
131 - Migrate PIN to new KBS enclave when Signal updates it
132 - Add
`--scrub-log` flag to remove possibly sensitive information from the log
133 - Add
`sendPaymentNotification` dbus method
136 - Fix an issue where messages were sent without sender phone number
139 - Store data except base account data in sqlite database
140 - Use new CDSI for contact discovery in compat mode
142 ## [0.10.11] - 2022-08-17
143 **Attention**: Now requires native libsignal-client version
0.19.3
146 - Output content of received story messages
148 ## [0.10.10] - 2022-07-30
149 **Attention**: Now requires native libsignal-client version
0.18.1
152 - Fix setPin/removePin commands which broke due to server side changes
153 - Workaround GraalVM
22.2.0 issue with daemon connection
155 ## [0.10.9] - 2022-07-16
158 - updateAccount command checks self number and PNI after updating account attributes
161 - Fixed small issue with syncing contacts from storage
162 - Fixed issue with opening older account files
164 ## [0.10.8] - 2022-06-13
167 - Attachments can now be given as data: URIs with base64 data instead of just file paths (Thanks @KevinRoebert)
168 - `version` command can now be used on the commandline, in addition to the
`--version` flag.
169 In the next version the current short form
`-v` will change its meaning to
`--verbose`!
172 - An account can now be registered on both LIVE and STAGING environment in the same config directory.
173 - Logging output for registering has been extended.
175 ## [0.10.7] - 2022-05-29
178 - Added profile information to
`listContacts` command output
179 - Added filter flags for
`listContacts` command
180 - New
`sendPaymentNotification` command to send payment receipt blobs
181 - New
`--given-name` and
`--family-name` parameters for
`updateContact` command
182 - Implement sending link previews with
`--preview-url`,
`--preview-title` parameters for the
`send` command
183 - New
`--send-read-receipts` parameter for
`receive` and
`daemon` commands for automatically marking received messages as read
186 - Issue with endless growing
`pre-keys-pni` data directory
188 ## [0.10.6] - 2022-05-19
189 **Attention**: Now requires native libsignal-client version
0.17
192 - Check if account is used on the environment it was registered (live or staging)
193 - New command
`deleteLocalAccountData` to delete all local data of an unregistered account
194 - New parameter
`-g` for
`listGroups` command to filter for specific groups
197 - Fix deleting a recipient which has no uuid
200 - Show warning when sending a message and no profile name has been set.
201 (A profile name may become mandatory in the future)
202 - After blocking a contact/group the profile key is now rotated
203 - Only update profile keys from authoritative group changes
205 ## [0.10.5] - 2022-04-11
206 **Attention**: Now requires native libsignal-client version
0.15
209 - New
`--ban`,
`--unban` flags for
`updateGroup` command to ban users from joining by group link
212 - Fix plain text output of blocked group ids
213 - Fix error output in case of rate limiting
214 - Fix error when creating a group with no members
215 - Fix adding recent Signal-Desktop versions as linked devices
217 ## [0.10.4.2] - 2022-03-17
219 - Crash in json output when receiving message from untrusted identity
220 - Fix multi account commands for newly created accounts
222 ## [0.10.4.1] - 2022-03-02
224 - Linking to current apps (which currently don't include a PNI identity yet)
225 - Show better error message when --target-timestamp is missing for sendReceipt
227 ## [0.10.4] - 2022-02-20
229 - Implement support for change number as linked device
230 - Add
`--message-from-stdin` flag for send command. The current behavior of
231 reading from stdin if the
`-m` flag is not given, will be removed in a future
235 - Align receive timeout behavior for dbus client with cli and JSON-RPC.
236 Timeout is reset by every incoming message
237 - Renamed
`error` field in json receive response to
`exception`
240 - Prevent a stale jsonrpc connection from interfering with message receiving
242 ## [0.10.3] - 2022-02-01
244 - MessageSendLog to cache sent message for
24h.
245 For resending messages in case the recipient fails to decrypt the message.
246 - New global
`--log-file` parameter to write logs to a separate file.
247 (
`--verbose` can be used to increase the log level)
250 - Better subscription handling for JSON-RPC
`subscribeReceive` command
253 - Output receipt data for unsealed sender receipts again
254 - Fix sending message resend requests to devices that happen to have the same deviceId
256 ## [0.10.2] - 2022-01-22
258 - Archive old sessions/sender keys when a recipient's identity key has changed
259 - Fix profile fetch with an invalid LANG variable
261 ## [0.10.1] - 2022-01-16
263 - Send group messages with sender keys (more efficient for larger groups)
264 - New command
`listStickerPacks` to display all known sticker packs
265 - New flag
`--sticker` for
`send` command to send stickers
268 - Improve exit code for message sending.
269 Exit with
0 status code if the message was sent successfully to at least
270 one recipient, otherwise exit with status code
2 or
4 (for untrusted).
271 - Download profiles in parallel for improved perfomance
272 - `--verbose` flag can be specified multiple times for additional log output
273 - Enable more security options for systemd service file
274 - Rename sandbox to staging environment, to match the upstream name.
277 - The first incoming message after registration can now always be decrypted successfully
278 - Ignore decryption failures from blocked contacts and don't send a resend request.
280 ## [0.10.0] - 2021-12-11
281 **Attention**: Now requires Java
17 and libsignal-client version
0.11
284 - The daemon command now provides a JSON-RPC based socket interface (
`--socket` and
`--tcp`)
285 - New daemon command flag
`--receive-mode` to configure when messages are received
286 - New daemon command flag
`--no-receive-stdout` to prevent outputting messages on stdout
287 - New command
`listAccounts` that lists all registered local accounts
288 - New command
`removeContact`
289 - Extend
`send` command to allow sending mentions (
`--mention`) and quotes (
`--quote-timestamp`,
`--quote-author`,
`--quote-message`,
`--quote-mention`)
290 - New dbus methods sendGroupTying, unregister, deleteAccount
291 - New dbus events MessageReceivedV2, ReceiptReceivedV2, SyncMessageReceivedV2 that provide an extras parameter with additional message info as a key/value map
292 - New dbus method sendViewedReceipt (Thanks @John Freed)
293 - New dbus object Configuration to read and update configuration values (Thanks @John Freed)
294 - Payment info in json receive output (Thanks @technillogue)
295 - `-c` alias for
`--config` (Thanks @technillogue)
298 - libzkgroup dependency is no longer required
299 - Renamed
`-u` and
`--username` flags to
`-a` and
`--account` to prevent confusion with upcoming Signal usernames. The old flags are also still supported for now.
300 - Respect phone number sharing mode and unlisted state set by primary device
301 - Adapt register command to reactivate account if possible.
302 - dbus-java now uses Java
16 native unix sockets, which should provide better cross-platform compatibility
303 - If sending to a recipient fails (e.g. unregistered) signal-cli now exits with a success exit code and prints additional information about the failure.
306 - Registering an existing unregistered account now works reliably in daemon mode
307 - Fixed an issue with loading some old config files without UUID
308 - More reliable send behavior if some recipients are unregistered
310 ## [0.9.2] - 2021-10-24
312 - dbus
`listNumbers` method works again
315 - Improved provisioning error handling if the last steps fail
316 - Adapt behavior of receive command as dbus client to match normal mode
317 - Update captcha url for proof required handling
319 ## [0.9.1] - 2021-10-16
320 **Attention**: Now requires native libzkgroup version
0.8
323 - New command
`updateConfiguration` which allows setting configurations for linked devices
324 - Improved dbus daemon for group handling, groups are now exported as separate dbus objects
325 - Linked devices can be managed via dbus
326 - New dbus methods sendTyping and sendReadReceipt (Thanks @JtheSaw)
327 - New dbus methods submitRateLimitChallenge, isRegistered, listDevices, setExpirationTimer, sendContacts, sendSyncRequest, uploadStickerPack, setPin and removePin (Thanks @John Freed)
328 - New dbus method getSelfNumber
331 - Do not send message resend request to own device
332 - Allow message from pending member to accept group invitations
333 - Fix issue which could cause signal-cli to repeatedly send the same delivery receipts
334 - Reconnect websocket after connection loss
337 - Use new provisioning URL
`sgnl://linkdevice` instead of
`tsdevice:/`
338 - The gradle command to build a graalvm native image is now
`./gradlew nativeCompile`
340 ## [0.9.0] - 2021-09-12
341 **Attention**: Now requires native libsignal-client version
0.9
344 - Removed deprecated
`--json` parameter, use global parameter
`--output=json` instead
345 - Json output format of
`listGroups` command changed:
346 Members are now arrays of
`{"number":"...","uuid":"..."}` objects instead of arrays of strings.
347 - Removed deprecated fallback data paths, only
`$XDG_DATA_HOME/signal-cli` is used now
348 For those still using the old paths (
`$HOME/.config/signal`,
`$HOME/.config/textsecure`) you need to move those to the new location.
351 - New global parameter
`--trust-new-identities=always` to allow trusting any new identity key without verification
352 - New parameter
`--device-name` for
`updateAccount` command to change the device name (also works for the primary device)
353 - New SignalControl DBus interface, to register/verify/link new accounts
354 - New
`jsonRpc` command that provides a JSON-RPC based API on stdout/stdin
355 - Support for announcement groups
356 - New parameter
`--set-permission-send-messages` for
`updateGroup` to create an announcement group
357 - New
`sendReceipt` command to send read and viewed receipts
358 - Support for receiving sender key messages, mobile apps can now send messages more efficiently with server-side fan-out to groups with signal-cli members.
359 - Support for reading data from remote Signal storage. Now v2 groups will be shown after linking a new device.
360 - New
`submitRateLimitChallenge` command that can be used to lift some rate-limits by solving a captcha
363 - Store identity key correctly when sending a message after a recipient has changed keys
365 ## [0.8.5] - 2021-08-07
367 - Source name is included in JSON receive output (Thanks @technillogue)
370 - Allow updateContact command to only set expiration timer without requiring a name parameter
372 ## [0.8.4.1] - 2021-06-20
374 - Incorrect error handling in register command
376 ## [0.8.4] - 2021-06-13
377 **Attention**: Now requires native libsignal-client version
0.8.1
380 - New parameters for
`updateGroup` command for group v2 features:
381 `--description`,
`--remove-member`,
`--admin`,
`--remove-admin`,
`--reset-link`,
`--link`,
`--set-permission-add-member`,
`--set-permission-edit-details`,
`--expiration`
382 - New
`--admin` parameter for
`quitGroup` to set an admin before leaving the group
383 - New
`--delete` parameter for
`quitGroup`, to delete the local group data
384 - New 'sendTyping' command to send typing indicators
387 - Fixed issue that prevented registration with invalid locales
388 - Prevent last admin of a group from leaving the group
389 - All commands now show a short description with
`--help`
390 - Now a hint is shown if messages aren't received regularly
391 - Group edit conflicts are now resolved automatically
393 ## [0.8.3] - 2021-05-13
396 - Upgrading from account files with older profiles
397 - Building native image with graalvm
399 ## [0.8.2] - 2021-05-11
401 - A manual page for the DBus interface (Thanks @bublath, @exquo)
402 - Remote message delete command (Thanks @adaptivegarage)
403 - sendSyncRequest command to request complete contact/group list from primary device
404 - New
`--delete-account` argument for unregister (Dangerous)
405 - New
`--family-name` argument for updateProfile
408 - Sending reaction to group (Thanks @adaptivegarage)
409 - Displaying of address for messages from untrusted identities
410 - Handling of recipient number or uuid changes (e.g. after account deletions)
411 - Only respond to sync requests from primary device
412 - Display of quit group messages
415 - Unlimited strength crypto is now enabled automatically for JREs that require it (Thanks @i-infra)
416 - Only one identity key is stored per recipient and updated from profile (to match app behavior)
417 - updateContact, block and unblock are now disabled for linked devices
418 - After registering an empty profile is created so new groups can be joined immediately
419 - If message decryption fails due to a broken session, the session is automatically renewed
420 - Rework account storage for better reliability
421 - Improved device linking flow
422 - Allow relinking existing account
423 - Encrypt/Decrypt device names
425 ## [0.8.1] - 2021-03-02
427 - New dbus commands: updateProfile, listNumbers, getContactNumber, quitGroup, isContactBlocked, isGroupBlocked, isMember, joinGroup (Thanks @bublath)
428 - Additional output for json format: shared contacts (Thanks @Atomic-Bean)
429 - Improved plain text output to be more consistent and synced messages are now indented
432 - Issue with broken sessions with linked devices
435 - Behavior of
`trust` command improved, when trusting a new identity key all other known keys for
436 the same number are removed.
438 ## [0.8.0] - 2021-02-14
439 **Attention**: For all signal protocol functionality an additional native library is now required:
[libsignal-client](https://github.com/signalapp/libsignal-client/).
440 See https://github.com/AsamK/signal-cli/wiki/Provide-native-lib-for-libsignal for more information.
443 - Experimental support for building a GraalVM native image
444 - Support for setting profile about text and emoji
447 - Incorrect error message when removing a non-existent profile avatar
449 ## [0.7.4] - 2021-01-19
451 - Notify linked devices after profile has been updated
454 - After registering a new account, receiving messages didn't work
455 You may have to register and verify again to fix the issue.
456 - Creating v1 groups works again
458 ## [0.7.3] - 2021-01-17
460 - `getUserStatus` command to check if a user is registered on Signal (Thanks @Atomic-Bean)
461 - Global
`--verbose` flag to increase log level
462 - Global
`--output=json` flag, currently supported by
`receive`,
`daemon`,
`getUserStatus`,
`listGroups`
463 - `--note-to-self` flag for
`send` command to send a note to linked devices
464 - More info for received messages in json output: stickers, viewOnce, typing, remoteDelete
467 - signal-cli can now be used without the username
`-u` flag
468 For daemon command all local users will be exposed as dbus objects.
469 If only one local user exists, all other commands will use that user,
470 otherwise a user has to be specified.
471 - Messages sent to self number will be sent as normal Signal messages again, to
472 send a sync message, use the new
`--note-to-self` flag
473 - Ignore messages with group context sent by non group member
474 - Profile key is sent along with all direct messages
475 - In json output unnecessary fields that are null are now omitted
478 - Disable registration lock before removing the PIN
479 - Fix PIN hash version to match the official clients.
480 If you had previously set a PIN you need to set it again to be able to unlock the registration lock later.
481 - Issue with saving account file after linking
483 ## [0.7.2] - 2020-12-31
485 - Implement new registration lock PIN with
`setPin` and
`removePin` (with KBS)
486 - Include quotes, mentions and reactions in json output (Thanks @Atomic-Bean)
489 - Retrieve avatars for v2 groups
490 - Download attachment thumbnail for quoted attachments
492 ## [0.7.1] - 2020-12-21
494 - Accept group invitation with
`updateGroup -g GROUP_ID`
495 - Decline group invitation with
`quitGroup -g GROUP_ID`
496 - Join group via invitation link
`joinGroup --uri https://signal.group/#...`
499 - Include group ids for v2 groups in json output
501 ## [0.7.0] - 2020-12-15
503 Support for groups of new type/v2
504 - Sending and receiving
505 - Updating name, avatar and adding members with
`updateGroup`
506 - Quit group and decline invitation with
`quitGroup`
507 - In the
`listGroups` output v2 groups can be recognized by the longer groupId
509 **Attention**: For the new group support to work the native libzkgroup library is required.
510 See https://github.com/AsamK/signal-cli/wiki/Provide-native-lib-for-libsignal for more information.
513 - Rare NullPointerException when receiving messages
515 ## [0.6.12] - 2020-11-22
517 - Show additional message content (view once, remote delete, mention, …) for received messages
518 - `--captcha` parameter for
`register` command, required for some IP ranges
521 - Profile keys are now stored separately from contact list
522 - Receipts from normal and unidentified messages now have the same format in json output
525 - Issue where some messages were sent with an old counter index
527 ## [0.6.11] - 2020-10-14
528 - Fix issue with receiving message reactions
530 ## [0.6.10] - 2020-09-11
531 - Fix issue when retrieving profiles
532 - Workaround issue with libzkgroup on platforms other than linux x86_64
534 ## [0.6.9] - 2020-09-10
535 - Minor bug fixes and improvements
536 - dbus functionality now works on FreeBSD
537 - signal-cli now requires Java
11
539 **Warning: this version only works on Linux x86_64, will be fixed in
0.6.10**
541 ## [0.6.8] - 2020-05-22
542 - Switch to hypfvieh dbus-java, which doesn't require a native library anymore (drops requirement of libmatthew-unix-java)
543 - Bugfixes for messages with uuids
544 - Add
`--expiration` parameter to
`updateContact` command to set expiration timer
546 ## [0.6.7] - 2020-04-03
547 - Send command now returns the timestamp of the sent message
548 - DBus daemon: Publish received sync message to SyncMessageReceived signal
549 - Fix issue with resolving e164/uuid addresses for sessions
550 - Fix pack key length for sticker upload
552 ## [0.6.6] - 2020-03-29
553 - Added listContacts command
554 - Added block/unblock commands to block contacts and groups
555 - Added uploadStickerPack command to upload sticker packs (see man page for more details)
556 - Full support for sending and receiving unidentified sender messages
557 - Support for message reactions with emojis
558 - Internal: support recipients with uuids
560 ## [0.6.5] - 2019-11-11
561 Supports receiving messages sent with unidentified sender
563 ## [0.6.4] - 2019-11-02
564 - Fix rounding error for attachment ids in json output
565 - Add additional info to json output
566 - Add commands to update profile name and avatar
567 - Add command to update contact names
569 ## [0.6.3] - 2019-09-05
570 Bug fixes and small improvements
572 ## [0.6.2] - 2018-12-16
573 - Fixes sending of group messages
575 ## [0.6.1] - 2018-12-09
576 - Added getGroupIds dbus command
577 - Use "NativePRNG" pseudo random number generator, if available
578 - Switch default data path:
579 `$XDG_DATA_HOME/signal-cli` (
`$HOME/.local/share/signal-cli`)
580 Existing data paths will continue to work (used as fallback)
582 ## [0.6.0] - 2018-05-03
584 - dbus signal for receiving messages
585 - Registration lock PIN
586 - Output quoted message
588 ## [0.5.6] - 2017-06-16
589 * new listGroups command
590 * Support for attachments with file names
591 * Support for complete contacts sync
592 * Support for contact verification sync
595 * Get/Set contact info
597 ## [0.5.5] - 2017-02-18
598 - fix receiving messages on linked devices
599 - add unregister command
601 ## [0.5.4] - 2017-02-17
602 - Fix linking of new devices
604 ## [0.5.3] - 2017-01-29
605 * New commandline paramter for receive: --ignore-attachments
606 * Updated dependencies
608 ## [0.5.2] - 2016-12-16
609 - Add support for group info requests
610 - Improve closing of file streams
612 ## [0.5.1] - 2016-11-18
613 - Support new safety numbers
(https://whispersystems.org/blog/safety-number-updates/)
615 - Support sending disappearing messages, if the recipient has activated it
617 ## [0.5.0] - 2016-08-29
618 - Check if a number is registered on Signal, before adding it to a group
619 - Prevent sending to groups that the user has quit
620 - Commands to trust new identity keys (see README)
621 - Messages from untrusted identities are stored on disk and decrypted when the user trusts the identity
622 - Timestamps shown in ISO
8601 format
624 ## [0.4.1] - 2016-07-18
625 - Fix issue with creating groups
626 - Lock config file to prevent parallel access by multiple instances of signal-cli
627 - Improve return codes, always return non-zero code, when sending failed
629 ## [0.4.0] - 2016-06-19
630 - Linking to Signal-Desktop and Signal-Android is now possible (Provisioning)
631 - Added a contact store, mainly for syncing contacts with linked devices (editing not yet possible via cli)
632 - Avatars for groups and contacts are now stored (new folder "avatars" in the config path)
634 ## [0.3.1] - 2016-04-03
635 - Fix running with Oracle JRE
8
637 - Fix unicode warning when compiling with non utf8 locale
639 ## [0.3.0] - 2016-04-02
640 - Renamed textsecure-cli to signal-cli, following the rename of libtextsecure-java to libsignal-service-java
641 - The experimental dbus interface was also renamed to org.asamk.Signal
642 - Upload new prekeys to the server, when there are less than
20 left, prekeys are needed to create new sessions
644 ## [0.2.1] - 2016-02-10
645 - Improve dbus service
646 - New command line argument --config to specify config directory
648 ## [0.2.0] - 2015-12-30
649 Added an experimental dbus interface, for sending and receiving messages (The interface is unstable and may change with future releases).
651 This release works with Java
7 and
8.
653 ## [0.1.0] - 2015-11-28
654 Add support for creating/updating groups and sending to them
656 ## [0.0.5] - 2015-11-21
657 - Add receive timeout commandline parameter
658 - Show message group info
660 ## [0.0.4] - 2015-09-22
662 ## [0.0.3] - 2015-08-07
664 ## [0.0.2] - 2015-07-08