config.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package config
  2. import (
  3. "embed"
  4. "encoding/json"
  5. "io/fs"
  6. "os"
  7. "strings"
  8. )
  9. var IsInit bool
  10. type Config struct {
  11. LogLevel string `json:"logLevel"` // 日志级别
  12. Domain string `json:"domain"`
  13. WebDomain string `json:"webDomain"`
  14. DkimPrivateKeyPath string `json:"dkimPrivateKeyPath"`
  15. SSLType string `json:"sslType"` // 0表示自动生成证书,1表示用户上传证书
  16. SSLPrivateKeyPath string `json:"SSLPrivateKeyPath"`
  17. SSLPublicKeyPath string `json:"SSLPublicKeyPath"`
  18. DbDSN string `json:"dbDSN"`
  19. DbType string `json:"dbType"`
  20. WeChatPushAppId string `json:"weChatPushAppId"`
  21. WeChatPushSecret string `json:"weChatPushSecret"`
  22. WeChatPushTemplateId string `json:"weChatPushTemplateId"`
  23. WeChatPushUserId string `json:"weChatPushUserId"`
  24. IsInit bool `json:"isInit"`
  25. HttpsEnabled int `json:"httpsEnabled"` //后台页面是否启用https,0默认(启用),1启用,2不启用
  26. Tables map[string]string `json:"-"`
  27. TablesInitData map[string]string `json:"-"`
  28. }
  29. //go:embed tables/*
  30. var tableConfig embed.FS
  31. const Version = "2.1.0"
  32. const DBTypeMySQL = "mysql"
  33. const DBTypeSQLite = "sqlite"
  34. const SSLTypeAuto = "0" //自动生成证书
  35. const SSLTypeUser = "1" //用户上传证书
  36. var DBTypes []string = []string{DBTypeMySQL, DBTypeSQLite}
  37. var Instance *Config
  38. func Init() {
  39. var cfgData []byte
  40. var err error
  41. args := os.Args
  42. if len(args) >= 2 && args[len(args)-1] == "dev" {
  43. cfgData, err = os.ReadFile("./config/config.dev.json")
  44. if err != nil {
  45. return
  46. }
  47. } else {
  48. cfgData, err = os.ReadFile("./config/config.json")
  49. if err != nil {
  50. return
  51. }
  52. }
  53. err = json.Unmarshal(cfgData, &Instance)
  54. if err != nil {
  55. return
  56. }
  57. // 读取表设置
  58. Instance.Tables = map[string]string{}
  59. Instance.TablesInitData = map[string]string{}
  60. root := "tables/mysql"
  61. if Instance.DbType == DBTypeSQLite {
  62. root = "tables/sqlite"
  63. }
  64. err = fs.WalkDir(tableConfig, root, func(path string, info fs.DirEntry, err error) error {
  65. if !info.IsDir() && strings.HasSuffix(info.Name(), ".sql") {
  66. tableName := strings.ReplaceAll(info.Name(), ".sql", "")
  67. i, e := tableConfig.ReadFile(path)
  68. if e != nil {
  69. panic(e)
  70. }
  71. if strings.Contains(path, "data") {
  72. Instance.TablesInitData[tableName] = string(i)
  73. } else {
  74. Instance.Tables[tableName] = string(i)
  75. }
  76. }
  77. return nil
  78. })
  79. if err != nil {
  80. panic(err)
  81. }
  82. if Instance.Domain != "" && Instance.IsInit {
  83. IsInit = true
  84. }
  85. }