When searching by fingerprint, show any unauthenticated certificate.

- `sq cert list FINGERPRINT` does not show the certificate if the
    certificate could not be authenticated.  Since the user is
    searching by fingerprint, which is self authenticating, we don't
    run the risk of showing something irrelevant.  As such, always
    show the certificate in this case.

  - Fixes #408.
This commit is contained in:
Neal H. Walfield 2024-11-18 10:51:39 +01:00
parent 7d44c8e3d5
commit 01aa1d1619
No known key found for this signature in database
GPG Key ID: 6863C9AD5B4D22D3

View File

@ -75,7 +75,7 @@ pub fn authenticate<'store, 'rstore>(
gossip: bool, gossip: bool,
certification_network: bool, certification_network: bool,
trust_amount: Option<TrustAmount<usize>>, trust_amount: Option<TrustAmount<usize>>,
userid: Option<&userid_designator::UserIDDesignator>, userid_designator: Option<&userid_designator::UserIDDesignator>,
certificate: Option<&Cert>, certificate: Option<&Cert>,
show_paths: bool, show_paths: bool,
) -> Result<()> ) -> Result<()>
@ -109,8 +109,8 @@ pub fn authenticate<'store, 'rstore>(
let fingerprint: Option<Fingerprint> = certificate.map(|c| c.fingerprint()); let fingerprint: Option<Fingerprint> = certificate.map(|c| c.fingerprint());
let email = userid.map(|u| u.is_email()).unwrap_or(false); let email = userid_designator.map(|u| u.is_email()).unwrap_or(false);
let userid = userid.map(|u| u.value()); let userid = userid_designator.map(|u| u.value());
let mut bindings = Vec::new(); let mut bindings = Vec::new();
if matches!(userid, Some(_)) && email { if matches!(userid, Some(_)) && email {
@ -229,6 +229,7 @@ pub fn authenticate<'store, 'rstore>(
bindings.dedup(); bindings.dedup();
let mut authenticated = 0; let mut authenticated = 0;
let mut bindings_shown = 0;
let mut lint_input = true; let mut lint_input = true;
let mut output = ConciseHumanReadableOutputNetwork::new( let mut output = ConciseHumanReadableOutputNetwork::new(
@ -243,9 +244,18 @@ pub fn authenticate<'store, 'rstore>(
}; };
let aggregated_amount = paths.amount(); let aggregated_amount = paths.amount();
if aggregated_amount == 0 && ! gossip { if certificate.is_some() && userid_designator.is_none()
&& list_pattern.is_none()
{
// We're authenticating a certificate, which was
// specified. We don't consider it authenticated, but we
// do want to show it.
} else if aggregated_amount == 0 && ! gossip {
// We didn't authenticate the binding, and we're not in
// gossip mode. Don't show it.
continue; continue;
} }
lint_input = false; lint_input = false;
if gossip { if gossip {
authenticated += 1; authenticated += 1;
@ -253,6 +263,7 @@ pub fn authenticate<'store, 'rstore>(
authenticated += 1; authenticated += 1;
} }
bindings_shown += 1;
let paths = paths.into_iter().collect::<Vec<(wot::Path, usize)>>(); let paths = paths.into_iter().collect::<Vec<(wot::Path, usize)>>();
output.add_paths(paths, fingerprint, userid, aggregated_amount)?; output.add_paths(paths, fingerprint, userid, aggregated_amount)?;
@ -418,12 +429,12 @@ pub fn authenticate<'store, 'rstore>(
.arg("some-mail-address") .arg("some-mail-address")
.done(); .done();
} }
} else if bindings.len() - authenticated > 0 { } else if bindings.len() - bindings_shown > 0 {
// Some of the matching bindings are unauthenticated. Tell // Some of the matching bindings were not shown. Tell the
// the user about the `--gossip` option. // user about the `--gossip` option.
let bindings = bindings.len(); let bindings = bindings.len();
assert!(bindings > 0); assert!(bindings > 0);
let unauthenticated = bindings - authenticated; let bindings_not_shown = bindings - bindings_shown;
if bindings == 1 { if bindings == 1 {
wprintln!("1 binding found."); wprintln!("1 binding found.");
@ -431,12 +442,12 @@ pub fn authenticate<'store, 'rstore>(
wprintln!("{} bindings found.", bindings); wprintln!("{} bindings found.", bindings);
} }
if unauthenticated == 1 { if bindings_not_shown == 1 {
wprintln!("Skipped 1 binding, which could not be authenticated."); wprintln!("Skipped 1 binding, which could not be authenticated.");
wprintln!("Pass `--gossip` to see the unauthenticated binding."); wprintln!("Pass `--gossip` to see the unauthenticated binding.");
} else { } else {
wprintln!("Skipped {} bindings, which could not be authenticated.", wprintln!("Skipped {} bindings, which could not be authenticated.",
unauthenticated); bindings_not_shown);
wprintln!("Pass `--gossip` to see the unauthenticated bindings."); wprintln!("Pass `--gossip` to see the unauthenticated bindings.");
} }
} }