config.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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. Tables map[string]string `json:"-"`
  26. TablesInitData map[string]string `json:"-"`
  27. }
  28. //go:embed tables/*
  29. var tableConfig embed.FS
  30. const Version = "2.0.0"
  31. const DBTypeMySQL = "mysql"
  32. const DBTypeSQLite = "sqlite"
  33. const SSLTypeAuto = "0" //自动生成证书
  34. const SSLTypeUser = "1" //用户上传证书
  35. var DBTypes []string = []string{DBTypeMySQL, DBTypeSQLite}
  36. var Instance *Config
  37. func Init() {
  38. var cfgData []byte
  39. var err error
  40. args := os.Args
  41. if len(args) >= 2 && args[len(args)-1] == "dev" {
  42. cfgData, err = os.ReadFile("./config/config.dev.json")
  43. if err != nil {
  44. return
  45. }
  46. } else {
  47. cfgData, err = os.ReadFile("./config/config.json")
  48. if err != nil {
  49. return
  50. }
  51. }
  52. err = json.Unmarshal(cfgData, &Instance)
  53. if err != nil {
  54. return
  55. }
  56. // 读取表设置
  57. Instance.Tables = map[string]string{}
  58. Instance.TablesInitData = map[string]string{}
  59. root := "tables/mysql"
  60. if Instance.DbType == DBTypeSQLite {
  61. root = "tables/sqlite"
  62. }
  63. err = fs.WalkDir(tableConfig, root, func(path string, info fs.DirEntry, err error) error {
  64. if !info.IsDir() && strings.HasSuffix(info.Name(), ".sql") {
  65. tableName := strings.ReplaceAll(info.Name(), ".sql", "")
  66. i, e := tableConfig.ReadFile(path)
  67. if e != nil {
  68. panic(e)
  69. }
  70. if strings.Contains(path, "data") {
  71. Instance.TablesInitData[tableName] = string(i)
  72. } else {
  73. Instance.Tables[tableName] = string(i)
  74. }
  75. }
  76. return nil
  77. })
  78. if err != nil {
  79. panic(err)
  80. }
  81. if Instance.Domain != "" && Instance.IsInit {
  82. IsInit = true
  83. }
  84. }