config.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. package config
  2. import (
  3. "bytes"
  4. "os"
  5. "reflect"
  6. "time"
  7. utilsConfig "git.familybaby.top/flight/utils/config"
  8. "github.com/sirupsen/logrus"
  9. _ "github.com/spf13/viper/remote"
  10. )
  11. var (
  12. local = utilsConfig.New()
  13. ServerName = "upgrade"
  14. log = logrus.WithField("module", "config")
  15. )
  16. func _default() {
  17. local.Register("viper", "remote", false)
  18. local.Register("viper", "provider", "")
  19. local.Register("viper", "endpoint", "")
  20. local.Register("viper", "path", "")
  21. local.Register("oss", "type", "local")
  22. local.Register("oss", "endpoint", "")
  23. local.Register("oss", "access_key", "")
  24. local.Register("oss", "access_secret", "")
  25. local.Register("oss", "bucket_name", "")
  26. local.Register("oss", "base_url", "")
  27. local.Register("oss", "secure", false)
  28. local.Register("database", "type", "sqlite3")
  29. local.Register("database", "url", "./sqlite.db")
  30. local.Register("database", "debug", false)
  31. local.Register("database", "sync", true)
  32. local.Register("log", "compress", true)
  33. local.Register("log", "disable_colors", false)
  34. local.Register("log", "disable_timestamp", false)
  35. local.Register("log", "caller", true)
  36. local.Register("log", "filename", "log.txt")
  37. local.Register("log", "level", "trace")
  38. local.Register("log", "max_age", 30)
  39. local.Register("log", "max_backups", 3)
  40. local.Register("log", "max_size", 10)
  41. local.Register("log", "output", "stdout")
  42. local.Register("log", "timestamp_format", "2006-01-02 15:04:05")
  43. local.Register("web", "cert", "")
  44. local.Register("web", "cors", true)
  45. local.Register("web", "debug", true)
  46. local.Register("web", "email", "")
  47. local.Register("web", "gzip", true)
  48. local.Register("web", "hosts", []string{})
  49. local.Register("web", "port", 8080)
  50. local.Register("web", "https", "")
  51. local.Register("web", "key", ServerName)
  52. local.Register("web", "jwt.expire", 7200)
  53. local.Register("web", "jwt.method", "SigningMethodHS256")
  54. local.Register("service", "name", ServerName)
  55. local.Register("service", "description", "通用ota 平台")
  56. isExist, err := local.ReadConfigAndFileExist()
  57. if err != nil || !isExist {
  58. _ = local.Store()
  59. }
  60. }
  61. var oldMap map[string]any
  62. func isSame() bool {
  63. if oldMap == nil {
  64. oldMap = local.Viper.AllSettings()
  65. //不做这个操作 将无法通过远程 更新本地配置
  66. b := bytes.NewReader(nil)
  67. _ = local.Viper.ReadConfig(b)
  68. log.Debug("清空 本地viper 配置")
  69. }
  70. newMap := local.Viper.AllSettings()
  71. return reflect.DeepEqual(oldMap, newMap)
  72. }
  73. func watchRemote() {
  74. for {
  75. time.Sleep(time.Second * 60) // delay after each request
  76. // currently, only tested with etcd support
  77. err := local.Viper.WatchRemoteConfigOnChannel()
  78. if err != nil {
  79. log.Errorf("unable to read remote config: %v", err)
  80. continue
  81. }
  82. //err = local.Viper.ReadRemoteConfig()
  83. //if err != nil {
  84. // log.Error("读取viper远端配置失败:", err)
  85. //}
  86. if !isSame() {
  87. err = local.Store()
  88. if err == nil {
  89. log.Debug("远端配置 修改, 将退出应用", err)
  90. os.Exit(0)
  91. }
  92. }
  93. }
  94. }
  95. func init() {
  96. _default()
  97. param, err := GetViperParam()
  98. if err != nil {
  99. log.Error("获取本地viper 配置错误:", err)
  100. } else {
  101. if param.Remote {
  102. local.Viper.SetConfigName("")
  103. err = local.Viper.AddRemoteProvider(
  104. param.Provider,
  105. param.Endpoint,
  106. param.Path,
  107. )
  108. if err != nil {
  109. log.Error("添加viper远端配置失败:", err)
  110. } else {
  111. err = local.Viper.ReadRemoteConfig()
  112. if err != nil {
  113. log.Error("读取viper远端配置失败:", err)
  114. } else {
  115. }
  116. go watchRemote()
  117. }
  118. }
  119. }
  120. }
  121. func GetViperParam() (c viper, err error) {
  122. err = local.Unmarshal(&c, "viper")
  123. return
  124. }
  125. func GetLogParam() (c Log, err error) {
  126. err = local.Unmarshal(&c, "log")
  127. return
  128. }