mirror of
https://github.com/str4d/rage.git
synced 2025-04-04 11:27:43 +03:00
Add tests for invalid plugin name chars
This commit is contained in:
parent
3e3e6a8bd8
commit
b6c8f06096
5 changed files with 106 additions and 0 deletions
|
@ -461,3 +461,65 @@ impl<C: Callbacks> crate::Identity for IdentityPluginV1<C> {
|
||||||
self.unwrap_stanzas(stanzas.iter())
|
self.unwrap_stanzas(stanzas.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use crate::{Callbacks, DecryptError, EncryptError};
|
||||||
|
|
||||||
|
use super::{
|
||||||
|
Identity, IdentityPluginV1, Recipient, RecipientPluginV1, PLUGIN_IDENTITY_PREFIX,
|
||||||
|
PLUGIN_RECIPIENT_PREFIX,
|
||||||
|
};
|
||||||
|
|
||||||
|
const INVALID_PLUGIN_NAME: &str = "foobar/../../../../../../../usr/bin/echo";
|
||||||
|
|
||||||
|
struct NoCallbacks;
|
||||||
|
impl Callbacks for NoCallbacks {
|
||||||
|
fn prompt(&self, _: &str) {}
|
||||||
|
fn request_public_string(&self, _: &str) -> Option<String> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
fn request_passphrase(&self, _: &str) -> Option<secrecy::SecretString> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn recipient_rejects_invalid_chars() {
|
||||||
|
let invalid_recipient = bech32::encode(
|
||||||
|
&format!("{}{}", PLUGIN_RECIPIENT_PREFIX, INVALID_PLUGIN_NAME),
|
||||||
|
[],
|
||||||
|
bech32::Variant::Bech32,
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
|
assert!(invalid_recipient.parse::<Recipient>().is_err());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn identity_rejects_invalid_chars() {
|
||||||
|
let invalid_identity = bech32::encode(
|
||||||
|
&format!("{}{}-", PLUGIN_IDENTITY_PREFIX, INVALID_PLUGIN_NAME),
|
||||||
|
[],
|
||||||
|
bech32::Variant::Bech32,
|
||||||
|
)
|
||||||
|
.expect("HRP is valid")
|
||||||
|
.to_uppercase();
|
||||||
|
assert!(invalid_identity.parse::<Identity>().is_err());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn recipient_plugin_v1_rejects_invalid_chars() {
|
||||||
|
assert!(matches!(
|
||||||
|
RecipientPluginV1::new(INVALID_PLUGIN_NAME, &[], &[], NoCallbacks),
|
||||||
|
Err(EncryptError::MissingPlugin { binary_name }) if binary_name == INVALID_PLUGIN_NAME,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn identity_plugin_v1_rejects_invalid_chars() {
|
||||||
|
assert!(matches!(
|
||||||
|
IdentityPluginV1::new(INVALID_PLUGIN_NAME, &[], NoCallbacks),
|
||||||
|
Err(DecryptError::MissingPlugin { binary_name }) if binary_name == INVALID_PLUGIN_NAME,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBHUGc3Zlhpekp0K012aXdu
|
||||||
|
T1VZN0lmWlRmNjdLYVB4RldkTFVLTkNDUXlBCmJjRUcrM3E0a0U0N3IyK1JsTitG
|
||||||
|
dHVTd0N6TVFRTWgzdG5uSzJmNm9YMTgKLT4gQXQ1WWAtZ3JlYXNlIDxodGFSVHJg
|
||||||
|
IFg0cWYsO0ogZ2Fzc1EKZGtPSTB3Ci0tLSBKazRIaHJxdnNJcHpyclRkQjg3QW5r
|
||||||
|
SVE2MHdtWkErYTNrNWJibWd1bmNBCkK9FoOkiLB93gD79vNed8L3LM9rhKm5qma2
|
||||||
|
lSiwRx/aM1DKaZO0CMmYQkoM2tPReA==
|
||||||
|
-----END AGE ENCRYPTED FILE-----
|
13
rage/tests/cmd/rage/decrypt-invalid-identity-chars.toml
Normal file
13
rage/tests/cmd/rage/decrypt-invalid-identity-chars.toml
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
bin.name = "rage"
|
||||||
|
args = "--decrypt --identity - file.age.txt"
|
||||||
|
status = "failed"
|
||||||
|
stdin = """
|
||||||
|
AGE-PLUGIN-FOOBAR/../../../../../../../USR/BIN/ECHO-1HKGPY3
|
||||||
|
"""
|
||||||
|
stdout = ""
|
||||||
|
stderr = """
|
||||||
|
Error: identity file contains non-identity data on line 1
|
||||||
|
|
||||||
|
[ Did rage not do what you expected? Could an error be more useful? ]
|
||||||
|
[ Tell us: https://str4d.xyz/rage/report ]
|
||||||
|
"""
|
12
rage/tests/cmd/rage/decrypt-invalid-plugin-name-chars.toml
Normal file
12
rage/tests/cmd/rage/decrypt-invalid-plugin-name-chars.toml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
bin.name = "rage"
|
||||||
|
args = "--decrypt -j foobar/../../../../../../../usr/bin/echo"
|
||||||
|
status = "failed"
|
||||||
|
stdin = ""
|
||||||
|
stdout = ""
|
||||||
|
stderr = """
|
||||||
|
Error: Could not find 'foobar/../../../../../../../usr/bin/echo' on the PATH.
|
||||||
|
Have you installed the plugin?
|
||||||
|
|
||||||
|
[ Did rage not do what you expected? Could an error be more useful? ]
|
||||||
|
[ Tell us: https://str4d.xyz/rage/report ]
|
||||||
|
"""
|
11
rage/tests/cmd/rage/encrypt-invalid-recipient-chars.toml
Normal file
11
rage/tests/cmd/rage/encrypt-invalid-recipient-chars.toml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
bin.name = "rage"
|
||||||
|
args = "--encrypt --recipient age1foobar/../../../../../../../usr/bin/echo1849l6e"
|
||||||
|
status = "failed"
|
||||||
|
stdin = ""
|
||||||
|
stdout = ""
|
||||||
|
stderr = """
|
||||||
|
Error: Invalid recipient 'age1foobar/../../../../../../../usr/bin/echo1849l6e'.
|
||||||
|
|
||||||
|
[ Did rage not do what you expected? Could an error be more useful? ]
|
||||||
|
[ Tell us: https://str4d.xyz/rage/report ]
|
||||||
|
"""
|
Loading…
Add table
Add a link
Reference in a new issue