mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	save the user-id in the config dir of the OS
This commit is contained in:
		
							
								
								
									
										41
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										41
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -849,6 +849,27 @@ dependencies = [ | |||||||
|  "generic-array 0.14.4", |  "generic-array 0.14.4", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "dirs-next" | ||||||
|  | version = "1.0.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "cf36e65a80337bea855cd4ef9b8401ffce06a7baedf2e85ec467b1ac3f6e82b6" | ||||||
|  | dependencies = [ | ||||||
|  |  "cfg-if 1.0.0", | ||||||
|  |  "dirs-sys-next", | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "dirs-sys-next" | ||||||
|  | version = "0.1.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "4ebda144c4fe02d1f7ea1a7d9641b6fc6b580adcfa024ae48797ecdeb6825b4d" | ||||||
|  | dependencies = [ | ||||||
|  |  "libc", | ||||||
|  |  "redox_users", | ||||||
|  |  "winapi", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "discard" | name = "discard" | ||||||
| version = "1.0.4" | version = "1.0.4" | ||||||
| @@ -1653,6 +1674,7 @@ dependencies = [ | |||||||
|  "parking_lot", |  "parking_lot", | ||||||
|  "paste", |  "paste", | ||||||
|  "pin-project", |  "pin-project", | ||||||
|  |  "platform-dirs", | ||||||
|  "rand", |  "rand", | ||||||
|  "rayon", |  "rayon", | ||||||
|  "regex", |  "regex", | ||||||
| @@ -2172,6 +2194,15 @@ version = "0.3.20" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "7c9b1041b4387893b91ee6746cddfc28516aff326a3519fb2adf820932c5e6cb" | checksum = "7c9b1041b4387893b91ee6746cddfc28516aff326a3519fb2adf820932c5e6cb" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "platform-dirs" | ||||||
|  | version = "0.3.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "e188d043c1a692985f78b5464853a263f1a27e5bd6322bad3a4078ee3c998a38" | ||||||
|  | dependencies = [ | ||||||
|  |  "dirs-next", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "ppv-lite86" | name = "ppv-lite86" | ||||||
| version = "0.2.10" | version = "0.2.10" | ||||||
| @@ -2353,6 +2384,16 @@ dependencies = [ | |||||||
|  "bitflags", |  "bitflags", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "redox_users" | ||||||
|  | version = "0.4.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "528532f3d801c87aec9def2add9ca802fe569e44a544afe633765267840abe64" | ||||||
|  | dependencies = [ | ||||||
|  |  "getrandom", | ||||||
|  |  "redox_syscall", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex" | name = "regex" | ||||||
| version = "1.5.4" | version = "1.5.4" | ||||||
|   | |||||||
| @@ -51,6 +51,7 @@ mime = "0.3.16" | |||||||
| num_cpus = "1.13.0" | num_cpus = "1.13.0" | ||||||
| once_cell = "1.8.0" | once_cell = "1.8.0" | ||||||
| parking_lot = "0.11.2" | parking_lot = "0.11.2" | ||||||
|  | platform-dirs = "0.3.0" | ||||||
| rand = "0.8.4" | rand = "0.8.4" | ||||||
| rayon = "1.5.1" | rayon = "1.5.1" | ||||||
| regex = "1.5.4" | regex = "1.5.4" | ||||||
|   | |||||||
| @@ -1,11 +1,50 @@ | |||||||
| use actix_web::HttpRequest; |  | ||||||
| use meilisearch_lib::index::SearchQuery; |  | ||||||
| use serde_json::Value; |  | ||||||
| use std::fmt::Display; |  | ||||||
| use std::fs::read_to_string; |  | ||||||
|  |  | ||||||
| use crate::routes::indexes::documents::UpdateDocumentsQuery; | use crate::routes::indexes::documents::UpdateDocumentsQuery; | ||||||
| use crate::Opt; | use crate::Opt; | ||||||
|  | use actix_web::HttpRequest; | ||||||
|  | use meilisearch_lib::index::SearchQuery; | ||||||
|  | use once_cell::sync::Lazy; | ||||||
|  | use platform_dirs::AppDirs; | ||||||
|  | use serde_json::Value; | ||||||
|  | use std::fmt::Display; | ||||||
|  | use std::fs; | ||||||
|  | use std::path::PathBuf; | ||||||
|  |  | ||||||
|  | /// The MeiliSearch config dir: | ||||||
|  | /// `~/.config/MeiliSearch` on *NIX or *BSD. | ||||||
|  | /// `~/Library/ApplicationSupport` on macOS. | ||||||
|  | /// `%APPDATA` (= `C:\Users%USERNAME%\AppData\Roaming`) on windows. | ||||||
|  | static MEILISEARCH_CONFIG_PATH: Lazy<Option<PathBuf>> = | ||||||
|  |     Lazy::new(|| AppDirs::new(Some("MeiliSearch"), false).map(|appdir| appdir.config_dir)); | ||||||
|  |  | ||||||
|  | fn config_user_id_path(opt: &Opt) -> Option<PathBuf> { | ||||||
|  |     opt.db_path | ||||||
|  |         .canonicalize() | ||||||
|  |         .ok() | ||||||
|  |         .map(|path| path.join("user-id").display().to_string().replace("/", "-")) | ||||||
|  |         .zip(MEILISEARCH_CONFIG_PATH.as_ref()) | ||||||
|  |         .map(|(filename, config_path)| config_path.join(filename)) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /// Look for the user-id in the `data.ms` or in `~/.config/MeiliSearch/path-to-db-user-id` | ||||||
|  | fn find_user_id(opt: &Opt) -> Option<String> { | ||||||
|  |     fs::read_to_string(opt.db_path.join("user-id")) | ||||||
|  |         .ok() | ||||||
|  |         .or_else(|| fs::read_to_string(&config_user_id_path(opt)?).ok()) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[cfg(all(not(debug_assertions), feature = "analytics"))] | ||||||
|  | /// Write the user-id in the `data.ms` and in `~/.config/MeiliSearch/path-to-db-user-id`. Ignore the errors. | ||||||
|  | fn write_user_id(opt: &Opt, user_id: &str) { | ||||||
|  |     let _ = fs::write(opt.db_path.join("user-id"), user_id.as_bytes()); | ||||||
|  |     if let Some((meilisearch_config_path, user_id_path)) = MEILISEARCH_CONFIG_PATH | ||||||
|  |         .as_ref() | ||||||
|  |         .zip(config_user_id_path(opt)) | ||||||
|  |     { | ||||||
|  |         println!("{}", user_id_path.display()); | ||||||
|  |         let _ = fs::create_dir_all(&meilisearch_config_path); | ||||||
|  |         let _ = fs::write(user_id_path, user_id.as_bytes()); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| // if we are in release mode and the feature analytics was enabled | // if we are in release mode and the feature analytics was enabled | ||||||
| #[cfg(all(not(debug_assertions), feature = "analytics"))] | #[cfg(all(not(debug_assertions), feature = "analytics"))] | ||||||
| @@ -24,7 +63,6 @@ mod segment { | |||||||
|     use serde_json::{json, Value}; |     use serde_json::{json, Value}; | ||||||
|     use std::collections::{HashMap, HashSet}; |     use std::collections::{HashMap, HashSet}; | ||||||
|     use std::fmt::Display; |     use std::fmt::Display; | ||||||
|     use std::fs; |  | ||||||
|     use std::time::{Duration, Instant}; |     use std::time::{Duration, Instant}; | ||||||
|     use sysinfo::{DiskExt, System, SystemExt}; |     use sysinfo::{DiskExt, System, SystemExt}; | ||||||
|     use tokio::sync::Mutex; |     use tokio::sync::Mutex; | ||||||
| @@ -100,17 +138,12 @@ mod segment { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         pub async fn new(opt: &Opt, meilisearch: &MeiliSearch) -> &'static Self { |         pub async fn new(opt: &Opt, meilisearch: &MeiliSearch) -> &'static Self { | ||||||
|             // see if there is already a user-id in the `data.ms` |             // see if there is already a user-id in the `data.ms` or in `/tmp/path-to-db-user-id` | ||||||
|             let user_id = fs::read_to_string(opt.db_path.join("user-id")) |             let user_id = super::find_user_id(opt); | ||||||
|                 .or_else(|_| fs::read_to_string("/tmp/meilisearch-user-id")); |             let first_time_run = user_id.is_none(); | ||||||
|             let first_time_run = user_id.is_err(); |  | ||||||
|             // if not, generate a new user-id and save it to the fs |             // if not, generate a new user-id and save it to the fs | ||||||
|             let user_id = user_id.unwrap_or_else(|_| Uuid::new_v4().to_string()); |             let user_id = user_id.unwrap_or_else(|| Uuid::new_v4().to_string()); | ||||||
|             let _ = fs::write(opt.db_path.join("user-id"), user_id.as_bytes()); |             super::write_user_id(opt, &user_id); | ||||||
|             let _ = fs::write( |  | ||||||
|                 opt.db_path.join("/tmp/meilisearch-user-id"), |  | ||||||
|                 user_id.as_bytes(), |  | ||||||
|             ); |  | ||||||
|  |  | ||||||
|             let client = HttpClient::default(); |             let client = HttpClient::default(); | ||||||
|             let user = User::UserId { |             let user = User::UserId { | ||||||
| @@ -536,9 +569,7 @@ pub struct MockAnalytics { | |||||||
|  |  | ||||||
| impl MockAnalytics { | impl MockAnalytics { | ||||||
|     pub fn new(opt: &Opt) -> &'static Self { |     pub fn new(opt: &Opt) -> &'static Self { | ||||||
|         let user = read_to_string(opt.db_path.join("user-id")) |         let user = find_user_id(opt).unwrap_or(String::new()); | ||||||
|             .or_else(|_| read_to_string("/tmp/meilisearch-user-id")) |  | ||||||
|             .unwrap_or_else(|_| "".to_string()); |  | ||||||
|         let analytics = Box::new(Self { user }); |         let analytics = Box::new(Self { user }); | ||||||
|         Box::leak(analytics) |         Box::leak(analytics) | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user