Add missing examples for the network commands.
- Except for `sq version`, and the intermediate subcommands (like `sq cert`), all commands now have examples. - Fixes #196.
This commit is contained in:
parent
356781e535
commit
1989acaf7a
@ -172,7 +172,8 @@ certificate is in turn certified as a minimally trusted CA (trust \
|
|||||||
amount: 1 of 120) by the local trust root. How much the DANE proxy CA \
|
amount: 1 of 120) by the local trust root. How much the DANE proxy CA \
|
||||||
is trusted can be tuned using `sq pki link add` or `sq pki link retract` \
|
is trusted can be tuned using `sq pki link add` or `sq pki link retract` \
|
||||||
in the usual way.
|
in the usual way.
|
||||||
"
|
",
|
||||||
|
after_help = SEARCH_EXAMPLES,
|
||||||
)]
|
)]
|
||||||
pub struct SearchCommand {
|
pub struct SearchCommand {
|
||||||
#[clap(
|
#[clap(
|
||||||
@ -196,3 +197,20 @@ pub struct SearchCommand {
|
|||||||
)]
|
)]
|
||||||
pub output: Option<FileOrStdout>,
|
pub output: Option<FileOrStdout>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const SEARCH_EXAMPLES: Actions = Actions {
|
||||||
|
actions: &[
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve Alice's certificate over DANE."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "dane", "search", "alice@example.org",
|
||||||
|
]).syntax_check(),
|
||||||
|
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve updates for all known certificates over DANE."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "dane", "search", "--all",
|
||||||
|
]).syntax_check(),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
test_examples!(sq_network_dane_search, SEARCH_EXAMPLES);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
use clap::{Args, Parser, Subcommand};
|
use clap::{Args, Parser, Subcommand};
|
||||||
|
|
||||||
|
use crate::cli::examples::*;
|
||||||
use crate::cli::types::ClapData;
|
use crate::cli::types::ClapData;
|
||||||
use crate::cli::types::FileOrCertStore;
|
use crate::cli::types::FileOrCertStore;
|
||||||
use crate::cli::types::FileOrStdout;
|
use crate::cli::types::FileOrStdout;
|
||||||
@ -69,7 +70,8 @@ is in turn certified as a minimally trusted CA (trust amount: 1 of \
|
|||||||
120) by the local trust root. How much a proxy key server CA is \
|
120) by the local trust root. How much a proxy key server CA is \
|
||||||
trusted can be tuned using `sq pki link add` or `sq pki link retract` in \
|
trusted can be tuned using `sq pki link add` or `sq pki link retract` in \
|
||||||
the usual way.
|
the usual way.
|
||||||
"
|
",
|
||||||
|
after_help = SEARCH_EXAMPLES,
|
||||||
)]
|
)]
|
||||||
pub struct SearchCommand {
|
pub struct SearchCommand {
|
||||||
#[clap(
|
#[clap(
|
||||||
@ -96,6 +98,40 @@ pub struct SearchCommand {
|
|||||||
pub query: Vec<String>,
|
pub query: Vec<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const SEARCH_EXAMPLES: Actions = Actions {
|
||||||
|
actions: &[
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve Alice's certificate from the default keyservers."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "keyserver", "search", "alice@example.org",
|
||||||
|
]).syntax_check(),
|
||||||
|
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve Alice's certificate addressed by fingerprint \
|
||||||
|
from the default keyservers."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "keyserver", "search",
|
||||||
|
"EB28F26E2739A4870ECC47726F0073F60FD0CBF0",
|
||||||
|
]).syntax_check(),
|
||||||
|
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve Alice's certificate from a non-default keyserver."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "keyserver", "search",
|
||||||
|
"--server=hkps://keys.example.org",
|
||||||
|
"alice@example.org",
|
||||||
|
]).syntax_check(),
|
||||||
|
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve updates for all known certificates from the default \
|
||||||
|
keyservers."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "keyserver", "search", "--all",
|
||||||
|
]).syntax_check(),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
test_examples!(sq_network_keyserver_search, SEARCH_EXAMPLES);
|
||||||
|
|
||||||
#[derive(Debug, Args)]
|
#[derive(Debug, Args)]
|
||||||
#[clap(
|
#[clap(
|
||||||
about = "Publish certificates on key servers",
|
about = "Publish certificates on key servers",
|
||||||
@ -107,6 +143,7 @@ default, the certificates are sent to {}. This can be tweaked using \
|
|||||||
`--servers`.
|
`--servers`.
|
||||||
",
|
",
|
||||||
join(DEFAULT_KEYSERVERS.iter().cloned())),
|
join(DEFAULT_KEYSERVERS.iter().cloned())),
|
||||||
|
after_help = PUBLISH_EXAMPLES,
|
||||||
)]
|
)]
|
||||||
pub struct PublishCommand {
|
pub struct PublishCommand {
|
||||||
#[command(flatten)]
|
#[command(flatten)]
|
||||||
@ -114,6 +151,18 @@ pub struct PublishCommand {
|
|||||||
CertPrefix>,
|
CertPrefix>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PUBLISH_EXAMPLES: Actions = Actions {
|
||||||
|
actions: &[
|
||||||
|
Action::example().comment(
|
||||||
|
"Publish Alice's certificate on the default keyservers."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "keyserver", "publish",
|
||||||
|
"--cert-email=alice@example.org",
|
||||||
|
]).syntax_check(),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
test_examples!(sq_network_keyserver_publish, PUBLISH_EXAMPLES);
|
||||||
|
|
||||||
/// Joins the given key server URLs into a list.
|
/// Joins the given key server URLs into a list.
|
||||||
fn join<'a>(i: impl Iterator<Item = &'a str>) -> String {
|
fn join<'a>(i: impl Iterator<Item = &'a str>) -> String {
|
||||||
let mut i = i.map(|u| format!("`{}`", u)).collect::<Vec<_>>();
|
let mut i = i.map(|u| format!("`{}`", u)).collect::<Vec<_>>();
|
||||||
|
@ -57,7 +57,8 @@ certificate is in turn certified as a minimally trusted CA (trust \
|
|||||||
amount: 1 of 120) by the local trust root. How much the WKD proxy CA \
|
amount: 1 of 120) by the local trust root. How much the WKD proxy CA \
|
||||||
is trusted can be tuned using `sq pki link add` or `sq pki link retract` \
|
is trusted can be tuned using `sq pki link add` or `sq pki link retract` \
|
||||||
in the usual way.
|
in the usual way.
|
||||||
"
|
",
|
||||||
|
after_help = SEARCH_EXAMPLES,
|
||||||
)]
|
)]
|
||||||
pub struct SearchCommand {
|
pub struct SearchCommand {
|
||||||
#[clap(
|
#[clap(
|
||||||
@ -82,6 +83,23 @@ pub struct SearchCommand {
|
|||||||
pub output: Option<FileOrStdout>,
|
pub output: Option<FileOrStdout>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const SEARCH_EXAMPLES: Actions = Actions {
|
||||||
|
actions: &[
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve Alice's certificate over WKD."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "dane", "search", "alice@example.org",
|
||||||
|
]).syntax_check(),
|
||||||
|
|
||||||
|
Action::example().comment(
|
||||||
|
"Retrieve updates for all known certificates over WKD."
|
||||||
|
).command(&[
|
||||||
|
"sq", "network", "dane", "search", "--all",
|
||||||
|
]).syntax_check(),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
test_examples!(sq_network_wkd_search, SEARCH_EXAMPLES);
|
||||||
|
|
||||||
const PUBLISH_EXAMPLES: Actions = Actions {
|
const PUBLISH_EXAMPLES: Actions = Actions {
|
||||||
actions: &[
|
actions: &[
|
||||||
Action::Setup(Setup {
|
Action::Setup(Setup {
|
||||||
|
Loading…
Reference in New Issue
Block a user