mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	Merge #3002
3002: Fix dump import without instance uid r=Kerollmops a=irevoire When creating a dump without any instance-uid (that can happen if you’ve always run meilisearch with the `--no-analytics` flag), you could get an error when trying to load the dump. Co-authored-by: Irevoire <tamo@meilisearch.com>
This commit is contained in:
		| @@ -1,7 +1,6 @@ | |||||||
| use std::fs::{self, File}; | use std::fs::{self, File}; | ||||||
| use std::io::{BufRead, BufReader}; | use std::io::{BufRead, BufReader, ErrorKind}; | ||||||
| use std::path::Path; | use std::path::Path; | ||||||
| use std::str::FromStr; |  | ||||||
|  |  | ||||||
| pub use meilisearch_types::milli; | pub use meilisearch_types::milli; | ||||||
| use tempfile::TempDir; | use tempfile::TempDir; | ||||||
| @@ -44,7 +43,7 @@ pub type Code = meilisearch_types::error::Code; | |||||||
|  |  | ||||||
| pub struct V6Reader { | pub struct V6Reader { | ||||||
|     dump: TempDir, |     dump: TempDir, | ||||||
|     instance_uid: Uuid, |     instance_uid: Option<Uuid>, | ||||||
|     metadata: Metadata, |     metadata: Metadata, | ||||||
|     tasks: BufReader<File>, |     tasks: BufReader<File>, | ||||||
|     keys: BufReader<File>, |     keys: BufReader<File>, | ||||||
| @@ -53,8 +52,11 @@ pub struct V6Reader { | |||||||
| impl V6Reader { | impl V6Reader { | ||||||
|     pub fn open(dump: TempDir) -> Result<Self> { |     pub fn open(dump: TempDir) -> Result<Self> { | ||||||
|         let meta_file = fs::read(dump.path().join("metadata.json"))?; |         let meta_file = fs::read(dump.path().join("metadata.json"))?; | ||||||
|         let instance_uid = fs::read_to_string(dump.path().join("instance_uid.uuid"))?; |         let instance_uid = match fs::read_to_string(dump.path().join("instance_uid.uuid")) { | ||||||
|         let instance_uid = Uuid::from_str(&instance_uid)?; |             Ok(uuid) => Some(Uuid::parse_str(&uuid)?), | ||||||
|  |             Err(e) if e.kind() == ErrorKind::NotFound => None, | ||||||
|  |             Err(e) => return Err(e.into()), | ||||||
|  |         }; | ||||||
|  |  | ||||||
|         Ok(V6Reader { |         Ok(V6Reader { | ||||||
|             metadata: serde_json::from_reader(&*meta_file)?, |             metadata: serde_json::from_reader(&*meta_file)?, | ||||||
| @@ -74,7 +76,7 @@ impl V6Reader { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn instance_uid(&self) -> Result<Option<Uuid>> { |     pub fn instance_uid(&self) -> Result<Option<Uuid>> { | ||||||
|         Ok(Some(self.instance_uid)) |         Ok(self.instance_uid) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn indexes(&self) -> Result<Box<dyn Iterator<Item = Result<V6IndexReader>> + '_>> { |     pub fn indexes(&self) -> Result<Box<dyn Iterator<Item = Result<V6IndexReader>> + '_>> { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user