Nats.go 4.6 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. WorkOrderNum int64 // 工单数量
  32. UntreatedWorkOrderNum int64 // 未处理工单数量
  33. }
  34. var t_R T_R
  35. t_R.WorkOrderNum = WorkOrder.Read_WorkOrder_ALL_T_State_Count(string(m.Data), 0)
  36. t_R.UntreatedWorkOrderNum = WorkOrder.Read_WorkOrder_ALL_T_State_Count(string(m.Data), 2)
  37. t_R.Code = 200
  38. t_R.Msg = "ok"
  39. b, _ := msgpack.Marshal(&t_R)
  40. _ = lib.Nats.Publish(m.Reply, b)
  41. })
  42. }
  43. // 验证TOKEY
  44. func Verification(GetCookie string, GetString string) (bool, Account.User) {
  45. User_tokey := GetCookie
  46. if len(User_tokey) == 0 {
  47. User_tokey = GetString
  48. }
  49. if len(User_tokey) == 0 {
  50. return false, Account.User{}
  51. }
  52. // 请求-响应, 向 verification 发布一个 `ToKey` 请求数据,设置超时间3秒,如果有多个响应,只接收第一个收到的消息
  53. msg, err := lib.Nats.Request("Cold_User_verification", []byte(User_tokey), 3*time.Second)
  54. if err != nil {
  55. return false, Account.User{}
  56. }
  57. fmt.Printf("Cold_User_verification : %s\n", string(msg.Data))
  58. type T_R struct {
  59. Code int16 `xml:"Code"`
  60. Msg string `xml:"Msg"`
  61. Data Account.User `xml:"Data"` // 泛型
  62. }
  63. var t_R T_R
  64. err = msgpack.Unmarshal(msg.Data, &t_R)
  65. if err != nil {
  66. return false, Account.User{}
  67. }
  68. return true, t_R.Data
  69. }
  70. func CompanyListAllByT_name(T_name string) (list []Account.Company) {
  71. msg, err := lib.Nats.Request("Cold_User_CompanyListAllByT_name", []byte(T_name), 3*time.Second)
  72. if err != nil {
  73. return list
  74. }
  75. fmt.Printf("CompanyListAllByT_name: %s\n", string(msg.Data))
  76. type T_R struct {
  77. Code int16 `xml:"Code"`
  78. Msg string `xml:"Msg"`
  79. Data []Account.Company `xml:"Data"` // 泛型
  80. }
  81. var t_R T_R
  82. err = msgpack.Unmarshal(msg.Data, &t_R)
  83. if err != nil {
  84. return list
  85. }
  86. return t_R.Data
  87. }
  88. func UserListAll() (list []Account.User) {
  89. msg, err := lib.Nats.Request("Cold_User_UserListAll", []byte(""), 3*time.Second)
  90. if err != nil {
  91. return list
  92. }
  93. fmt.Printf("UserListAll: %v\n", string(msg.Data))
  94. type T_R struct {
  95. Code int16 `xml:"Code"`
  96. Msg string `xml:"Msg"`
  97. Data []Account.User `xml:"Data"` // 泛型
  98. }
  99. var t_R T_R
  100. err = msgpack.Unmarshal(msg.Data, &t_R)
  101. if err != nil {
  102. return list
  103. }
  104. return t_R.Data
  105. }
  106. // 添加系统日志
  107. func AddSysLogs(T_class, T_title string, T_txt interface{}) {
  108. type T_S struct {
  109. T_class string
  110. T_title string
  111. T_txt interface{}
  112. }
  113. b, _ := msgpack.Marshal(&T_S{T_class: T_class, T_title: T_title, T_txt: T_txt})
  114. // 发布-订阅 模式,向 test1 发布一个 `Hello World` 数据
  115. _ = lib.Nats.Publish("Cold_User_AddSysLogs", b)
  116. }
  117. // 添加用户日志
  118. func AddUserLogs(T_uuid, T_class, T_title string, T_txt interface{}) {
  119. type T_S struct {
  120. T_uuid string
  121. T_class string
  122. T_title string
  123. T_txt interface{}
  124. }
  125. b, _ := msgpack.Marshal(&T_S{T_uuid: T_uuid, T_class: T_class, T_title: T_title, T_txt: T_txt})
  126. // 发布-订阅 模式,向 test1 发布一个 `Hello World` 数据
  127. _ = lib.Nats.Publish("Cold_User_AddUserLogs", b)
  128. }
  129. func CheckUserPermissions(Power_Id int, Req_Url string) bool {
  130. type T_Req struct {
  131. Power_Id int `xml:"Power_Id"` // 权限id
  132. Req_Url string `xml:"Req_Url"` // 请求url
  133. }
  134. t_Req := T_Req{
  135. Power_Id: Power_Id,
  136. Req_Url: Req_Url,
  137. }
  138. b, _ := msgpack.Marshal(&t_Req)
  139. // 请求-响应, 向 verification 发布一个 `ToKey` 请求数据,设置超时间3秒,如果有多个响应,只接收第一个收到的消息
  140. msg, err := lib.Nats.Request("Cold_User_CheckUserPermissions", b, 3*time.Second)
  141. fmt.Printf("CheckUserPermissions : %s\n", string(msg.Data))
  142. if err != nil {
  143. return false
  144. }
  145. type T_R struct {
  146. Code int16 `xml:"Code"`
  147. Msg string `xml:"Msg"`
  148. Pass bool `xml:"Pass"` // 泛型
  149. }
  150. var t_R T_R
  151. err = msgpack.Unmarshal(msg.Data, &t_R)
  152. if err != nil {
  153. return false
  154. }
  155. return t_R.Pass
  156. }