From d8e18a8eb7746e69b00b6a84e7704d95d8eddb5f Mon Sep 17 00:00:00 2001 From: zouyixiong Date: Mon, 9 Sep 2024 17:15:25 +0800 Subject: [PATCH] bug fixed to filer store elastic deleteEntry (#5988) --- weed/filer/elastic/v7/elastic_store.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/weed/filer/elastic/v7/elastic_store.go b/weed/filer/elastic/v7/elastic_store.go index 7bd34852f..1832ddb73 100644 --- a/weed/filer/elastic/v7/elastic_store.go +++ b/weed/filer/elastic/v7/elastic_store.go @@ -159,8 +159,16 @@ func (store *ElasticStore) FindEntry(ctx context.Context, fullpath weed_util.Ful func (store *ElasticStore) DeleteEntry(ctx context.Context, fullpath weed_util.FullPath) (err error) { index := getIndex(fullpath, false) id := weed_util.Md5String([]byte(fullpath)) - if strings.Count(string(fullpath), "/") == 1 { - return store.deleteIndex(ctx, index) + strFullpath := string(fullpath) + + // A top-level subdirectory refers to an Elasticsearch index. + // If we delete an entry at the top level, we should attempt to delete the corresponding Elasticsearch index. + if strings.Count(strFullpath, "/") == 1 { + entry, err2 := store.FindEntry(ctx, fullpath) + if err2 == nil && entry.IsDirectory() { + bucketIndex := indexPrefix + strFullpath[1:] + store.deleteIndex(ctx, bucketIndex) + } } return store.deleteEntry(ctx, index, id) }