mirror of https://github.com/Xhofe/alist
				
				
				
			
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
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
 | 
						|
	})
 | 
						|
}
 |