package db import ( "fmt" "strings" log "github.com/sirupsen/logrus" "github.com/alist-org/alist/v3/internal/conf" "github.com/alist-org/alist/v3/internal/db" "github.com/alist-org/alist/v3/internal/search/searcher" ) var config = searcher.Config{ Name: "database", AutoUpdate: true, } func init() { searcher.RegisterSearcher(config, func() (searcher.Searcher, error) { db := db.GetDb() switch conf.Conf.Database.Type { case "mysql": tableName := fmt.Sprintf("%ssearch_nodes", conf.Conf.Database.TablePrefix) tx := db.Exec(fmt.Sprintf("CREATE FULLTEXT INDEX idx_%s_name_fulltext ON %s(name);", tableName, tableName)) if err := tx.Error; err != nil && !strings.Contains(err.Error(), "Error 1061 (42000)") { // duplicate error log.Errorf("failed to create full text index: %v", err) return nil, err } case "postgres": db.Exec("CREATE EXTENSION pg_trgm;") db.Exec("CREATE EXTENSION btree_gin;") tableName := fmt.Sprintf("%ssearch_nodes", conf.Conf.Database.TablePrefix) tx := db.Exec(fmt.Sprintf("CREATE INDEX idx_%s_name ON %s USING GIN (name);", tableName, tableName)) if err := tx.Error; err != nil && !strings.Contains(err.Error(), "SQLSTATE 42P07") { log.Errorf("failed to create index using GIN: %v", err) return nil, err } } return &DB{}, nil }) }