mirror of
https://github.com/str4d/rage.git
synced 2025-04-03 19:07:42 +03:00
Merge pull request #342 from str4d/330-prevent-encryption-to-no-recipients
Prevent `age::Encryptor` from being constructed with no recipients
This commit is contained in:
commit
59c9997f78
8 changed files with 31 additions and 8 deletions
|
@ -7,6 +7,8 @@ and this project adheres to Rust's notion of
|
|||
to 1.0.0 are beta releases.
|
||||
|
||||
## [Unreleased]
|
||||
### Changed
|
||||
- Migrated to `aead 0.5`.
|
||||
|
||||
## [0.8.0] - 2022-05-02
|
||||
### Added
|
||||
|
|
|
@ -12,6 +12,13 @@ to 1.0.0 are beta releases.
|
|||
### Added
|
||||
- `age::armor::ArmoredReadError`, used to wrap armor-specific read errors inside
|
||||
`std::io::Error`.
|
||||
- `age::ssh`:
|
||||
- `impl Clone for Identity`
|
||||
|
||||
### Changed
|
||||
- `age::Encryptor::with_recipients` now returns `Option<Encryptor>`, with `None`
|
||||
returned if the provided list of recipients is empty (to prevent files being
|
||||
encrypted to no recipients).
|
||||
|
||||
### Fixed
|
||||
- `age::Decryptor` now rejects invalid or non-canonical `scrypt` recipient
|
||||
|
|
|
@ -24,6 +24,7 @@ fn bench(c: &mut Criterion) {
|
|||
.map(|r| r as Box<dyn Recipient>)
|
||||
.collect(),
|
||||
)
|
||||
.unwrap()
|
||||
.wrap_output(&mut encrypted)
|
||||
.unwrap();
|
||||
output.write_all(&[]).unwrap();
|
||||
|
|
|
@ -53,6 +53,7 @@ fn bench(c: &mut Criterion_) {
|
|||
group.bench_function(BenchmarkId::new("encrypt", size), |b| {
|
||||
b.iter(|| {
|
||||
let mut output = Encryptor::with_recipients(vec![Box::new(recipient.clone())])
|
||||
.unwrap()
|
||||
.wrap_output(io::sink())
|
||||
.unwrap();
|
||||
output.write_all(&pt_buf[..size]).unwrap();
|
||||
|
@ -62,6 +63,7 @@ fn bench(c: &mut Criterion_) {
|
|||
|
||||
group.bench_function(BenchmarkId::new("decrypt", size), |b| {
|
||||
let mut output = Encryptor::with_recipients(vec![Box::new(recipient.clone())])
|
||||
.unwrap()
|
||||
.wrap_output(&mut ct_buf)
|
||||
.unwrap();
|
||||
output.write_all(&pt_buf[..size]).unwrap();
|
||||
|
|
|
@ -40,7 +40,8 @@
|
|||
//! // Encrypt the plaintext to a ciphertext...
|
||||
//! # fn encrypt(pubkey: age::x25519::Recipient, plaintext: &[u8]) -> Result<Vec<u8>, age::EncryptError> {
|
||||
//! let encrypted = {
|
||||
//! let encryptor = age::Encryptor::with_recipients(vec![Box::new(pubkey)]);
|
||||
//! let encryptor = age::Encryptor::with_recipients(vec![Box::new(pubkey)])
|
||||
//! .expect("we provided a recipient");
|
||||
//!
|
||||
//! let mut encrypted = vec![];
|
||||
//! let mut writer = encryptor.wrap_output(&mut encrypted)?;
|
||||
|
|
|
@ -59,10 +59,12 @@ enum EncryptorType {
|
|||
pub struct Encryptor(EncryptorType);
|
||||
|
||||
impl Encryptor {
|
||||
/// Returns an `Encryptor` that will create an age file encrypted to a list of
|
||||
/// Constructs an `Encryptor` that will create an age file encrypted to a list of
|
||||
/// recipients.
|
||||
pub fn with_recipients(recipients: Vec<Box<dyn Recipient>>) -> Self {
|
||||
Encryptor(EncryptorType::Keys(recipients))
|
||||
///
|
||||
/// Returns `None` if no recipients were provided.
|
||||
pub fn with_recipients(recipients: Vec<Box<dyn Recipient>>) -> Option<Self> {
|
||||
(!recipients.is_empty()).then(|| Encryptor(EncryptorType::Keys(recipients)))
|
||||
}
|
||||
|
||||
/// Returns an `Encryptor` that will create an age file encrypted with a passphrase.
|
||||
|
@ -242,7 +244,7 @@ mod tests {
|
|||
let test_msg = b"This is a test message. For testing.";
|
||||
|
||||
let mut encrypted = vec![];
|
||||
let e = Encryptor::with_recipients(recipients);
|
||||
let e = Encryptor::with_recipients(recipients).unwrap();
|
||||
{
|
||||
let mut w = e.wrap_output(&mut encrypted).unwrap();
|
||||
w.write_all(test_msg).unwrap();
|
||||
|
@ -269,7 +271,7 @@ mod tests {
|
|||
let mut cx = noop_context();
|
||||
|
||||
let mut encrypted = vec![];
|
||||
let e = Encryptor::with_recipients(recipients);
|
||||
let e = Encryptor::with_recipients(recipients).unwrap();
|
||||
{
|
||||
let w = {
|
||||
let f = e.wrap_async_output(&mut encrypted);
|
||||
|
|
|
@ -9,6 +9,11 @@ and this project adheres to Rust's notion of
|
|||
to 1.0.0 are beta releases.
|
||||
|
||||
## [Unreleased]
|
||||
### Fixed
|
||||
- Encryption now returns an error if the file would be encrypted to no
|
||||
recipients. This can occur if only `-R/--recipients-file` flags are provided,
|
||||
and they all point to files that contain only "#" prefixed comments and empty
|
||||
lines.
|
||||
|
||||
## [0.8.1] - 2022-06-18
|
||||
### Security
|
||||
|
|
|
@ -377,12 +377,15 @@ fn encrypt(opts: AgeOptions) -> Result<(), error::EncryptError> {
|
|||
return Err(error::EncryptError::MissingRecipients);
|
||||
}
|
||||
|
||||
age::Encryptor::with_recipients(read_recipients(
|
||||
match age::Encryptor::with_recipients(read_recipients(
|
||||
opts.recipient,
|
||||
opts.recipients_file,
|
||||
opts.identity,
|
||||
opts.max_work_factor,
|
||||
)?)
|
||||
)?) {
|
||||
Some(encryptor) => encryptor,
|
||||
None => return Err(error::EncryptError::MissingRecipients),
|
||||
}
|
||||
};
|
||||
|
||||
let (format, output_format) = if opts.armor {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue