Commit graph

475 commits

Author SHA1 Message Date
Jack Grigg
0780882307 Update changelog with GHSA for security vulnerability
Thanks to ⬡-49016 for reporting this issue.
2024-12-18 15:18:02 +00:00
Jack Grigg
a82a76a849 v0.11.1 2024-11-18 07:11:33 +00:00
Jack Grigg
383b6f52aa Replace the test NoCallbacks with the library version 2024-11-18 07:06:16 +00:00
Jack Grigg
741de973ee Merge branch 'bugfix-0.10.1' into bugfix-0.11.1 2024-11-18 07:04:30 +00:00
Jack Grigg
62f15b9d9d v0.10.1 2024-11-18 06:56:17 +00:00
Jack Grigg
e48bab7b3c Merge branch 'bugfix-0.9.3' into bugfix-0.10.1 2024-11-18 06:53:17 +00:00
Jack Grigg
2b501beff2 v0.9.3 2024-11-18 06:46:08 +00:00
Jack Grigg
bbe157839f Merge branch 'bugfix-0.8.2' into bugfix-0.9.3 2024-11-18 06:44:52 +00:00
Jack Grigg
8673d5687e v0.8.2 2024-11-18 06:42:27 +00:00
Jack Grigg
951ffb9ede Merge branch 'bugfix-0.7.2' into bugfix-0.8.2 2024-11-18 06:40:52 +00:00
Jack Grigg
f8d0ef7154 v0.7.2 2024-11-18 06:40:16 +00:00
Jack Grigg
f70d84618b Apply plugin name restriction to 0.7 changes
The existing code was already panicking, but this gives it a nicer error
message.
2024-11-18 06:40:16 +00:00
Jack Grigg
650081765f Merge branch 'bugfix-0.6.1' into bugfix-0.7.2 2024-11-18 05:30:01 +00:00
Jack Grigg
5501bb6220 v0.6.1 2024-11-18 05:24:53 +00:00
Jack Grigg
703152ecfa Restrict set of valid characters for plugin names
Previously, plugin names were allowed to be `1*VCHAR`, which permits
path separators and parent directory syntax. Under certain conditions,
this could cause `rage` to execute a different binary than intended when
launching a plugin.

Plugin names are now restricted to alphanumeric characters or +-._ which
covers all binary names generally observed in practice.
2024-11-18 04:58:13 +00:00
Jack Grigg
b6c8f06096 Add tests for invalid plugin name chars 2024-11-18 04:41:20 +00:00
Jack Grigg
d35d442f91 v0.11.0 2024-11-03 10:42:17 +00:00
Jack Grigg
e3a5c5fe8c Update user handles in readmes 2024-11-03 10:41:37 +00:00
Jack Grigg
ae5a392925 Provide a better error on invalid filename or missing directory
Closes str4d/rage#530.
2024-11-03 08:22:43 +00:00
Jack Grigg
1d2b3bfa37 age: Merge error cases in cli_common::file_io 2024-11-03 08:04:59 +00:00
Jack Grigg
bca6916bac Update docs to permit multiple stanzas from recipients
Closes str4d/rage#524.
2024-11-03 07:30:16 +00:00
Jack Grigg
d0889c90af age: Document crate's calling contract of Identity::unwrap_stanza
Closes str4d/rage#509.
2024-11-03 07:04:20 +00:00
Jack Grigg
93fa28ad78 Migrate to secrecy 0.10 2024-11-03 05:38:51 +00:00
Jack Grigg
195b86b6bc age: Add streamlined APIs for encryption and decryption
Closes str4d/rage#333.
2024-08-30 11:34:01 -04:00
Jack Grigg
9ab26bf360 age: Take recipients by reference in Encryptor::with_recipients
This aligns it with `Decryptor`, and means that recipients can be
used to encrypt multiple files without cloning.

Part of str4d/rage#353.
2024-08-30 10:40:34 -04:00
Jack Grigg
67a539791b age: Adjust scrypt::Identity::set_max_work_factor docs
They are now consistent with `scrypt::Recipient::set_work_factor`.
2024-08-28 05:16:32 +00:00
Jack Grigg
e84159365d age: Add scrypt::Recipient::set_work_factor for overriding default
This can only be configured by using `scrypt::Recipient` directly in a
library context. The helper method `Encryptor::with_user_passphrase`
does not expose this, and `rage` continues to use the default.

Closes str4d/rage#383.
2024-08-28 05:16:32 +00:00
Jack Grigg
5a57e120a2 age: Don't exit peeking state if entire identity file fits in the buffer
This ensures we can call `PeekableReader::reset` when the file is a
single line without a trailing newline character, which rage-keygen does
not generate but users can.

Closes str4d/rage#484.
2024-08-28 02:56:58 +00:00
Jack Grigg
5e57ef07ca age: Return Box<dyn Identity> from IdentityFile::into_identities
This is doable now that `IdentityFile` stores callbacks, and is more
useful to crate users than `IdentityFileEntry`. The one place we were
relying on the latter was in `rage-keygen` to distinguish plugin
identities (which cannot be re-encoded as recipients); we now move that
functionality into the `age` crate.
2024-08-27 03:47:40 +00:00
Jack Grigg
f243d63c31 age: Improve documentation of Callbacks 2024-08-27 03:47:40 +00:00
Jack Grigg
ae2434216d age: Store C: Callbacks inside IdentityFile
This removes the need for explicit `callbacks` arguments in methods that
may act on plugin identities, and instead enables the caller to choose
whether or not to provide callbacks independently of plugin support
being compiled in. Enabling plugin support without providing callbacks
now has well-defined fallback behaviour via the default `NoCallbacks`
struct.
2024-08-27 03:47:40 +00:00
Jack Grigg
8dcdacc1ac age: Make recipients from encrypted identities more efficient
We now merge plugin recipients together, so we only run each plugin once
during encryption.
2024-08-27 03:47:40 +00:00
Jack Grigg
52fd675bbd age: Add IdentityFile::to_recipients 2024-08-27 03:47:40 +00:00
Jack Grigg
2f9cf3f86f age: Extract RecipientsAccumulator from cli_common::read_recipients 2024-08-27 03:47:40 +00:00
Jack Grigg
d31fb568b7 age: Pass entire IdentityFile to parse_identity_files closure 2024-08-23 22:49:47 +00:00
Jack Grigg
5086bd65d9 age: Remove two unnecessary clones from IdentityFileEntry decryption 2024-08-23 20:32:28 +00:00
Jack Grigg
cb36c4cd53 i18n-embed 0.15 2024-08-23 15:58:15 +00:00
Jack Grigg
7e3c62b98b age: Fix feature flag combination bugs in cli_common module 2024-08-23 12:37:24 +00:00
Jack Grigg
2d29668712 age: Add labels extension to client side of recipient-v1 2024-08-12 04:35:52 +00:00
Jack Grigg
8f1d6af149 age: Return label set from Recipient::wrap_file_key 2024-08-12 04:35:07 +00:00
Jack Grigg
8091015514 age: Add test that X25519 and scrypt recipients are incompatible 2024-08-10 06:53:39 +00:00
Jack Grigg
f69c29bf6f age: Clean up crate documentation 2024-07-29 03:05:38 +00:00
Jack Grigg
944f56a4a9 age: Remove EncryptorType 2024-07-29 03:05:38 +00:00
Jack Grigg
219ac41b60 age: Merge RecipientsDecryptor into Decryptor 2024-07-29 02:27:05 +00:00
Jack Grigg
a1f16094b8 age: Remove PassphraseDecryptor 2024-07-29 02:27:05 +00:00
Jack Grigg
f253ff2ff1 age: Expose scrypt::{Recipient, Identity} 2024-07-29 02:27:05 +00:00
Jack Grigg
4ba982254c age: Make scrypt::Identity an owning type 2024-07-29 02:27:05 +00:00
Jack Grigg
0c2acd5306 age: Move scrypt structural requirement checks to HeaderV1 2024-07-29 02:27:05 +00:00
Jack Grigg
67ee02b47e Update changelogs for partial French translations 2024-07-28 17:22:54 +00:00
AnomalRoil
96f89b3400
[i18n] Partial French translation (#499) 2024-07-19 00:26:09 +01:00