Fix bad http status and error message on wrong payload

This commit is contained in:
karribalu 2024-06-20 23:55:09 +01:00
parent d1962b2b0f
commit fb683fe88b

View File

@ -98,14 +98,27 @@ impl From<MeilisearchHttpError> for aweb::Error {
impl From<aweb::error::PayloadError> for MeilisearchHttpError { impl From<aweb::error::PayloadError> for MeilisearchHttpError {
fn from(error: aweb::error::PayloadError) -> Self { fn from(error: aweb::error::PayloadError) -> Self {
MeilisearchHttpError::Payload(PayloadError::Payload(error)) match error {
aweb::error::PayloadError::Incomplete(_) => {
MeilisearchHttpError::Payload(PayloadError::Payload(ActixPayloadError::IncompleteError))
}
_ => MeilisearchHttpError::Payload(PayloadError::Payload(ActixPayloadError::OtherError(error)))
}
} }
} }
#[derive(Debug, thiserror::Error)]
pub enum ActixPayloadError {
#[error("The provided payload is incomplete and cannot be decompressed")]
IncompleteError,
#[error(transparent)]
OtherError(aweb::error::PayloadError)
}
#[derive(Debug, thiserror::Error)] #[derive(Debug, thiserror::Error)]
pub enum PayloadError { pub enum PayloadError {
#[error(transparent)] #[error(transparent)]
Payload(aweb::error::PayloadError), Payload(ActixPayloadError),
#[error(transparent)] #[error(transparent)]
Json(JsonPayloadError), Json(JsonPayloadError),
#[error(transparent)] #[error(transparent)]
@ -122,13 +135,15 @@ impl ErrorCode for PayloadError {
fn error_code(&self) -> Code { fn error_code(&self) -> Code {
match self { match self {
PayloadError::Payload(e) => match e { PayloadError::Payload(e) => match e {
aweb::error::PayloadError::Incomplete(_) => Code::Internal, ActixPayloadError::IncompleteError => Code::BadRequest,
aweb::error::PayloadError::EncodingCorrupted => Code::Internal, ActixPayloadError::OtherError(error) => match error {
aweb::error::PayloadError::Overflow => Code::PayloadTooLarge, aweb::error::PayloadError::EncodingCorrupted => Code::Internal,
aweb::error::PayloadError::UnknownLength => Code::Internal, aweb::error::PayloadError::Overflow => Code::PayloadTooLarge,
aweb::error::PayloadError::Http2Payload(_) => Code::Internal, aweb::error::PayloadError::UnknownLength => Code::Internal,
aweb::error::PayloadError::Io(_) => Code::Internal, aweb::error::PayloadError::Http2Payload(_) => Code::Internal,
_ => todo!(), aweb::error::PayloadError::Io(_) => Code::Internal,
_ => todo!(),
}
}, },
PayloadError::Json(err) => match err { PayloadError::Json(err) => match err {
JsonPayloadError::Overflow { .. } => Code::PayloadTooLarge, JsonPayloadError::Overflow { .. } => Code::PayloadTooLarge,