mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-11 05:54:30 +01:00
Return an error when calling DELETE /tasks with an empty query
This commit is contained in:
parent
fbd2be2ec8
commit
f32b973945
@ -15,7 +15,9 @@ pub enum Error {
|
|||||||
CorruptedTaskQueue,
|
CorruptedTaskQueue,
|
||||||
#[error("Task `{0}` not found")]
|
#[error("Task `{0}` not found")]
|
||||||
TaskNotFound(TaskId),
|
TaskNotFound(TaskId),
|
||||||
|
// TODO: Lo: proper error message for this
|
||||||
|
#[error("Cannot delete all tasks")]
|
||||||
|
TaskDeletionWithEmptyQuery,
|
||||||
// maybe the two next errors are going to move to the frontend
|
// maybe the two next errors are going to move to the frontend
|
||||||
#[error("`{0}` is not a status. Available status are")]
|
#[error("`{0}` is not a status. Available status are")]
|
||||||
InvalidStatus(String),
|
InvalidStatus(String),
|
||||||
@ -41,6 +43,7 @@ impl ErrorCode for Error {
|
|||||||
Error::IndexNotFound(_) => Code::IndexNotFound,
|
Error::IndexNotFound(_) => Code::IndexNotFound,
|
||||||
Error::IndexAlreadyExists(_) => Code::IndexAlreadyExists,
|
Error::IndexAlreadyExists(_) => Code::IndexAlreadyExists,
|
||||||
Error::TaskNotFound(_) => Code::TaskNotFound,
|
Error::TaskNotFound(_) => Code::TaskNotFound,
|
||||||
|
Error::TaskDeletionWithEmptyQuery => Code::TaskDeletionWithEmptyQuery,
|
||||||
Error::InvalidStatus(_) => Code::BadRequest,
|
Error::InvalidStatus(_) => Code::BadRequest,
|
||||||
Error::InvalidKind(_) => Code::BadRequest,
|
Error::InvalidKind(_) => Code::BadRequest,
|
||||||
|
|
||||||
|
@ -56,6 +56,21 @@ impl Default for Query {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Query {
|
impl Query {
|
||||||
|
/// Return `true` iff every field of the query is set to `None`, such that the query
|
||||||
|
/// would match all tasks.
|
||||||
|
pub fn is_empty(&self) -> bool {
|
||||||
|
matches!(
|
||||||
|
self,
|
||||||
|
Query {
|
||||||
|
limit: None,
|
||||||
|
from: None,
|
||||||
|
status: None,
|
||||||
|
kind: None,
|
||||||
|
index_uid: None,
|
||||||
|
uid: None
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
pub fn with_status(self, status: Status) -> Self {
|
pub fn with_status(self, status: Status) -> Self {
|
||||||
let mut status_vec = self.status.unwrap_or_default();
|
let mut status_vec = self.status.unwrap_or_default();
|
||||||
status_vec.push(status);
|
status_vec.push(status);
|
||||||
|
@ -209,6 +209,9 @@ async fn delete_tasks(
|
|||||||
index_uid,
|
index_uid,
|
||||||
uid,
|
uid,
|
||||||
};
|
};
|
||||||
|
if query.is_empty() {
|
||||||
|
return Err(index_scheduler::Error::TaskDeletionWithEmptyQuery.into());
|
||||||
|
}
|
||||||
|
|
||||||
let filtered_query = filter_out_inaccessible_indexes_from_query(&index_scheduler, &query);
|
let filtered_query = filter_out_inaccessible_indexes_from_query(&index_scheduler, &query);
|
||||||
|
|
||||||
@ -258,6 +261,7 @@ async fn get_tasks(
|
|||||||
Some(&req),
|
Some(&req),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// TODO: Lo: use `filter_out_inaccessible_indexes_from_query` here
|
||||||
let mut filters = index_scheduler::Query::default();
|
let mut filters = index_scheduler::Query::default();
|
||||||
|
|
||||||
// Then we filter on potential indexes and make sure that the search filter
|
// Then we filter on potential indexes and make sure that the search filter
|
||||||
|
@ -150,6 +150,7 @@ pub enum Code {
|
|||||||
NoSpaceLeftOnDevice,
|
NoSpaceLeftOnDevice,
|
||||||
DumpNotFound,
|
DumpNotFound,
|
||||||
TaskNotFound,
|
TaskNotFound,
|
||||||
|
TaskDeletionWithEmptyQuery,
|
||||||
PayloadTooLarge,
|
PayloadTooLarge,
|
||||||
RetrieveDocument,
|
RetrieveDocument,
|
||||||
SearchDocuments,
|
SearchDocuments,
|
||||||
@ -240,6 +241,10 @@ impl Code {
|
|||||||
ErrCode::authentication("missing_master_key", StatusCode::UNAUTHORIZED)
|
ErrCode::authentication("missing_master_key", StatusCode::UNAUTHORIZED)
|
||||||
}
|
}
|
||||||
TaskNotFound => ErrCode::invalid("task_not_found", StatusCode::NOT_FOUND),
|
TaskNotFound => ErrCode::invalid("task_not_found", StatusCode::NOT_FOUND),
|
||||||
|
// TODO: Lo: find the proper error name & message for this one
|
||||||
|
TaskDeletionWithEmptyQuery => {
|
||||||
|
ErrCode::invalid("task_deletion_with_empty_query", StatusCode::BAD_REQUEST)
|
||||||
|
}
|
||||||
DumpNotFound => ErrCode::invalid("dump_not_found", StatusCode::NOT_FOUND),
|
DumpNotFound => ErrCode::invalid("dump_not_found", StatusCode::NOT_FOUND),
|
||||||
NoSpaceLeftOnDevice => {
|
NoSpaceLeftOnDevice => {
|
||||||
ErrCode::internal("no_space_left_on_device", StatusCode::INTERNAL_SERVER_ERROR)
|
ErrCode::internal("no_space_left_on_device", StatusCode::INTERNAL_SERVER_ERROR)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user