wip: add indexer mappings #495

merged
opened by boltless.me targeting master from boltless.me/core: feat/search
Changed files
+57 -1
appview
db
indexer
issues
+1
appview/db/issues.go
···
return nil, nil, err
}
+
issue.RepoAt = repoAt
createdTime, err := time.Parse(time.RFC3339, createdAt)
if err != nil {
return nil, nil, err
+56 -1
appview/indexer/issues/indexer.go
···
"github.com/blevesearch/bleve/v2"
"github.com/blevesearch/bleve/v2/index/upsidedown"
+
"github.com/blevesearch/bleve/v2/mapping"
"github.com/blevesearch/bleve/v2/search/query"
"tangled.sh/tangled.sh/core/appview/db"
"tangled.sh/tangled.sh/core/appview/indexer/base36"
···
"tangled.sh/tangled.sh/core/appview/pagination"
)
+
const (
+
issueIndexerDocType = "issueIndexerDocType"
+
)
+
type Indexer struct {
indexer bleve.Index
path string
···
log.Println("Initialized the issue indexer")
}
+
func generateIssueIndexMapping() (mapping.IndexMapping, error) {
+
mapping := bleve.NewIndexMapping()
+
docMapping := bleve.NewDocumentMapping()
+
+
textFieldMapping := bleve.NewTextFieldMapping()
+
textFieldMapping.Store = false
+
textFieldMapping.IncludeInAll = false
+
+
boolFieldMapping := bleve.NewBooleanFieldMapping()
+
boolFieldMapping.Store = false
+
boolFieldMapping.IncludeInAll = false
+
+
keywordFieldMapping := bleve.NewKeywordFieldMapping()
+
keywordFieldMapping.Store = false
+
keywordFieldMapping.IncludeInAll = false
+
+
// numericFieldMapping := bleve.NewNumericFieldMapping()
+
+
docMapping.AddFieldMappingsAt("title", textFieldMapping)
+
docMapping.AddFieldMappingsAt("body", textFieldMapping)
+
+
docMapping.AddFieldMappingsAt("repo_at", keywordFieldMapping)
+
docMapping.AddFieldMappingsAt("is_open", boolFieldMapping)
+
+
mapping.AddDocumentMapping(issueIndexerDocType, docMapping)
+
mapping.AddDocumentMapping("_all", bleve.NewDocumentDisabledMapping())
+
mapping.DefaultMapping = bleve.NewDocumentDisabledMapping()
+
+
return mapping, nil
+
}
+
func (ix *Indexer) intialize(_ context.Context) (bool, error) {
if ix.indexer != nil {
return false, errors.New("indexer is already initialized")
···
return true, nil
}
-
mapping := bleve.NewIndexMapping()
+
mapping, err := generateIssueIndexMapping()
+
if err != nil {
+
return false, err
+
}
indexer, err = bleve.New(ix.path, mapping)
if err != nil {
return false, err
···
}
dataList = append(dataList, &IssueData{
ID: issue.ID,
+
RepoAt: issue.RepoAt.String(),
IssueID: issue.IssueId,
Title: issue.Title,
Body: issue.Body,
IsOpen: issue.Open,
})
+
log.Println(dataList[len(dataList)-1])
}
err = ix.Index(ctx, dataList...)
if err != nil {
···
// IssueData data stored and will be indexed
type IssueData struct {
ID int64 `json:"id"`
+
RepoAt string `json:"repo_at"`
IssueID int `json:"issue_id"`
Title string `json:"title"`
Body string `json:"body"`
···
Comments []IssueCommentData `json:"comments"`
}
+
// Type returns the document type, for bleve's mapping.Classifier interface.
+
func (i *IssueData) Type() string {
+
return issueIndexerDocType
+
}
+
+
type IssueCommentData struct {
Body string `json:"body"`
}
···
matchAndQuery(opts.Keyword, "body"),
))
}
+
queries = append(queries, keywordFieldQuery(opts.RepoAt, "repo_at"))
queries = append(queries, boolFieldQuery(opts.IsOpen, "is_open"))
// TODO: append more queries
···
q.FieldVal = field
return q
}
+
+
func keywordFieldQuery(keyword, field string) query.Query {
+
q := bleve.NewTermQuery(keyword)
+
q.FieldVal = field
+
return q
+
}