Nats.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. package Nats
  2. import (
  3. "Cold_WorkOrder/conf"
  4. "Cold_WorkOrder/lib"
  5. "Cold_WorkOrder/models/Account"
  6. "Cold_WorkOrder/models/WorkOrder"
  7. "fmt"
  8. "github.com/nats-io/nats.go"
  9. "github.com/vmihailenco/msgpack/v5"
  10. "time"
  11. )
  12. func Init() {
  13. fmt.Println("============Nats init============")
  14. var err error
  15. // 连接Nats服务器
  16. lib.Nats, err = nats.Connect("nats://" + conf.NatsServer_Url)
  17. if err != nil {
  18. fmt.Println("nats 连接失败!")
  19. panic(err)
  20. }
  21. fmt.Println("nats OK!")
  22. go NatsInit()
  23. }
  24. func NatsInit() {
  25. // 请求-响应 获取工单总数
  26. _, _ = lib.Nats.Subscribe("Cold_WorkOrder_Read_WorkOrderT_State_Count", func(m *nats.Msg) {
  27. fmt.Printf("Cold_WorkOrder_Read_WorkOrderT_State_Count message: %s\n", string(m.Data))
  28. type T_R struct {
  29. Code int16 `xml:"Code"`
  30. Msg string `xml:"Msg"`
  31. TodayWorkOrderNum int64 // 工单数量
  32. UntreatedWorkOrderNum int64 // 未处理工单数量
  33. }
  34. var t_R T_R
  35. today := time.Now().Format("2006-01-02") + " 00:00:00"
  36. t_R.TodayWorkOrderNum = WorkOrder.Read_WorkOrder_ALL_T_State_Count(string(m.Data), 0, today)
  37. t_R.UntreatedWorkOrderNum = WorkOrder.Read_WorkOrder_ALL_T_State_Count(string(m.Data), 2, "")
  38. t_R.Code = 200
  39. t_R.Msg = "ok"
  40. b, _ := msgpack.Marshal(&t_R)
  41. _ = lib.Nats.Publish(m.Reply, b)
  42. })
  43. }
  44. // 验证TOKEY
  45. func Verification(GetCookie string, GetString string) (bool, Account.User) {
  46. User_tokey := GetCookie
  47. if len(User_tokey) == 0 {
  48. User_tokey = GetString
  49. }
  50. if len(User_tokey) == 0 {
  51. return false, Account.User{}
  52. }
  53. // 请求-响应, 向 verification 发布一个 `ToKey` 请求数据,设置超时间3秒,如果有多个响应,只接收第一个收到的消息
  54. msg, err := lib.Nats.Request("Cold_User_verification", []byte(User_tokey), 3*time.Second)
  55. if err != nil {
  56. return false, Account.User{}
  57. }
  58. fmt.Printf("Cold_User_verification : %s\n", string(msg.Data))
  59. type T_R struct {
  60. Code int16 `xml:"Code"`
  61. Msg string `xml:"Msg"`
  62. Data Account.User `xml:"Data"` // 泛型
  63. }
  64. var t_R T_R
  65. err = msgpack.Unmarshal(msg.Data, &t_R)
  66. if err != nil {
  67. return false, Account.User{}
  68. }
  69. return true, t_R.Data
  70. }
  71. func CompanyListAllByT_name(T_name string) (list []Account.Company) {
  72. msg, err := lib.Nats.Request("Cold_User_CompanyListAllByT_name", []byte(T_name), 3*time.Second)
  73. if err != nil {
  74. return list
  75. }
  76. fmt.Printf("CompanyListAllByT_name: %s\n", string(msg.Data))
  77. type T_R struct {
  78. Code int16 `xml:"Code"`
  79. Msg string `xml:"Msg"`
  80. Data []Account.Company `xml:"Data"` // 泛型
  81. }
  82. var t_R T_R
  83. err = msgpack.Unmarshal(msg.Data, &t_R)
  84. if err != nil {
  85. return list
  86. }
  87. return t_R.Data
  88. }
  89. func UserListAll() (list []Account.User) {
  90. msg, err := lib.Nats.Request("Cold_User_UserListAll", []byte(""), 3*time.Second)
  91. if err != nil {
  92. return list
  93. }
  94. fmt.Printf("UserListAll: %v\n", string(msg.Data))
  95. type T_R struct {
  96. Code int16 `xml:"Code"`
  97. Msg string `xml:"Msg"`
  98. Data []Account.User `xml:"Data"` // 泛型
  99. }
  100. var t_R T_R
  101. err = msgpack.Unmarshal(msg.Data, &t_R)
  102. if err != nil {
  103. return list
  104. }
  105. return t_R.Data
  106. }
  107. // 添加系统日志
  108. func AddSysLogs(T_class, T_title string, T_txt interface{}) {
  109. type T_S struct {
  110. T_class string
  111. T_title string
  112. T_txt interface{}
  113. }
  114. b, _ := msgpack.Marshal(&T_S{T_class: T_class, T_title: T_title, T_txt: T_txt})
  115. // 发布-订阅 模式,向 test1 发布一个 `Hello World` 数据
  116. _ = lib.Nats.Publish("Cold_User_AddSysLogs", b)
  117. }
  118. // 添加用户日志
  119. func AddUserLogs(T_uuid, T_class, T_title string, T_txt interface{}) {
  120. type T_S struct {
  121. T_uuid string
  122. T_class string
  123. T_title string
  124. T_txt interface{}
  125. }
  126. b, _ := msgpack.Marshal(&T_S{T_uuid: T_uuid, T_class: T_class, T_title: T_title, T_txt: T_txt})
  127. // 发布-订阅 模式,向 test1 发布一个 `Hello World` 数据
  128. _ = lib.Nats.Publish("Cold_User_AddUserLogs", b)
  129. }
  130. func CheckUserPermissions(Power_Id int, Req_Url string) bool {
  131. type T_Req struct {
  132. Power_Id int `xml:"Power_Id"` // 权限id
  133. Req_Url string `xml:"Req_Url"` // 请求url
  134. }
  135. t_Req := T_Req{
  136. Power_Id: Power_Id,
  137. Req_Url: Req_Url,
  138. }
  139. b, _ := msgpack.Marshal(&t_Req)
  140. // 请求-响应, 向 verification 发布一个 `ToKey` 请求数据,设置超时间3秒,如果有多个响应,只接收第一个收到的消息
  141. msg, err := lib.Nats.Request("Cold_User_CheckUserPermissions", b, 3*time.Second)
  142. fmt.Printf("CheckUserPermissions : %s\n", string(msg.Data))
  143. if err != nil {
  144. return false
  145. }
  146. type T_R struct {
  147. Code int16 `xml:"Code"`
  148. Msg string `xml:"Msg"`
  149. Pass bool `xml:"Pass"` // 泛型
  150. }
  151. var t_R T_R
  152. err = msgpack.Unmarshal(msg.Data, &t_R)
  153. if err != nil {
  154. return false
  155. }
  156. return t_R.Pass
  157. }