config.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package configs
  2. import (
  3. "crypto/rsa"
  4. "fmt"
  5. "github.com/go-redis/redis/v8"
  6. _ "github.com/go-sql-driver/mysql"
  7. "github.com/spf13/viper"
  8. "os"
  9. "xorm.io/xorm"
  10. )
  11. var (
  12. Config *viper.Viper
  13. Engine *xorm.Engine
  14. RedisDb *redis.Client
  15. WxPay WxPayConfig
  16. )
  17. //type User struct {
  18. // Id int64 `xorm:"'id'" json:"id"`
  19. // Username string `xorm:"'username'" json:"username"`
  20. // Password string `xorm:"'password'" json:"password"`
  21. // Creation_time int `xorm:"'creation_time'" json:"creation_Time"`
  22. // Login_time int `xorm:"'login_time'" json:"login_Time"`
  23. // Status int `xorm:"'status'" json:"status"`
  24. // Role_id int `xorm:"'role_id'" json:"role_id"`
  25. // Phone string `xorm:"'phone'" json:"phone"`
  26. // Email string `xorm:"'email'" json:"email"`
  27. // Name string `xorm:"'name'" json:"name"`
  28. // Avatar string `xorm:"'avatar'" json:"avatar"`
  29. // RecommendCode string `xorm:"'recommend_code'" json:"recommend_code"`
  30. //}
  31. //
  32. //func (receiver User) String() string {
  33. // return fmt.Sprintf("User{Id:%d, Username:%s, Password:%s, Creation_time:%d, Login_time:%d, Status:%d, Role_id:%d, Phone:%s, Email:%s, Name:%s, Avatar:%s, RecommendCode:%s}", receiver.Id, receiver.Username, receiver.Password, receiver.Creation_time, receiver.Login_time, receiver.Status, receiver.Role_id, receiver.Phone, receiver.Email, receiver.Name, receiver.Avatar, receiver.RecommendCode)
  34. //}
  35. //
  36. //type Role struct {
  37. // Id int `xorm:"'id'" json:"id"`
  38. // Role_name string `xorm:"'role_name'" json:"role_Name"`
  39. //}
  40. //type Role_authority struct {
  41. // Authority_id int `xorm:"'authority_id'" json:"authority_id"`
  42. // Role_id int `xorm:"'role_id'" json:"role_id"`
  43. //}
  44. //type Authority struct {
  45. // Id int `xorm:"'id'" json:"id"`
  46. // Authority_name string `xorm:"'authority_name'" json:"authority_Name"`
  47. // Authority_path string `xorm:"'authority_path'" json:"authority_Path"`
  48. //}
  49. //
  50. //type MysqlData struct {
  51. // User `xorm:"extends"`
  52. // Role `xorm:"extends"`
  53. // Role_authority `xorm:"extends"`
  54. // Authority `xorm:"extends"`
  55. //}
  56. func ConfigInit() {
  57. //获取项目的执行路径
  58. path, err := os.Getwd()
  59. if err != nil {
  60. panic(err)
  61. }
  62. config := viper.New()
  63. config.AddConfigPath(path + "/configs") //设置读取的文件路径
  64. config.SetConfigName("config") //设置读取的文件名
  65. config.SetConfigType("yaml") //设置文件的类型
  66. //尝试进行配置读取
  67. if err := config.ReadInConfig(); err != nil {
  68. panic(err)
  69. }
  70. fmt.Println(fmt.Sprintf("%s:%s@(%s:%s)/%s?charset=utf8", config.Get("mysql.user"), config.Get("mysql.password"), config.Get("mysql.host"), config.Get("mysql.port"), config.Get("mysql.database")))
  71. Engine, err = xorm.NewEngine("mysql", fmt.Sprintf("%s:%s@(%s:%s)/%s?charset=utf8", config.Get("mysql.user"), config.Get("mysql.password"), config.Get("mysql.host"), config.Get("mysql.port"), config.Get("mysql.database")))
  72. Engine.Ping() //连接测试
  73. //TODO 显示sql
  74. Engine.ShowSQL(true)
  75. Engine.Logger().ShowSQL(true)
  76. RedisDb = redis.NewClient(&redis.Options{
  77. Addr: fmt.Sprintf("%s:%s", config.Get("redis.host"), config.Get("redis.port")), // Redis地址
  78. Password: "", // Redis密码,如果没有则为空字符串
  79. DB: 0, // 使用默认DB
  80. })
  81. //开启debug模式
  82. Config = config
  83. fmt.Println("xorm 数据库orm框架初始化成功")
  84. //PayConfigInit()
  85. }
  86. func ConfigInitByUrl(configUrl string) {
  87. //获取项目的执行路径
  88. config := viper.New()
  89. config.AddConfigPath(configUrl + "\\configs") //设置读取的文件路径
  90. config.SetConfigName("config") //设置读取的文件名
  91. config.SetConfigType("yaml") //设置文件的类型
  92. //尝试进行配置读取
  93. if err := config.ReadInConfig(); err != nil {
  94. panic(err)
  95. }
  96. fmt.Println(fmt.Sprintf("%s:%s@(%s:%s)/%s?charset=utf8", config.Get("mysql.user"), config.Get("mysql.password"), config.Get("mysql.host"), config.Get("mysql.port"), config.Get("mysql.database")))
  97. Engine, _ := xorm.NewEngine("mysql", fmt.Sprintf("%s:%s@(%s:%s)/%s?charset=utf8", config.Get("mysql.user"), config.Get("mysql.password"), config.Get("mysql.host"), config.Get("mysql.port"), config.Get("mysql.database")))
  98. Engine.Ping() //连接测试
  99. //TODO 显示sql
  100. Engine.ShowSQL(true)
  101. Engine.Logger().ShowSQL(true)
  102. RedisDb = redis.NewClient(&redis.Options{
  103. Addr: fmt.Sprintf("%s:%s", config.Get("redis.host"), config.Get("redis.port")), // Redis地址
  104. Password: "", // Redis密码,如果没有则为空字符串
  105. DB: 0, // 使用默认DB
  106. })
  107. Config = config
  108. fmt.Println("xorm 数据库orm框架初始化成功")
  109. }
  110. type WxPayConfig struct {
  111. MchID string
  112. MchCertificateSerialNumber string
  113. MchAPIv3Key string
  114. PrivateKey *rsa.PrivateKey
  115. }
  116. func (w WxPayConfig) String() string {
  117. return fmt.Sprintf("MchID:%s, MchCertificateSerialNumber:%s, MchAPIv3Key:%s",
  118. w.MchID, w.MchCertificateSerialNumber, w.MchAPIv3Key)
  119. }