mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Make possible to use a custom uid and simplify the usage
This commit is contained in:
		| @@ -62,7 +62,7 @@ MeiliDB can serve multiple indexes, with different kinds of documents, | |||||||
| therefore, it is required to create the index before sending documents to it. | therefore, it is required to create the index before sending documents to it. | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| curl -i -X POST 'http://127.0.0.1:8080/indexes/movies' | curl -i -X POST 'http://127.0.0.1:8080/indexes' --data '{ "name": "Movies", "uid": "movies" }' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Now that the server knows about our brand new index, we can send it data. | Now that the server knows about our brand new index, we can send it data. | ||||||
|   | |||||||
| @@ -123,6 +123,7 @@ pub async fn get_index(ctx: Context<Data>) -> SResult<Response> { | |||||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] | #[serde(rename_all = "camelCase", deny_unknown_fields)] | ||||||
| struct IndexCreateRequest { | struct IndexCreateRequest { | ||||||
|     name: String, |     name: String, | ||||||
|  |     uid: Option<String>, | ||||||
|     schema: Option<SchemaBody>, |     schema: Option<SchemaBody>, | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -148,14 +149,17 @@ pub async fn create_index(mut ctx: Context<Data>) -> SResult<Response> { | |||||||
|  |  | ||||||
|     let db = &ctx.state().db; |     let db = &ctx.state().db; | ||||||
|  |  | ||||||
|     let generated_uid = loop { |     let uid = match body.uid { | ||||||
|         let uid = generate_uid(); |         Some(uid) => uid, | ||||||
|         if db.open_index(&uid).is_none() { |         None => loop { | ||||||
|             break uid; |             let uid = generate_uid(); | ||||||
|         } |             if db.open_index(&uid).is_none() { | ||||||
|  |                 break uid; | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     let created_index = match db.create_index(&generated_uid) { |     let created_index = match db.create_index(&uid) { | ||||||
|         Ok(index) => index, |         Ok(index) => index, | ||||||
|         Err(e) => return Err(ResponseError::create_index(e)), |         Err(e) => return Err(ResponseError::create_index(e)), | ||||||
|     }; |     }; | ||||||
| @@ -189,7 +193,7 @@ pub async fn create_index(mut ctx: Context<Data>) -> SResult<Response> { | |||||||
|  |  | ||||||
|     let response_body = IndexCreateResponse { |     let response_body = IndexCreateResponse { | ||||||
|         name: body.name, |         name: body.name, | ||||||
|         uid: generated_uid, |         uid, | ||||||
|         schema: body.schema, |         schema: body.schema, | ||||||
|         update_id: response_update_id, |         update_id: response_update_id, | ||||||
|         created_at: Utc::now(), |         created_at: Utc::now(), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user