diff options
author | Alex Auvolat <lx@deuxfleurs.fr> | 2025-01-31 15:53:02 +0100 |
---|---|---|
committer | Alex Auvolat <lx@deuxfleurs.fr> | 2025-02-03 18:54:51 +0100 |
commit | 7b9c047b113d78dacbece4670b8a1a1cbd771849 (patch) | |
tree | 92e4241de8f981d7011eef3b3871e09175b28656 /src/garage/cli_v2/mod.rs | |
parent | 10bbb26b303e7bd58ca3396009a66b70a1673c0f (diff) | |
download | garage-7b9c047b113d78dacbece4670b8a1a1cbd771849.tar.gz garage-7b9c047b113d78dacbece4670b8a1a1cbd771849.zip |
cli_v2: add local_api_request with crazy type bound
Diffstat (limited to 'src/garage/cli_v2/mod.rs')
-rw-r--r-- | src/garage/cli_v2/mod.rs | 38 |
1 files changed, 33 insertions, 5 deletions
diff --git a/src/garage/cli_v2/mod.rs b/src/garage/cli_v2/mod.rs index b9bf05fe..b175ab38 100644 --- a/src/garage/cli_v2/mod.rs +++ b/src/garage/cli_v2/mod.rs @@ -16,7 +16,7 @@ use garage_rpc::*; use garage_api_admin::api::*; use garage_api_admin::api_server::{AdminRpc as ProxyRpc, AdminRpcResponse as ProxyRpcResponse}; -use garage_api_admin::RequestHandler as AdminApiEndpoint; +use garage_api_admin::RequestHandler; use crate::admin::*; use crate::cli as cli_v1; @@ -74,11 +74,11 @@ impl Cli { } } - pub async fn api_request<T>(&self, req: T) -> Result<<T as AdminApiEndpoint>::Response, Error> + pub async fn api_request<T>(&self, req: T) -> Result<<T as RequestHandler>::Response, Error> where - T: AdminApiEndpoint, + T: RequestHandler, AdminApiRequest: From<T>, - <T as AdminApiEndpoint>::Response: TryFrom<TaggedAdminApiResponse>, + <T as RequestHandler>::Response: TryFrom<TaggedAdminApiResponse>, { let req = AdminApiRequest::from(req); let req_name = req.name(); @@ -88,7 +88,7 @@ impl Cli { .await?? { ProxyRpcResponse::ProxyApiOkResponse(resp) => { - <T as AdminApiEndpoint>::Response::try_from(resp).map_err(|_| { + <T as RequestHandler>::Response::try_from(resp).map_err(|_| { Error::Message(format!("{} returned unexpected response", req_name)) }) } @@ -103,4 +103,32 @@ impl Cli { m => Err(Error::unexpected_rpc_message(m)), } } + + pub async fn local_api_request<T>( + &self, + req: T, + ) -> Result<<T as RequestHandler>::Response, Error> + where + T: RequestHandler, + MultiRequest<T>: RequestHandler<Response = MultiResponse<<T as RequestHandler>::Response>>, + AdminApiRequest: From<MultiRequest<T>>, + <MultiRequest<T> as RequestHandler>::Response: TryFrom<TaggedAdminApiResponse>, + { + let req = MultiRequest { + node: hex::encode(self.rpc_host), + body: req, + }; + let resp = self.api_request(req).await?; + + if let Some((_, e)) = resp.error.into_iter().next() { + return Err(Error::Message(e)); + } + if resp.success.len() != 1 { + return Err(Error::Message(format!( + "{} responses returned, expected 1", + resp.success.len() + ))); + } + Ok(resp.success.into_iter().next().unwrap().1) + } } |