mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Making it work with index uid patterns
This commit is contained in:
		| @@ -1,7 +1,10 @@ | ||||
| use std::borrow::Borrow; | ||||
| use std::error::Error; | ||||
| use std::fmt; | ||||
| use std::ops::Deref; | ||||
| use std::str::FromStr; | ||||
|  | ||||
| use deserr::DeserializeFromValue; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::error::{Code, ErrorCode}; | ||||
| @@ -9,17 +12,25 @@ use crate::index_uid::{IndexUid, IndexUidFormatError}; | ||||
|  | ||||
| /// An index uid pattern is composed of only ascii alphanumeric characters, - and _, between 1 and 400 | ||||
| /// bytes long and optionally ending with a *. | ||||
| #[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq)] | ||||
| #[cfg_attr(feature = "test-traits", derive(proptest_derive::Arbitrary))] | ||||
| pub struct IndexUidPattern( | ||||
|     #[cfg_attr(feature = "test-traits", proptest(regex("[a-zA-Z0-9_-]{1,400}\\*?")))] String, | ||||
| ); | ||||
| #[derive(Serialize, Deserialize, DeserializeFromValue, Debug, Clone, PartialEq, Eq, Hash)] | ||||
| #[deserr(from(&String) = FromStr::from_str -> IndexUidPatternFormatError)] | ||||
| pub struct IndexUidPattern(String); | ||||
|  | ||||
| impl IndexUidPattern { | ||||
|     pub fn new_unchecked(s: impl AsRef<str>) -> Self { | ||||
|         Self(s.as_ref().to_string()) | ||||
|     } | ||||
|  | ||||
|     /// Matches any index name. | ||||
|     pub fn all() -> Self { | ||||
|         IndexUidPattern::from_str("*").unwrap() | ||||
|     } | ||||
|  | ||||
|     /// Returns `true` if the pattern matches a specific index name. | ||||
|     pub fn is_exact(&self) -> bool { | ||||
|         !self.0.ends_with('*') | ||||
|     } | ||||
|  | ||||
|     /// Returns wether this index uid matches this index uid pattern. | ||||
|     pub fn matches(&self, uid: &IndexUid) -> bool { | ||||
|         self.matches_str(uid.as_str()) | ||||
| @@ -34,7 +45,7 @@ impl IndexUidPattern { | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl std::ops::Deref for IndexUidPattern { | ||||
| impl Deref for IndexUidPattern { | ||||
|     type Target = str; | ||||
|  | ||||
|     fn deref(&self) -> &Self::Target { | ||||
| @@ -42,6 +53,12 @@ impl std::ops::Deref for IndexUidPattern { | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl Borrow<str> for IndexUidPattern { | ||||
|     fn borrow(&self) -> &str { | ||||
|         &self.0 | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl TryFrom<String> for IndexUidPattern { | ||||
|     type Error = IndexUidPatternFormatError; | ||||
|  | ||||
|   | ||||
| @@ -47,7 +47,7 @@ pub struct CreateApiKey { | ||||
|     #[deserr(error = DeserrError<InvalidApiKeyActions>)] | ||||
|     pub actions: Vec<Action>, | ||||
|     #[deserr(error = DeserrError<InvalidApiKeyIndexes>)] | ||||
|     pub indexes: Vec<StarOr<IndexUidPattern>>, | ||||
|     pub indexes: Vec<IndexUidPattern>, | ||||
|     #[deserr(error = DeserrError<InvalidApiKeyExpiresAt>, default = None, from(&String) = parse_expiration_date -> TakeErrorMessage<ParseOffsetDateTimeError>)] | ||||
|     pub expires_at: Option<OffsetDateTime>, | ||||
| } | ||||
| @@ -109,7 +109,7 @@ pub struct Key { | ||||
|     pub name: Option<String>, | ||||
|     pub uid: KeyId, | ||||
|     pub actions: Vec<Action>, | ||||
|     pub indexes: Vec<StarOr<IndexUidPattern>>, | ||||
|     pub indexes: Vec<IndexUidPattern>, | ||||
|     #[serde(with = "time::serde::rfc3339::option")] | ||||
|     pub expires_at: Option<OffsetDateTime>, | ||||
|     #[serde(with = "time::serde::rfc3339")] | ||||
| @@ -127,7 +127,7 @@ impl Key { | ||||
|             description: Some("Use it for anything that is not a search operation. Caution! Do not expose it on a public frontend".to_string()), | ||||
|             uid, | ||||
|             actions: vec![Action::All], | ||||
|             indexes: vec![StarOr::Star], | ||||
|             indexes: vec![IndexUidPattern::all()], | ||||
|             expires_at: None, | ||||
|             created_at: now, | ||||
|             updated_at: now, | ||||
| @@ -142,7 +142,7 @@ impl Key { | ||||
|             description: Some("Use it to search from the frontend".to_string()), | ||||
|             uid, | ||||
|             actions: vec![Action::Search], | ||||
|             indexes: vec![StarOr::Star], | ||||
|             indexes: vec![IndexUidPattern::all()], | ||||
|             expires_at: None, | ||||
|             created_at: now, | ||||
|             updated_at: now, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user