#![allow(clippy::result_large_err)]
use crate::APIClient;
use crate::arg_helpers::ArgMatchesExt;
use clap::ArgMatches;
use rabbitmq_http_client::blocking_api::Result as ClientResult;
use rabbitmq_http_client::responses::{SchemaDefinitionSyncStatus, WarmStandbyReplicationStatus};
pub fn sds_status_on_node(
client: APIClient,
command_args: &ArgMatches,
) -> ClientResult<SchemaDefinitionSyncStatus> {
let node = command_args.get_one::<String>("node");
client.schema_definition_sync_status(node.map(|s| s.as_str()))
}
pub fn sds_enable_cluster_wide(client: APIClient) -> ClientResult<()> {
client.enable_schema_definition_sync_on_node(None)
}
pub fn sds_disable_cluster_wide(client: APIClient) -> ClientResult<()> {
client.disable_schema_definition_sync_on_node(None)
}
pub fn sds_enable_on_node(client: APIClient, command_args: &ArgMatches) -> ClientResult<()> {
let node = command_args.str_arg("node");
client.enable_schema_definition_sync_on_node(Some(node))
}
pub fn sds_disable_on_node(client: APIClient, command_args: &ArgMatches) -> ClientResult<()> {
let node = command_args.str_arg("node");
client.disable_schema_definition_sync_on_node(Some(node))
}
pub fn wsr_status(client: APIClient) -> ClientResult<WarmStandbyReplicationStatus> {
client.warm_standby_replication_status()
}