mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Merge remote-tracking branch 'origin/main' into temp-wildcard
This commit is contained in:
		| @@ -10,6 +10,7 @@ use error::{AuthControllerError, Result}; | ||||
| use maplit::hashset; | ||||
| use meilisearch_types::index_uid_pattern::IndexUidPattern; | ||||
| use meilisearch_types::keys::{Action, CreateApiKey, Key, PatchApiKey}; | ||||
| use meilisearch_types::milli::update::Setting; | ||||
| use serde::{Deserialize, Serialize}; | ||||
| pub use store::open_auth_store_env; | ||||
| use store::{generate_key_as_hexa, HeedAuthStore}; | ||||
| @@ -33,6 +34,11 @@ impl AuthController { | ||||
|         Ok(Self { store: Arc::new(store), master_key: master_key.clone() }) | ||||
|     } | ||||
|  | ||||
|     /// Return the size of the `AuthController` database in bytes. | ||||
|     pub fn size(&self) -> Result<u64> { | ||||
|         self.store.size() | ||||
|     } | ||||
|  | ||||
|     pub fn create_key(&self, create_key: CreateApiKey) -> Result<Key> { | ||||
|         match self.store.get_api_key(create_key.uid)? { | ||||
|             Some(_) => Err(AuthControllerError::ApiKeyAlreadyExists(create_key.uid.to_string())), | ||||
| @@ -42,8 +48,14 @@ impl AuthController { | ||||
|  | ||||
|     pub fn update_key(&self, uid: Uuid, patch: PatchApiKey) -> Result<Key> { | ||||
|         let mut key = self.get_key(uid)?; | ||||
|         key.description = patch.description; | ||||
|         key.name = patch.name; | ||||
|         match patch.description { | ||||
|             Setting::NotSet => (), | ||||
|             description => key.description = description.set(), | ||||
|         }; | ||||
|         match patch.name { | ||||
|             Setting::NotSet => (), | ||||
|             name => key.name = name.set(), | ||||
|         }; | ||||
|         key.updated_at = OffsetDateTime::now_utc(); | ||||
|         self.store.put_api_key(key) | ||||
|     } | ||||
|   | ||||
| @@ -3,7 +3,6 @@ use std::cmp::Reverse; | ||||
| use std::collections::HashSet; | ||||
| use std::convert::{TryFrom, TryInto}; | ||||
| use std::fs::create_dir_all; | ||||
| use std::ops::Deref; | ||||
| use std::path::Path; | ||||
| use std::str; | ||||
| use std::sync::Arc; | ||||
| @@ -61,6 +60,11 @@ impl HeedAuthStore { | ||||
|         Ok(Self { env, keys, action_keyid_index_expiration, should_close_on_drop: true }) | ||||
|     } | ||||
|  | ||||
|     /// Return the size in bytes of database | ||||
|     pub fn size(&self) -> Result<u64> { | ||||
|         Ok(self.env.real_disk_size()?) | ||||
|     } | ||||
|  | ||||
|     pub fn set_drop_on_close(&mut self, v: bool) { | ||||
|         self.should_close_on_drop = v; | ||||
|     } | ||||
| @@ -135,7 +139,7 @@ impl HeedAuthStore { | ||||
|                 for index in key.indexes.iter() { | ||||
|                     db.put( | ||||
|                         &mut wtxn, | ||||
|                         &(&uid, &action, Some(index.deref().as_bytes())), | ||||
|                         &(&uid, &action, Some(index.to_string().as_bytes())), | ||||
|                         &key.expires_at, | ||||
|                     )?; | ||||
|                 } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user