mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-25 20:57:35 +01:00
auto index creation
This commit is contained in:
parent
ac4d795eff
commit
2f93cce7aa
@ -104,7 +104,7 @@ trait IndexStore {
|
|||||||
async fn update_index<R, F>(&self, uuid: Uuid, f: F) -> Result<R>
|
async fn update_index<R, F>(&self, uuid: Uuid, f: F) -> Result<R>
|
||||||
where F: FnOnce(Index) -> Result<R> + Send + Sync + 'static,
|
where F: FnOnce(Index) -> Result<R> + Send + Sync + 'static,
|
||||||
R: Sync + Send + 'static;
|
R: Sync + Send + 'static;
|
||||||
async fn get_or_create(&self, uuid: Uuid) -> Result<Index>;
|
async fn get_or_create(&self, uuid: Uuid, primary_key: Option<String>) -> Result<Index>;
|
||||||
async fn get(&self, uuid: Uuid) -> Result<Option<Index>>;
|
async fn get(&self, uuid: Uuid) -> Result<Option<Index>>;
|
||||||
async fn delete(&self, uuid: &Uuid) -> Result<Option<Index>>;
|
async fn delete(&self, uuid: &Uuid) -> Result<Option<Index>>;
|
||||||
async fn get_meta(&self, uuid: &Uuid) -> Result<Option<IndexMeta>>;
|
async fn get_meta(&self, uuid: &Uuid) -> Result<Option<IndexMeta>>;
|
||||||
@ -473,14 +473,49 @@ impl IndexStore for MapIndexStore {
|
|||||||
Ok(meta)
|
Ok(meta)
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn get_or_create(&self, uuid: Uuid) -> Result<Index> {
|
async fn get_or_create(&self, uuid: Uuid, primary_key: Option<String>) -> Result<Index> {
|
||||||
match self.index_store.write().await.entry(uuid.clone()) {
|
match self.index_store.write().await.entry(uuid.clone()) {
|
||||||
Entry::Vacant(entry) => match self.meta_store.write().await.entry(uuid.clone()) {
|
Entry::Vacant(index_entry) => match self.meta_store.write().await.entry(uuid.clone()) {
|
||||||
Entry::Vacant(_) => {
|
Entry::Vacant(meta_entry) => {
|
||||||
todo!()
|
let now = Utc::now();
|
||||||
|
let meta = IndexMeta{
|
||||||
|
uuid,
|
||||||
|
created_at: now.clone(),
|
||||||
|
updated_at: now,
|
||||||
|
primary_key,
|
||||||
|
};
|
||||||
|
let meta = meta_entry.insert(meta);
|
||||||
|
let db_path = self.root.join(format!("index-{}", meta.uuid));
|
||||||
|
|
||||||
|
let index: Result<Index> = tokio::task::spawn_blocking(move || {
|
||||||
|
create_dir_all(&db_path).expect("can't create db");
|
||||||
|
let mut options = EnvOpenOptions::new();
|
||||||
|
options.map_size(4096 * 100_000);
|
||||||
|
let index = milli::Index::new(options, &db_path).map_err(|e| IndexError::Error(e))?;
|
||||||
|
let index = Index(Arc::new(index));
|
||||||
|
Ok(index)
|
||||||
|
})
|
||||||
|
.await
|
||||||
|
.expect("thread died");
|
||||||
|
|
||||||
|
Ok(index_entry.insert(index?).clone())
|
||||||
}
|
}
|
||||||
Entry::Occupied(entry) => {
|
Entry::Occupied(entry) => {
|
||||||
todo!()
|
let meta = entry.get();
|
||||||
|
let db_path = self.root.join(format!("index-{}", meta.uuid));
|
||||||
|
|
||||||
|
let index: Result<Index> = tokio::task::spawn_blocking(move || {
|
||||||
|
create_dir_all(&db_path).expect("can't create db");
|
||||||
|
let mut options = EnvOpenOptions::new();
|
||||||
|
options.map_size(4096 * 100_000);
|
||||||
|
let index = milli::Index::new(options, &db_path).map_err(|e| IndexError::Error(e))?;
|
||||||
|
let index = Index(Arc::new(index));
|
||||||
|
Ok(index)
|
||||||
|
})
|
||||||
|
.await
|
||||||
|
.expect("thread died");
|
||||||
|
|
||||||
|
Ok(index_entry.insert(index?).clone())
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
Entry::Occupied(entry) => Ok(entry.get().clone()),
|
Entry::Occupied(entry) => Ok(entry.get().clone()),
|
||||||
@ -508,7 +543,7 @@ impl IndexStore for MapIndexStore {
|
|||||||
where F: FnOnce(Index) -> Result<R> + Send + Sync + 'static,
|
where F: FnOnce(Index) -> Result<R> + Send + Sync + 'static,
|
||||||
R: Sync + Send + 'static,
|
R: Sync + Send + 'static,
|
||||||
{
|
{
|
||||||
let index = self.get_or_create(uuid.clone()).await?;
|
let index = self.get_or_create(uuid.clone(), None).await?;
|
||||||
let mut meta = self.get_meta(&uuid).await?
|
let mut meta = self.get_meta(&uuid).await?
|
||||||
.ok_or(IndexError::UnexistingIndex)?;
|
.ok_or(IndexError::UnexistingIndex)?;
|
||||||
match f(index) {
|
match f(index) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user