mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Introduce the IndexUidPattern type
This commit is contained in:
		
				
					committed by
					
						 Kerollmops
						Kerollmops
					
				
			
			
				
	
			
			
			
						parent
						
							474d4ec498
						
					
				
				
					commit
					0b08413c98
				
			
							
								
								
									
										97
									
								
								meilisearch-types/src/index_uid_pattern.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								meilisearch-types/src/index_uid_pattern.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | use std::error::Error; | ||||||
|  | use std::fmt; | ||||||
|  | use std::str::FromStr; | ||||||
|  |  | ||||||
|  | use serde::{Deserialize, Serialize}; | ||||||
|  |  | ||||||
|  | use crate::error::{Code, ErrorCode}; | ||||||
|  | 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)] | ||||||
|  | pub struct IndexUidPattern( | ||||||
|  |     #[cfg_attr(feature = "test-traits", proptest(regex("[a-zA-Z0-9_-]{1,400}\\*?")))] String, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | impl IndexUidPattern { | ||||||
|  |     /// Returns wether this index uid matches this index uid pattern. | ||||||
|  |     pub fn matches(&self, uid: &IndexUid) -> bool { | ||||||
|  |         self.matches_str(uid.as_str()) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /// Returns wether this string matches this index uid pattern. | ||||||
|  |     pub fn matches_str(&self, uid: &str) -> bool { | ||||||
|  |         match self.0.strip_suffix('*') { | ||||||
|  |             Some(prefix) => uid.starts_with(prefix), | ||||||
|  |             None => self.0 == uid, | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl std::ops::Deref for IndexUidPattern { | ||||||
|  |     type Target = str; | ||||||
|  |  | ||||||
|  |     fn deref(&self) -> &Self::Target { | ||||||
|  |         &self.0 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl TryFrom<String> for IndexUidPattern { | ||||||
|  |     type Error = IndexUidPatternFormatError; | ||||||
|  |  | ||||||
|  |     fn try_from(uid: String) -> Result<Self, Self::Error> { | ||||||
|  |         let result = match uid.strip_suffix('*') { | ||||||
|  |             Some(prefix) => IndexUid::from_str(prefix).map(|_| IndexUidPattern(uid)), | ||||||
|  |             None => IndexUid::try_from(uid).map(IndexUid::into_inner).map(IndexUidPattern), | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         match result { | ||||||
|  |             Ok(index_uid_pattern) => Ok(index_uid_pattern), | ||||||
|  |             Err(IndexUidFormatError { invalid_uid }) => { | ||||||
|  |                 Err(IndexUidPatternFormatError { invalid_uid }) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl FromStr for IndexUidPattern { | ||||||
|  |     type Err = IndexUidPatternFormatError; | ||||||
|  |  | ||||||
|  |     fn from_str(uid: &str) -> Result<IndexUidPattern, IndexUidPatternFormatError> { | ||||||
|  |         uid.to_string().try_into() | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl From<IndexUidPattern> for String { | ||||||
|  |     fn from(IndexUidPattern(uid): IndexUidPattern) -> Self { | ||||||
|  |         uid | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[derive(Debug)] | ||||||
|  | pub struct IndexUidPatternFormatError { | ||||||
|  |     pub invalid_uid: String, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl fmt::Display for IndexUidPatternFormatError { | ||||||
|  |     fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { | ||||||
|  |         write!( | ||||||
|  |             f, | ||||||
|  |             "`{}` is not a valid index uid pattern. Index uid patterns \ | ||||||
|  |             can be an integer or a string containing only alphanumeric \ | ||||||
|  |             characters, hyphens (-), underscores (_), and \ | ||||||
|  |             optionally end with a star (*).", | ||||||
|  |             self.invalid_uid, | ||||||
|  |         ) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl Error for IndexUidPatternFormatError {} | ||||||
|  |  | ||||||
|  | impl ErrorCode for IndexUidPatternFormatError { | ||||||
|  |     fn error_code(&self) -> Code { | ||||||
|  |         // TODO should I return a new error code? | ||||||
|  |         Code::InvalidIndexUid | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,6 +2,7 @@ pub mod compression; | |||||||
| pub mod document_formats; | pub mod document_formats; | ||||||
| pub mod error; | pub mod error; | ||||||
| pub mod index_uid; | pub mod index_uid; | ||||||
|  | pub mod index_uid_pattern; | ||||||
| pub mod keys; | pub mod keys; | ||||||
| pub mod settings; | pub mod settings; | ||||||
| pub mod star_or; | pub mod star_or; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user