Skip to content

Commit

Permalink
Merge pull request #56 from basenana/fix/meiliindex
Browse files Browse the repository at this point in the history
split doc and attr index
  • Loading branch information
zwwhdls authored Dec 14, 2024
2 parents c98e5eb + c617439 commit 728afc7
Show file tree
Hide file tree
Showing 4 changed files with 70 additions and 28 deletions.
3 changes: 2 additions & 1 deletion config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,8 @@ type MeiliConfig struct {
MasterKey string `json:"masterKey,omitempty"`
AdminApiKey string `json:"adminApiKey,omitempty"`
SearchApiKey string `json:"searchApiKey,omitempty"`
Index string `json:"index,omitempty"`
DocIndex string `json:"docIndex,omitempty"`
AttrIndex string `json:"attrIndex,omitempty"`
}

type LLMConfig struct {
Expand Down
5 changes: 5 additions & 0 deletions pkg/models/doc/attr.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,11 @@ type DocumentAttr struct {
Value interface{} `json:"value"`
}

var (
DocAttrFilterableAttrs = []string{"namespace", "entryId", "key", "id", "kind", "value"}
DocAttrSortAttrs = []string{"createdAt", "updatedAt"}
)

var _ DocPtrInterface = &DocumentAttr{}

func (d *DocumentAttr) ID() string {
Expand Down
5 changes: 2 additions & 3 deletions pkg/models/doc/document.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,8 @@ import (
)

var (
DocFilterableAttrs = []string{"namespace", "id", "entryId", "kind", "name", "source", "webUrl", "createdAt", "updatedAt"}
DocAttrFilterableAttrs = []string{"namespace", "entryId", "key", "id", "kind", "value"}
DocSortAttrs = []string{"createdAt", "updatedAt", "name"}
DocFilterableAttrs = []string{"namespace", "id", "entryId", "kind", "name", "source", "webUrl", "createdAt", "updatedAt"}
DocSortAttrs = []string{"createdAt", "updatedAt", "name"}
)

type DocPtrInterface interface {
Expand Down
85 changes: 61 additions & 24 deletions pkg/store/docstore/meili.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,15 +37,17 @@ type MeiliClient struct {
masterKey string
adminApiKey string
searchApiKey string
index meilisearch.IndexManager
docIndex meilisearch.IndexManager
attrIndex meilisearch.IndexManager
client meilisearch.ServiceManager
}

var _ DocStoreInterface = &MeiliClient{}

func NewMeiliClient(conf config.Config) (DocStoreInterface, error) {
client := meilisearch.New(conf.MeiliConfig.MeiliUrl, meilisearch.WithAPIKey(conf.MeiliConfig.MasterKey))
index := client.Index(conf.MeiliConfig.Index)
docIndex := client.Index(conf.MeiliConfig.DocIndex)
attrIndex := client.Index(conf.MeiliConfig.AttrIndex)

log := logger.NewLog("meilisearch")
meiliClient := &MeiliClient{
Expand All @@ -54,62 +56,97 @@ func NewMeiliClient(conf config.Config) (DocStoreInterface, error) {
masterKey: conf.MeiliConfig.MasterKey,
adminApiKey: conf.MeiliConfig.AdminApiKey,
searchApiKey: conf.MeiliConfig.SearchApiKey,
index: index,
docIndex: docIndex,
attrIndex: attrIndex,
client: client,
}
return meiliClient, meiliClient.init()
}

func (c *MeiliClient) init() error {
filterableAttrs := append(doc.DocFilterableAttrs, doc.DocAttrFilterableAttrs...)

attrs, err := c.index.GetFilterableAttributes()
attrs, err := c.docIndex.GetFilterableAttributes()
if err != nil {
return err
}
if !utils.Equal(filterableAttrs, attrs) {
t, err := c.index.UpdateFilterableAttributes(&filterableAttrs)
if !utils.Equal(doc.DocFilterableAttrs, attrs) {
t, err := c.docIndex.UpdateFilterableAttributes(&doc.DocFilterableAttrs)
if err != nil {
return err
}
if err = c.wait(context.TODO(), t.TaskUID); err != nil {
if err = c.wait(context.TODO(), "document", t.TaskUID); err != nil {
return err
}
}

sortAttrs := doc.DocSortAttrs
crtSortAttrs, err := c.index.GetSortableAttributes()
crtSortAttrs, err := c.docIndex.GetSortableAttributes()
if err != nil {
return err
}
if !utils.Equal(sortAttrs, crtSortAttrs) {
t, err := c.index.UpdateSortableAttributes(&sortAttrs)
t, err := c.docIndex.UpdateSortableAttributes(&sortAttrs)
if err != nil {
return err
}
if err = c.wait(context.TODO(), "document", t.TaskUID); err != nil {
return err
}
}

// attr index
attrAttrs, err := c.attrIndex.GetFilterableAttributes()
if err != nil {
return err
}
if !utils.Equal(doc.DocAttrFilterableAttrs, attrAttrs) {
t, err := c.docIndex.UpdateFilterableAttributes(&doc.DocAttrFilterableAttrs)
if err != nil {
return err
}
if err = c.wait(context.TODO(), t.TaskUID); err != nil {
if err = c.wait(context.TODO(), "attr", t.TaskUID); err != nil {
return err
}
}
attrSortAttrs := doc.DocAttrSortAttrs
crtAttrSortAttrs, err := c.docIndex.GetSortableAttributes()
if err != nil {
return err
}
if !utils.Equal(attrSortAttrs, crtAttrSortAttrs) {
t, err := c.docIndex.UpdateSortableAttributes(&attrSortAttrs)
if err != nil {
return err
}
if err = c.wait(context.TODO(), "attr", t.TaskUID); err != nil {
return err
}
}
return nil
}

func (c *MeiliClient) index(kind string) meilisearch.IndexManager {
if kind == "attr" {
return c.attrIndex
}
return c.docIndex
}

func (c *MeiliClient) Store(ctx context.Context, docPtr doc.DocPtrInterface) error {
c.log.Debugf("store entryId %s %s: %s", docPtr.EntryID(), docPtr.Type(), docPtr.String())
task, err := c.index.AddDocuments(docPtr, "id")
task, err := c.index(docPtr.Type()).AddDocuments(docPtr, "id")
if err != nil {
c.log.Error(err)
return err
}
if err := c.wait(ctx, task.TaskUID); err != nil {
if err := c.wait(ctx, docPtr.Type(), task.TaskUID); err != nil {
c.log.Errorf("store document with entryId %s error: %s", docPtr.EntryID(), err)
}
return nil
}

func (c *MeiliClient) FilterAttr(ctx context.Context, query *doc.DocumentAttrQuery) (doc.DocumentAttrList, error) {
c.log.Debugf("query document attr : [%s]", query.String())
rep, err := c.index.Search("", query.ToRequest())
rep, err := c.index("attr").Search("", query.ToRequest())
if err != nil {
return nil, err
}
Expand All @@ -129,7 +166,7 @@ func (c *MeiliClient) FilterAttr(ctx context.Context, query *doc.DocumentAttrQue

func (c *MeiliClient) Search(ctx context.Context, query *doc.DocumentQuery) (doc.DocumentList, error) {
c.log.Debugf("search document: [%s] query: [%s]", query.Search, query.String())
rep, err := c.index.Search(query.Search, query.ToRequest())
rep, err := c.index("document").Search(query.Search, query.ToRequest())
if err != nil {
return nil, err
}
Expand All @@ -149,25 +186,25 @@ func (c *MeiliClient) Search(ctx context.Context, query *doc.DocumentQuery) (doc

func (c *MeiliClient) Update(ctx context.Context, document *doc.Document) error {
c.log.Debugf("update document: %s", document.ID())
t, err := c.index.UpdateDocuments(document)
t, err := c.index(document.Type()).UpdateDocuments(document)
if err != nil {
c.log.Error(err)
return err
}
if err := c.wait(ctx, t.TaskUID); err != nil {
if err := c.wait(ctx, document.Type(), t.TaskUID); err != nil {
c.log.Errorf("update document %s error: %s", document.ID, err)
}
return nil
}

func (c *MeiliClient) Delete(ctx context.Context, docId string) error {
c.log.Debugf("delete document: %s", docId)
t, err := c.index.DeleteDocument(docId)
t, err := c.index("document").DeleteDocument(docId)
if err != nil {
c.log.Error(err)
return err
}
if err := c.wait(ctx, t.TaskUID); err != nil {
if err := c.wait(ctx, "document", t.TaskUID); err != nil {
c.log.Errorf("delete document %s error: %s", docId, err)
}
return nil
Expand All @@ -180,26 +217,26 @@ func (c *MeiliClient) DeleteByFilter(ctx context.Context, aqs doc.DocumentAttrQu
filter = append(filter, aq.ToFilter())
}

t, err := c.index.DeleteDocumentsByFilter(filter)
t, err := c.index("attr").DeleteDocumentsByFilter(filter)
if err != nil {
c.log.Error(err)
return err
}
if err := c.wait(ctx, t.TaskUID); err != nil {
if err := c.wait(ctx, "attr", t.TaskUID); err != nil {
c.log.Errorf("delete document by filter error: %s", err)
}
return nil
}

func (c *MeiliClient) wait(ctx context.Context, taskUID int64) error {
func (c *MeiliClient) wait(ctx context.Context, kind string, taskUID int64) error {
t := time.NewTicker(100 * time.Millisecond)
defer t.Stop()
for {
select {
case <-ctx.Done():
return fmt.Errorf("context timeout")
case <-t.C:
t, err := c.index.GetTask(taskUID)
t, err := c.index(kind).GetTask(taskUID)
if err != nil {
c.log.Error(err)
return err
Expand Down

0 comments on commit 728afc7

Please sign in to comment.