client: remove option from inner RawApiResponse

when using the client for an api call that does not return any data
(it returns '{"data":null}'), we would always get an error 'api returned
no data'. The message is technically correct, but it should not be an
error when we expect no data (e.g. most of our CRUD PUT/POST calls)

instead of having the Option<T> in the RawApiResponse type itself, move
it into to the 'nodata' function intended for api calls where we don't
expect any data.

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
This commit is contained in:
Dominik Csapak 2023-08-29 14:04:40 +02:00 committed by Dietmar Maurer
parent 022fdacb25
commit 271a55f187

View File

@ -106,8 +106,8 @@ impl HttpApiResponse {
/// Expect that the API call did *not* return any data in the `data` field. /// Expect that the API call did *not* return any data in the `data` field.
pub fn nodata(self) -> Result<(), Error> { pub fn nodata(self) -> Result<(), Error> {
let response = serde_json::from_slice::<RawApiResponse<()>>(&self.body) let response = serde_json::from_slice::<RawApiResponse<Option<()>>>(&self.body)
.map_err(|err| Error::bad_api("failed to parse api response", err))?; .map_err(|err| Error::bad_api("unexpected api response", err))?;
if response.data.is_some() { if response.data.is_some() {
Err(Error::UnexpectedData) Err(Error::UnexpectedData)
@ -131,7 +131,7 @@ struct RawApiResponse<T> {
message: Option<String>, message: Option<String>,
#[serde(default, deserialize_with = "proxmox_login::parse::deserialize_bool")] #[serde(default, deserialize_with = "proxmox_login::parse::deserialize_bool")]
success: Option<bool>, success: Option<bool>,
data: Option<T>, data: T,
#[serde(default)] #[serde(default)]
errors: HashMap<String, String>, errors: HashMap<String, String>,
@ -164,9 +164,7 @@ impl<T> RawApiResponse<T> {
let this = self.check_success()?; let this = self.check_success()?;
Ok(ApiResponseData { Ok(ApiResponseData {
data: this data: this.data,
.data
.ok_or_else(|| Error::BadApi("api returned no data".to_string(), None))?,
attribs: this.attribs, attribs: this.attribs,
}) })
} }