mod create_csr;
mod create_ecc_key;
mod create_rsa_key;
mod decrypt;
mod delete_client;
mod delete_key;
mod encrypt;
mod export_public_key;
mod generate_random;
mod list_authenticators;
mod list_clients;
mod list_keys;
mod list_opcodes;
mod list_providers;
mod ping;
mod sign;
use crate::error::{Error::ParsecClientError, Result};
use crate::subcommands::{
create_csr::CreateCsr, create_ecc_key::CreateEccKey, create_rsa_key::CreateRsaKey,
decrypt::Decrypt, delete_client::DeleteClient, delete_key::DeleteKey, encrypt::Encrypt,
export_public_key::ExportPublicKey, generate_random::GenerateRandom,
list_authenticators::ListAuthenticators, list_clients::ListClients, list_keys::ListKeys,
list_opcodes::ListOpcodes, list_providers::ListProviders, ping::Ping, sign::Sign,
};
use parsec_client::BasicClient;
use structopt::StructOpt;
#[derive(Debug, StructOpt)]
pub enum Subcommand {
Ping(Ping),
ListProviders(ListProviders),
ListAuthenticators(ListAuthenticators),
ListOpcodes(ListOpcodes),
ListKeys(ListKeys),
GenerateRandom(GenerateRandom),
ExportPublicKey(ExportPublicKey),
CreateRsaKey(CreateRsaKey),
CreateEccKey(CreateEccKey),
Decrypt(Decrypt),
Sign(Sign),
DeleteKey(DeleteKey),
ListClients(ListClients),
DeleteClient(DeleteClient),
CreateCsr(CreateCsr),
Encrypt(Encrypt),
}
impl Subcommand {
pub fn run(&self, client: BasicClient) -> Result<()> {
match &self {
Subcommand::Ping(cmd) => cmd.run(client),
Subcommand::ListProviders(cmd) => cmd.run(client),
Subcommand::ListAuthenticators(cmd) => cmd.run(client),
Subcommand::ListKeys(cmd) => cmd.run(client),
Subcommand::ListClients(cmd) => cmd.run(client),
Subcommand::DeleteClient(cmd) => cmd.run(client),
Subcommand::ListOpcodes(cmd) => cmd.run(client),
Subcommand::GenerateRandom(cmd) => cmd.run(client),
Subcommand::ExportPublicKey(cmd) => cmd.run(client),
Subcommand::CreateRsaKey(cmd) => cmd.run(client),
Subcommand::CreateEccKey(cmd) => cmd.run(client),
Subcommand::Sign(cmd) => cmd.run(client),
Subcommand::Decrypt(cmd) => cmd.run(client),
Subcommand::DeleteKey(cmd) => cmd.run(client),
Subcommand::CreateCsr(cmd) => cmd.run(client),
Subcommand::Encrypt(cmd) => cmd.run(client),
}
}
fn authentication_required(&self) -> bool {
!matches!(
&self,
Subcommand::Ping(_)
| Subcommand::ListProviders(_)
| Subcommand::ListAuthenticators(_)
| Subcommand::ListOpcodes(_)
)
}
pub fn create_client(&self, app_name: Option<String>) -> Result<BasicClient> {
let client_result = if self.authentication_required() {
BasicClient::new(app_name)
} else {
BasicClient::new_naked()
};
match client_result {
Ok(client) => Ok(client),
Err(err) => Err(ParsecClientError(err)),
}
}
}