]> nmode's Git Repositories - signal-cli/blob - CHANGELOG.md
efefc6e3889e9293f9dbf64b2f7adb27b644981b
[signal-cli] / CHANGELOG.md
1 # Changelog
2
3 ## [Unreleased]
4
5 ## [0.11.1] - 2022-10-05
6
7 ### Fixed
8 - Fix sending group messages
9 - Fix store migration issue on Windows
10 - Fix building fat jars
11
12 ## [0.11.0] - 2022-10-02
13 **Attention**: Now requires native libsignal-client version 0.20.0
14
15 ### Breaking changes
16 - Changed meaning of `-v` flag from `--version` to `--verbose`.
17 So now extended logging can be achieved with `-vv`.
18 - Remove deprecated fallback to reading from stdin if no message body is given.
19 To read a message from stdin, use the `--message-from-stdin` flag.
20
21 ### Added
22 - Migrate PIN to new KBS enclave when Signal updates it
23 - Add `--scrub-log` flag to remove possibly sensitive information from the log
24 - Add `sendPaymentNotification` dbus method
25
26 ### Fixed
27 - Fix an issue where messages were sent without sender phone number
28
29 ### Changed
30 - Store data except base account data in sqlite database
31 - Use new CDSI for contact discovery in compat mode
32
33 ## [0.10.11] - 2022-08-17
34 **Attention**: Now requires native libsignal-client version 0.19.3
35
36 ### Added
37 - Output content of received story messages
38
39 ## [0.10.10] - 2022-07-30
40 **Attention**: Now requires native libsignal-client version 0.18.1
41
42 ### Fixed
43 - Fix setPin/removePin commands which broke due to server side changes
44 - Workaround GraalVM 22.2.0 issue with daemon connection
45
46 ## [0.10.9] - 2022-07-16
47
48 ### Changed
49 - updateAccount command checks self number and PNI after updating account attributes
50
51 ### Fixed
52 - Fixed small issue with syncing contacts from storage
53 - Fixed issue with opening older account files
54
55 ## [0.10.8] - 2022-06-13
56
57 ### Added
58 - Attachments can now be given as data: URIs with base64 data instead of just file paths (Thanks @KevinRoebert)
59 - `version` command can now be used on the commandline, in addition to the `--version` flag.
60 In the next version the current short form `-v` will change its meaning to `--verbose`!
61
62 ### Improved
63 - An account can now be registered on both LIVE and STAGING environment in the same config directory.
64 - Logging output for registering has been extended.
65
66 ## [0.10.7] - 2022-05-29
67
68 ### Added
69 - Added profile information to `listContacts` command output
70 - Added filter flags for `listContacts` command
71 - New `sendPaymentNotification` command to send payment receipt blobs
72 - New `--given-name` and `--family-name` parameters for `updateContact` command
73 - Implement sending link previews with `--preview-url`, `--preview-title` parameters for the `send` command
74 - New `--send-read-receipts` parameter for `receive` and `daemon` commands for automatically marking received messages as read
75
76 ### Fixed
77 - Issue with endless growing `pre-keys-pni` data directory
78
79 ## [0.10.6] - 2022-05-19
80 **Attention**: Now requires native libsignal-client version 0.17
81
82 ### Added
83 - Check if account is used on the environment it was registered (live or staging)
84 - New command `deleteLocalAccountData` to delete all local data of an unregistered account
85 - New parameter `-g` for `listGroups` command to filter for specific groups
86
87 ### Fixed
88 - Fix deleting a recipient which has no uuid
89
90 ### Changed
91 - Show warning when sending a message and no profile name has been set.
92 (A profile name may become mandatory in the future)
93 - After blocking a contact/group the profile key is now rotated
94 - Only update profile keys from authoritative group changes
95
96 ## [0.10.5] - 2022-04-11
97 **Attention**: Now requires native libsignal-client version 0.15
98
99 ### Added
100 - New `--ban`, `--unban` flags for `updateGroup` command to ban users from joining by group link
101
102 ### Fixed
103 - Fix plain text output of blocked group ids
104 - Fix error output in case of rate limiting
105 - Fix error when creating a group with no members
106 - Fix adding recent Signal-Desktop versions as linked devices
107
108 ## [0.10.4.2] - 2022-03-17
109 ### Fixed
110 - Crash in json output when receiving message from untrusted identity
111 - Fix multi account commands for newly created accounts
112
113 ## [0.10.4.1] - 2022-03-02
114 ### Fixed
115 - Linking to current apps (which currently don't include a PNI identity yet)
116 - Show better error message when --target-timestamp is missing for sendReceipt
117
118 ## [0.10.4] - 2022-02-20
119 ### Added
120 - Implement support for change number as linked device
121 - Add `--message-from-stdin` flag for send command. The current behavior of
122 reading from stdin if the `-m` flag is not given, will be removed in a future
123 version.
124
125 ### Changed
126 - Align receive timeout behavior for dbus client with cli and JSON-RPC.
127 Timeout is reset by every incoming message
128 - Renamed `error` field in json receive response to `exception`
129
130 ### Fixed
131 - Prevent a stale jsonrpc connection from interfering with message receiving
132
133 ## [0.10.3] - 2022-02-01
134 ### Added
135 - MessageSendLog to cache sent message for 24h.
136 For resending messages in case the recipient fails to decrypt the message.
137 - New global `--log-file` parameter to write logs to a separate file.
138 (`--verbose` can be used to increase the log level)
139
140 ### Improved
141 - Better subscription handling for JSON-RPC `subscribeReceive` command
142
143 ### Fixed
144 - Output receipt data for unsealed sender receipts again
145 - Fix sending message resend requests to devices that happen to have the same deviceId
146
147 ## [0.10.2] - 2022-01-22
148 ### Fixed
149 - Archive old sessions/sender keys when a recipient's identity key has changed
150 - Fix profile fetch with an invalid LANG variable
151
152 ## [0.10.1] - 2022-01-16
153 ### Added
154 - Send group messages with sender keys (more efficient for larger groups)
155 - New command `listStickerPacks` to display all known sticker packs
156 - New flag `--sticker` for `send` command to send stickers
157
158 ### Changed
159 - Improve exit code for message sending.
160 Exit with 0 status code if the message was sent successfully to at least
161 one recipient, otherwise exit with status code 2 or 4 (for untrusted).
162 - Download profiles in parallel for improved perfomance
163 - `--verbose` flag can be specified multiple times for additional log output
164 - Enable more security options for systemd service file
165 - Rename sandbox to staging environment, to match the upstream name.
166
167 ### Fixed
168 - The first incoming message after registration can now always be decrypted successfully
169 - Ignore decryption failures from blocked contacts and don't send a resend request.
170
171 ## [0.10.0] - 2021-12-11
172 **Attention**: Now requires Java 17 and libsignal-client version 0.11
173
174 ### Added
175 - The daemon command now provides a JSON-RPC based socket interface (`--socket` and `--tcp`)
176 - New daemon command flag `--receive-mode` to configure when messages are received
177 - New daemon command flag `--no-receive-stdout` to prevent outputting messages on stdout
178 - New command `listAccounts` that lists all registered local accounts
179 - New command `removeContact`
180 - Extend `send` command to allow sending mentions (`--mention`) and quotes (`--quote-timestamp`, `--quote-author`, `--quote-message`, `--quote-mention`)
181 - New dbus methods sendGroupTying, unregister, deleteAccount
182 - New dbus events MessageReceivedV2, ReceiptReceivedV2, SyncMessageReceivedV2 that provide an extras parameter with additional message info as a key/value map
183 - New dbus method sendViewedReceipt (Thanks @John Freed)
184 - New dbus object Configuration to read and update configuration values (Thanks @John Freed)
185 - Payment info in json receive output (Thanks @technillogue)
186 - `-c` alias for `--config` (Thanks @technillogue)
187
188 ### Changed
189 - libzkgroup dependency is no longer required
190 - 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.
191 - Respect phone number sharing mode and unlisted state set by primary device
192 - Adapt register command to reactivate account if possible.
193 - dbus-java now uses Java 16 native unix sockets, which should provide better cross-platform compatibility
194 - 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.
195
196 ### Fixed
197 - Registering an existing unregistered account now works reliably in daemon mode
198 - Fixed an issue with loading some old config files without UUID
199 - More reliable send behavior if some recipients are unregistered
200
201 ## [0.9.2] - 2021-10-24
202 ### Fixed
203 - dbus `listNumbers` method works again
204
205 ### Changed
206 - Improved provisioning error handling if the last steps fail
207 - Adapt behavior of receive command as dbus client to match normal mode
208 - Update captcha url for proof required handling
209
210 ## [0.9.1] - 2021-10-16
211 **Attention**: Now requires native libzkgroup version 0.8
212
213 ### Added
214 - New command `updateConfiguration` which allows setting configurations for linked devices
215 - Improved dbus daemon for group handling, groups are now exported as separate dbus objects
216 - Linked devices can be managed via dbus
217 - New dbus methods sendTyping and sendReadReceipt (Thanks @JtheSaw)
218 - New dbus methods submitRateLimitChallenge, isRegistered, listDevices, setExpirationTimer, sendContacts, sendSyncRequest, uploadStickerPack, setPin and removePin (Thanks @John Freed)
219 - New dbus method getSelfNumber
220
221 ### Fixed
222 - Do not send message resend request to own device
223 - Allow message from pending member to accept group invitations
224 - Fix issue which could cause signal-cli to repeatedly send the same delivery receipts
225 - Reconnect websocket after connection loss
226
227 ### Changed
228 - Use new provisioning URL `sgnl://linkdevice` instead of `tsdevice:/`
229 - The gradle command to build a graalvm native image is now `./gradlew nativeCompile`
230
231 ## [0.9.0] - 2021-09-12
232 **Attention**: Now requires native libsignal-client version 0.9
233
234 ### Breaking changes
235 - Removed deprecated `--json` parameter, use global parameter `--output=json` instead
236 - Json output format of `listGroups` command changed:
237 Members are now arrays of `{"number":"...","uuid":"..."}` objects instead of arrays of strings.
238 - Removed deprecated fallback data paths, only `$XDG_DATA_HOME/signal-cli` is used now
239 For those still using the old paths (`$HOME/.config/signal`, `$HOME/.config/textsecure`) you need to move those to the new location.
240
241 ### Added
242 - New global parameter `--trust-new-identities=always` to allow trusting any new identity key without verification
243 - New parameter `--device-name` for `updateAccount` command to change the device name (also works for the primary device)
244 - New SignalControl DBus interface, to register/verify/link new accounts
245 - New `jsonRpc` command that provides a JSON-RPC based API on stdout/stdin
246 - Support for announcement groups
247 - New parameter `--set-permission-send-messages` for `updateGroup` to create an announcement group
248 - New `sendReceipt` command to send read and viewed receipts
249 - 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.
250 - Support for reading data from remote Signal storage. Now v2 groups will be shown after linking a new device.
251 - New `submitRateLimitChallenge` command that can be used to lift some rate-limits by solving a captcha
252
253 ### Fixed
254 - Store identity key correctly when sending a message after a recipient has changed keys
255
256 ## [0.8.5] - 2021-08-07
257 ### Added
258 - Source name is included in JSON receive output (Thanks @technillogue)
259
260 ### Fixed
261 - Allow updateContact command to only set expiration timer without requiring a name parameter
262
263 ## [0.8.4.1] - 2021-06-20
264 ### Fixed
265 - Incorrect error handling in register command
266
267 ## [0.8.4] - 2021-06-13
268 **Attention**: Now requires native libsignal-client version 0.8.1
269
270 ### Added
271 - New parameters for `updateGroup` command for group v2 features:
272 `--description`, `--remove-member`, `--admin`, `--remove-admin`, `--reset-link`, `--link`, `--set-permission-add-member`, `--set-permission-edit-details`, `--expiration`
273 - New `--admin` parameter for `quitGroup` to set an admin before leaving the group
274 - New `--delete` parameter for `quitGroup`, to delete the local group data
275 - New 'sendTyping' command to send typing indicators
276
277 ### Fixed
278 - Fixed issue that prevented registration with invalid locales
279 - Prevent last admin of a group from leaving the group
280 - All commands now show a short description with `--help`
281 - Now a hint is shown if messages aren't received regularly
282 - Group edit conflicts are now resolved automatically
283
284 ## [0.8.3] - 2021-05-13
285
286 ### Fixed
287 - Upgrading from account files with older profiles
288 - Building native image with graalvm
289
290 ## [0.8.2] - 2021-05-11
291 ### Added
292 - A manual page for the DBus interface (Thanks @bublath, @exquo)
293 - Remote message delete command (Thanks @adaptivegarage)
294 - sendSyncRequest command to request complete contact/group list from primary device
295 - New `--delete-account` argument for unregister (Dangerous)
296 - New `--family-name` argument for updateProfile
297
298 ### Fixed
299 - Sending reaction to group (Thanks @adaptivegarage)
300 - Displaying of address for messages from untrusted identities
301 - Handling of recipient number or uuid changes (e.g. after account deletions)
302 - Only respond to sync requests from primary device
303 - Display of quit group messages
304
305 ### Changed
306 - Unlimited strength crypto is now enabled automatically for JREs that require it (Thanks @i-infra)
307 - Only one identity key is stored per recipient and updated from profile (to match app behavior)
308 - updateContact, block and unblock are now disabled for linked devices
309 - After registering an empty profile is created so new groups can be joined immediately
310 - If message decryption fails due to a broken session, the session is automatically renewed
311 - Rework account storage for better reliability
312 - Improved device linking flow
313 - Allow relinking existing account
314 - Encrypt/Decrypt device names
315
316 ## [0.8.1] - 2021-03-02
317 ### Added
318 - New dbus commands: updateProfile, listNumbers, getContactNumber, quitGroup, isContactBlocked, isGroupBlocked, isMember, joinGroup (Thanks @bublath)
319 - Additional output for json format: shared contacts (Thanks @Atomic-Bean)
320 - Improved plain text output to be more consistent and synced messages are now indented
321
322 ### Fixed
323 - Issue with broken sessions with linked devices
324
325 ### Changed
326 - Behavior of `trust` command improved, when trusting a new identity key all other known keys for
327 the same number are removed.
328
329 ## [0.8.0] - 2021-02-14
330 **Attention**: For all signal protocol functionality an additional native library is now required: [libsignal-client](https://github.com/signalapp/libsignal-client/).
331 See https://github.com/AsamK/signal-cli/wiki/Provide-native-lib-for-libsignal for more information.
332
333 ### Added
334 - Experimental support for building a GraalVM native image
335 - Support for setting profile about text and emoji
336
337 ### Fixed
338 - Incorrect error message when removing a non-existent profile avatar
339
340 ## [0.7.4] - 2021-01-19
341 ### Changed
342 - Notify linked devices after profile has been updated
343
344 ### Fixed
345 - After registering a new account, receiving messages didn't work
346 You may have to register and verify again to fix the issue.
347 - Creating v1 groups works again
348
349 ## [0.7.3] - 2021-01-17
350 ### Added
351 - `getUserStatus` command to check if a user is registered on Signal (Thanks @Atomic-Bean)
352 - Global `--verbose` flag to increase log level
353 - Global `--output=json` flag, currently supported by `receive`, `daemon`, `getUserStatus`, `listGroups`
354 - `--note-to-self` flag for `send` command to send a note to linked devices
355 - More info for received messages in json output: stickers, viewOnce, typing, remoteDelete
356
357 ### Changed
358 - signal-cli can now be used without the username `-u` flag
359 For daemon command all local users will be exposed as dbus objects.
360 If only one local user exists, all other commands will use that user,
361 otherwise a user has to be specified.
362 - Messages sent to self number will be sent as normal Signal messages again, to
363 send a sync message, use the new `--note-to-self` flag
364 - Ignore messages with group context sent by non group member
365 - Profile key is sent along with all direct messages
366 - In json output unnecessary fields that are null are now omitted
367
368 ### Fixed
369 - Disable registration lock before removing the PIN
370 - Fix PIN hash version to match the official clients.
371 If you had previously set a PIN you need to set it again to be able to unlock the registration lock later.
372 - Issue with saving account file after linking
373
374 ## [0.7.2] - 2020-12-31
375 ### Added
376 - Implement new registration lock PIN with `setPin` and `removePin` (with KBS)
377 - Include quotes, mentions and reactions in json output (Thanks @Atomic-Bean)
378
379 ### Fixed
380 - Retrieve avatars for v2 groups
381 - Download attachment thumbnail for quoted attachments
382
383 ## [0.7.1] - 2020-12-21
384 ### Added
385 - Accept group invitation with `updateGroup -g GROUP_ID`
386 - Decline group invitation with `quitGroup -g GROUP_ID`
387 - Join group via invitation link `joinGroup --uri https://signal.group/#...`
388
389 ### Fixed
390 - Include group ids for v2 groups in json output
391
392 ## [0.7.0] - 2020-12-15
393 ### Added
394 Support for groups of new type/v2
395 - Sending and receiving
396 - Updating name, avatar and adding members with `updateGroup`
397 - Quit group and decline invitation with `quitGroup`
398 - In the `listGroups` output v2 groups can be recognized by the longer groupId
399
400 **Attention**: For the new group support to work the native libzkgroup library is required.
401 See https://github.com/AsamK/signal-cli/wiki/Provide-native-lib-for-libsignal for more information.
402
403 ### Fixed
404 - Rare NullPointerException when receiving messages
405
406 ## [0.6.12] - 2020-11-22
407 ### Added
408 - Show additional message content (view once, remote delete, mention, …) for received messages
409 - `--captcha` parameter for `register` command, required for some IP ranges
410
411 ### Changed
412 - Profile keys are now stored separately from contact list
413 - Receipts from normal and unidentified messages now have the same format in json output
414
415 ### Fixed
416 - Issue where some messages were sent with an old counter index
417
418 ## [0.6.11] - 2020-10-14
419 - Fix issue with receiving message reactions
420
421 ## [0.6.10] - 2020-09-11
422 - Fix issue when retrieving profiles
423 - Workaround issue with libzkgroup on platforms other than linux x86_64
424
425 ## [0.6.9] - 2020-09-10
426 - Minor bug fixes and improvements
427 - dbus functionality now works on FreeBSD
428 - signal-cli now requires Java 11
429
430 **Warning: this version only works on Linux x86_64, will be fixed in 0.6.10**
431
432 ## [0.6.8] - 2020-05-22
433 - Switch to hypfvieh dbus-java, which doesn't require a native library anymore (drops requirement of libmatthew-unix-java)
434 - Bugfixes for messages with uuids
435 - Add `--expiration` parameter to `updateContact` command to set expiration timer
436
437 ## [0.6.7] - 2020-04-03
438 - Send command now returns the timestamp of the sent message
439 - DBus daemon: Publish received sync message to SyncMessageReceived signal
440 - Fix issue with resolving e164/uuid addresses for sessions
441 - Fix pack key length for sticker upload
442
443 ## [0.6.6] - 2020-03-29
444 - Added listContacts command
445 - Added block/unblock commands to block contacts and groups
446 - Added uploadStickerPack command to upload sticker packs (see man page for more details)
447 - Full support for sending and receiving unidentified sender messages
448 - Support for message reactions with emojis
449 - Internal: support recipients with uuids
450
451 ## [0.6.5] - 2019-11-11
452 Supports receiving messages sent with unidentified sender
453
454 ## [0.6.4] - 2019-11-02
455 - Fix rounding error for attachment ids in json output
456 - Add additional info to json output
457 - Add commands to update profile name and avatar
458 - Add command to update contact names
459
460 ## [0.6.3] - 2019-09-05
461 Bug fixes and small improvements
462
463 ## [0.6.2] - 2018-12-16
464 - Fixes sending of group messages
465
466 ## [0.6.1] - 2018-12-09
467 - Added getGroupIds dbus command
468 - Use "NativePRNG" pseudo random number generator, if available
469 - Switch default data path:
470 `$XDG_DATA_HOME/signal-cli` (`$HOME/.local/share/signal-cli`)
471 Existing data paths will continue to work (used as fallback)
472
473 ## [0.6.0] - 2018-05-03
474 - Simple json output
475 - dbus signal for receiving messages
476 - Registration lock PIN
477 - Output quoted message
478
479 ## [0.5.6] - 2017-06-16
480 * new listGroups command
481 * Support for attachments with file names
482 * Support for complete contacts sync
483 * Support for contact verification sync
484 * DBus interface:
485 * Get/Set group info
486 * Get/Set contact info
487
488 ## [0.5.5] - 2017-02-18
489 - fix receiving messages on linked devices
490 - add unregister command
491
492 ## [0.5.4] - 2017-02-17
493 - Fix linking of new devices
494
495 ## [0.5.3] - 2017-01-29
496 * New commandline paramter for receive: --ignore-attachments
497 * Updated dependencies
498
499 ## [0.5.2] - 2016-12-16
500 - Add support for group info requests
501 - Improve closing of file streams
502
503 ## [0.5.1] - 2016-11-18
504 - Support new safety numbers (https://whispersystems.org/blog/safety-number-updates/)
505 - Add a man page
506 - Support sending disappearing messages, if the recipient has activated it
507
508 ## [0.5.0] - 2016-08-29
509 - Check if a number is registered on Signal, before adding it to a group
510 - Prevent sending to groups that the user has quit
511 - Commands to trust new identity keys (see README)
512 - Messages from untrusted identities are stored on disk and decrypted when the user trusts the identity
513 - Timestamps shown in ISO 8601 format
514
515 ## [0.4.1] - 2016-07-18
516 - Fix issue with creating groups
517 - Lock config file to prevent parallel access by multiple instances of signal-cli
518 - Improve return codes, always return non-zero code, when sending failed
519
520 ## [0.4.0] - 2016-06-19
521 - Linking to Signal-Desktop and Signal-Android is now possible (Provisioning)
522 - Added a contact store, mainly for syncing contacts with linked devices (editing not yet possible via cli)
523 - Avatars for groups and contacts are now stored (new folder "avatars" in the config path)
524
525 ## [0.3.1] - 2016-04-03
526 - Fix running with Oracle JRE 8
527 - Fix registering
528 - Fix unicode warning when compiling with non utf8 locale
529
530 ## [0.3.0] - 2016-04-02
531 - Renamed textsecure-cli to signal-cli, following the rename of libtextsecure-java to libsignal-service-java
532 - The experimental dbus interface was also renamed to org.asamk.Signal
533 - Upload new prekeys to the server, when there are less than 20 left, prekeys are needed to create new sessions
534
535 ## [0.2.1] - 2016-02-10
536 - Improve dbus service
537 - New command line argument --config to specify config directory
538
539 ## [0.2.0] - 2015-12-30
540 Added an experimental dbus interface, for sending and receiving messages (The interface is unstable and may change with future releases).
541
542 This release works with Java 7 and 8.
543
544 ## [0.1.0] - 2015-11-28
545 Add support for creating/updating groups and sending to them
546
547 ## [0.0.5] - 2015-11-21
548 - Add receive timeout commandline parameter
549 - Show message group info
550
551 ## [0.0.4] - 2015-09-22
552
553 ## [0.0.3] - 2015-08-07
554
555 ## [0.0.2] - 2015-07-08
556 First release