mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-02-13 05:53:33 +01:00
![many](/assets/img/avatar_default.png)
implements: https://github.com/meilisearch/specifications/blob/develop/text/0085-api-keys.md - Add tests on API keys management route (meilisearch-http/tests/auth/api_keys.rs) - Add tests checking authorizations on each meilisearch routes (meilisearch-http/tests/auth/authorization.rs) - Implement API keys management routes (meilisearch-http/src/routes/api_key.rs) - Create module to manage API keys and authorizations (meilisearch-auth) - Reimplement GuardedData to extend authorizations (meilisearch-http/src/extractors/authentication/mod.rs) - Change X-MEILI-API-KEY by Authorization Bearer (meilisearch-http/src/extractors/authentication/mod.rs) - Change meilisearch routes to fit to the new authorization feature (meilisearch-http/src/routes/) - close #1867
42 lines
1.8 KiB
Rust
42 lines
1.8 KiB
Rust
use std::error::Error;
|
|
|
|
use meilisearch_error::ErrorCode;
|
|
use meilisearch_error::{internal_error, Code};
|
|
use serde_json::Value;
|
|
|
|
pub type Result<T> = std::result::Result<T, AuthControllerError>;
|
|
|
|
#[derive(Debug, thiserror::Error)]
|
|
pub enum AuthControllerError {
|
|
#[error("`{0}` field is mandatory.")]
|
|
MissingParameter(&'static str),
|
|
#[error("actions field value `{0}` is invalid. It should be an array of string representing action names.")]
|
|
InvalidApiKeyActions(Value),
|
|
#[error("indexes field value `{0}` is invalid. It should be an array of string representing index names.")]
|
|
InvalidApiKeyIndexes(Value),
|
|
#[error("expiresAt field value `{0}` is invalid. It should be in ISO-8601 format to represents a date or datetime in the future or specified as a null value. e.g. 'YYYY-MM-DD' or 'YYYY-MM-DDTHH:MM:SS'.")]
|
|
InvalidApiKeyExpiresAt(Value),
|
|
#[error("description field value `{0}` is invalid. It should be a string or specified as a null value.")]
|
|
InvalidApiKeyDescription(Value),
|
|
#[error("API key `{0}` not found.")]
|
|
ApiKeyNotFound(String),
|
|
#[error("Internal error: {0}")]
|
|
Internal(Box<dyn Error + Send + Sync + 'static>),
|
|
}
|
|
|
|
internal_error!(AuthControllerError: heed::Error, std::io::Error);
|
|
|
|
impl ErrorCode for AuthControllerError {
|
|
fn error_code(&self) -> Code {
|
|
match self {
|
|
Self::MissingParameter(_) => Code::MissingParameter,
|
|
Self::InvalidApiKeyActions(_) => Code::InvalidApiKeyActions,
|
|
Self::InvalidApiKeyIndexes(_) => Code::InvalidApiKeyIndexes,
|
|
Self::InvalidApiKeyExpiresAt(_) => Code::InvalidApiKeyExpiresAt,
|
|
Self::InvalidApiKeyDescription(_) => Code::InvalidApiKeyDescription,
|
|
Self::ApiKeyNotFound(_) => Code::ApiKeyNotFound,
|
|
Self::Internal(_) => Code::Internal,
|
|
}
|
|
}
|
|
}
|