Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
alist-org
GitHub Repository: alist-org/alist
Path: blob/main/internal/search/db/init.go
1562 views
1
package db
2
3
import (
4
"fmt"
5
"strings"
6
7
log "github.com/sirupsen/logrus"
8
9
"github.com/alist-org/alist/v3/internal/conf"
10
"github.com/alist-org/alist/v3/internal/db"
11
"github.com/alist-org/alist/v3/internal/search/searcher"
12
)
13
14
var config = searcher.Config{
15
Name: "database",
16
AutoUpdate: true,
17
}
18
19
func init() {
20
searcher.RegisterSearcher(config, func() (searcher.Searcher, error) {
21
db := db.GetDb()
22
switch conf.Conf.Database.Type {
23
case "mysql":
24
tableName := fmt.Sprintf("%ssearch_nodes", conf.Conf.Database.TablePrefix)
25
tx := db.Exec(fmt.Sprintf("CREATE FULLTEXT INDEX idx_%s_name_fulltext ON %s(name);", tableName, tableName))
26
if err := tx.Error; err != nil && !strings.Contains(err.Error(), "Error 1061 (42000)") { // duplicate error
27
log.Errorf("failed to create full text index: %v", err)
28
return nil, err
29
}
30
case "postgres":
31
db.Exec("CREATE EXTENSION pg_trgm;")
32
db.Exec("CREATE EXTENSION btree_gin;")
33
tableName := fmt.Sprintf("%ssearch_nodes", conf.Conf.Database.TablePrefix)
34
tx := db.Exec(fmt.Sprintf("CREATE INDEX idx_%s_name ON %s USING GIN (name);", tableName, tableName))
35
if err := tx.Error; err != nil && !strings.Contains(err.Error(), "SQLSTATE 42P07") {
36
log.Errorf("failed to create index using GIN: %v", err)
37
return nil, err
38
}
39
}
40
return &DB{}, nil
41
})
42
}
43
44