init.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. package dao
  2. import (
  3. "errors"
  4. "fmt"
  5. "github.com/allanpk716/ChineseSubFinder/internal/models"
  6. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_folder"
  7. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_util"
  8. "gorm.io/driver/sqlite"
  9. "gorm.io/gorm"
  10. "os"
  11. "path/filepath"
  12. "sync"
  13. )
  14. // GetDb 获取数据库实例
  15. func GetDb() *gorm.DB {
  16. if db == nil {
  17. once.Do(func() {
  18. err := InitDb()
  19. if err != nil {
  20. panic(err)
  21. }
  22. })
  23. }
  24. return db
  25. }
  26. // DeleteDbFile 删除 Db 文件
  27. func DeleteDbFile() error {
  28. if db != nil {
  29. sqlDB, err := db.DB()
  30. if err != nil {
  31. return err
  32. }
  33. err = sqlDB.Close()
  34. if err != nil {
  35. return err
  36. }
  37. }
  38. // 这里需要考虑是 Windows 的时候就是在本程序的允许目录下新建数据库即可
  39. // 如果是 Linux 则在 /config 目录下
  40. nowDbFileName := getDbName()
  41. if my_util.IsFile(nowDbFileName) == true {
  42. return os.Remove(nowDbFileName)
  43. }
  44. return nil
  45. }
  46. // InitDb 初始化数据库
  47. func InitDb() error {
  48. var err error
  49. // 新建数据库
  50. nowDbFileName := getDbName()
  51. dbDir := filepath.Dir(nowDbFileName)
  52. if my_util.IsDir(dbDir) == false {
  53. _ = os.MkdirAll(dbDir, os.ModePerm)
  54. }
  55. db, err = gorm.Open(sqlite.Open(nowDbFileName), &gorm.Config{})
  56. if err != nil {
  57. return errors.New(fmt.Sprintf("failed to connect database, %s", err.Error()))
  58. }
  59. // 迁移 schema
  60. err = db.AutoMigrate(&models.HotFix{}, &models.SubFormatRec{},
  61. &models.IMDBInfo{}, &models.VideoSubInfo{})
  62. if err != nil {
  63. return errors.New(fmt.Sprintf("db AutoMigrate error, %s", err.Error()))
  64. }
  65. return nil
  66. }
  67. func getDbName() string {
  68. return filepath.Join(my_folder.GetConfigRootDirFPath(), dbFileName)
  69. }
  70. var (
  71. db *gorm.DB
  72. once sync.Once
  73. )
  74. const (
  75. dbFileName = "ChineseSubFinder-Cache.db"
  76. )