use crate::cli::command::CommandRequest;
#[derive(Debug, Clone, PartialEq, serde::Serialize, serde::Deserialize, schemars::JsonSchema)]
#[schemars(rename = "cli.command.viewer.config.get.Request")]
pub struct Request {
pub path_type: Path,
pub scope: crate::cli::command::GetScope,
#[serde(flatten)]
pub base: crate::cli::command::RequestBase,
}
#[derive(Debug, Clone, PartialEq, Eq, serde::Serialize, serde::Deserialize, schemars::JsonSchema)]
#[schemars(rename = "cli.command.viewer.config.get.Path")]
pub enum Path {
#[serde(rename = "viewer/config/get")]
ViewerConfigGet,
}
impl CommandRequest for Request {
fn into_command(&self) -> Vec<String> {
let mut argv = vec!["viewer".to_string(), "config".to_string(), "get".to_string()];
argv.push(match self.scope {
crate::cli::command::GetScope::Global => "--global".to_string(),
crate::cli::command::GetScope::State => "--state".to_string(),
crate::cli::command::GetScope::Final => "--final".to_string(),
});
self.base.push_flags(&mut argv);
argv
}
fn request_base(&self) -> &crate::cli::command::RequestBase {
&self.base
}
fn request_base_mut(&mut self) -> Option<&mut crate::cli::command::RequestBase> {
Some(&mut self.base)
}
}
#[derive(PartialEq, Debug, Clone, Default, serde::Serialize, serde::Deserialize, schemars::JsonSchema)]
#[schemars(rename = "cli.command.viewer.config.get.Response")]
pub struct Response {
#[serde(skip_serializing_if = "Option::is_none")]
#[schemars(extend("omitempty" = true))]
pub address: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
#[schemars(extend("omitempty" = true))]
pub secret: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
#[schemars(extend("omitempty" = true))]
pub signature: Option<String>,
}
#[derive(clap::Args)]
pub struct Args {
#[arg(long)]
pub global: bool,
#[arg(long)]
pub state: bool,
#[arg(long)]
pub r#final: bool,
#[command(flatten)]
pub base: crate::cli::command::RequestBaseArgs,
}
#[derive(clap::Args)]
#[command(args_conflicts_with_subcommands = true)]
pub struct Command {
#[command(flatten)]
pub args: Args,
#[command(subcommand)]
pub schema: Option<Schema>,
}
#[derive(clap::Subcommand)]
pub enum Schema {
RequestSchema(request_schema::Args),
ResponseSchema(response_schema::Args),
}
impl TryFrom<Args> for Request {
type Error = crate::cli::command::FromArgsError;
fn try_from(args: Args) -> Result<Self, Self::Error> {
let scope = match (args.global, args.state, args.r#final) {
(true, false, false) => crate::cli::command::GetScope::Global,
(false, true, false) => crate::cli::command::GetScope::State,
(false, false, true) => crate::cli::command::GetScope::Final,
_ => {
return Err(crate::cli::command::FromArgsError {
field: "scope",
source: crate::cli::command::FromArgsErrorSource::Plain(
"exactly one of --global, --state, --final is required".to_string(),
),
});
}
};
Ok(Self { path_type: Path::ViewerConfigGet,
scope,
base: args.base.into(),
})
}
}
#[cfg(feature = "cli-executor")]
pub async fn execute<E: crate::cli::command::CommandExecutor>(
executor: &E,
mut request: Request,
agent_arguments: Option<&crate::cli::command::AgentArguments>,
) -> Result<Response, E::Error> {
request.base.clear_transform();
executor.execute_one(request, agent_arguments).await
}
#[cfg(feature = "cli-executor")]
pub async fn execute_transform<E: crate::cli::command::CommandExecutor>(
executor: &E,
mut request: Request,
transform: crate::cli::command::Transform,
agent_arguments: Option<&crate::cli::command::AgentArguments>,
) -> Result<serde_json::Value, E::Error> {
request.base.set_transform(transform);
executor.execute_one(request, agent_arguments).await
}
#[cfg(feature = "mcp")]
impl crate::cli::command::CommandResponse for Response {
fn into_mcp(self) -> crate::cli::command::McpResponseItem {
crate::cli::command::McpResponseItem::JSONL(serde_json::to_value(self).unwrap())
}
}
pub mod request_schema;
pub mod response_schema;