status.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. package alstatus
  2. import (
  3. "fmt"
  4. "net"
  5. "pbx-api-gin/internal/app/stc/active"
  6. msgdata "pbx-api-gin/internal/app/stc/data"
  7. "pbx-api-gin/internal/app/stc/socket"
  8. "pbx-api-gin/pkg/lfshook"
  9. "pbx-api-gin/pkg/utils"
  10. )
  11. var ExtenStatMap map[string]string
  12. func init() {
  13. ExtenStatMap = make(map[string]string)
  14. }
  15. func SendToStc(conn net.Conn, data []byte) {
  16. _, err := conn.Write(data)
  17. if err != nil {
  18. fmt.Println("send msg err:", err)
  19. conn.Close()
  20. }
  21. lfshook.NewLogger().Logger.Infof("==send==data:==%x", data)
  22. }
  23. // report alarm status to STC
  24. func AlarmStatus(exten string, status string) {
  25. //check exten if it is a alarm exten
  26. if !utils.IsPAIU(exten) { // if not alarm device , return
  27. return
  28. }
  29. protocol := msgdata.NewProtocol()
  30. protocol.MessageID = 0x26
  31. protocol.DataLength = 0x04
  32. protocol.Data = make([]byte, 4)
  33. protocol.Data[0] = exten[2] - '0' //车厢号
  34. protocol.Data[1] = exten[3] - '0' //位置号
  35. //报警器工作状态
  36. switch status {
  37. case "unavailable", "Unavailable": //offline
  38. protocol.Data[2] = 0x00
  39. case "idle", "Idle": //idle
  40. protocol.Data[2] = 0x01
  41. case "dial": //dial
  42. protocol.Data[2] = 0x02
  43. return
  44. case "queue": //PAD alarm
  45. protocol.Data[2] = 0x03
  46. case "connect": //connect
  47. protocol.Data[2] = 0x04
  48. case "allreset": //allreset
  49. protocol.MessageID = 0x29
  50. protocol.Data[0] = 0x02 //all reset
  51. protocol.Data[1] = 0
  52. protocol.Data[2] = 0
  53. case "allhold": //allhold
  54. protocol.MessageID = 0x29
  55. protocol.Data[0] = 0x01 //all hold
  56. protocol.Data[1] = 0
  57. protocol.Data[2] = 0
  58. }
  59. encoded, errEn := protocol.Encode()
  60. if errEn != nil {
  61. fmt.Println("Encode error:", errEn)
  62. return
  63. }
  64. //check if actived
  65. lfshook.NewLogger().Logger.Infof("===AlarmStatus=ext:%s===carr:%x==========pos:%x=========status:%x", exten, protocol.Data[0], protocol.Data[1], protocol.Data[2])
  66. if active.Actived {
  67. if socket.Conn != nil {
  68. SendToStc(socket.Conn, encoded)
  69. }
  70. if socket.Conn8 != nil {
  71. SendToStc(socket.Conn8, encoded)
  72. }
  73. }
  74. }
  75. // report broadcast status to STC
  76. func PaStatus(src string, patype string, operation string) {
  77. lfshook.NewLogger().Logger.Infof("===PAStatus=Startext:%s=== type:%s=========action:%s", src, patype, operation)
  78. protocol := msgdata.NewProtocol()
  79. protocol.MessageID = 0x22
  80. protocol.DataLength = 0x04
  81. protocol.Data = make([]byte, 4)
  82. //广播发起方
  83. switch src {
  84. case "2311": //mc1
  85. protocol.Data[0] = 0x01
  86. case "2381": //mc8
  87. protocol.Data[0] = 0x08
  88. case "": //
  89. protocol.Data[0] = 0x00
  90. }
  91. //广播类型
  92. switch patype {
  93. case "C2C": //司机对讲---ami
  94. protocol.Data[1] = 0x01
  95. case "PA": //人工广播---ami
  96. protocol.Data[1] = 0x02
  97. case "DCS": //开关门提示音
  98. protocol.Data[1] = 0x03
  99. case "EMG": //紧急广播
  100. protocol.Data[1] = 0x04
  101. case "PAD": //报警
  102. protocol.Data[1] = 0x05
  103. case "CPA": //地面广播---ami
  104. protocol.Data[1] = 0x06
  105. case "SPC": //特殊
  106. protocol.Data[1] = 0x07
  107. case "STN": //报站
  108. protocol.Data[1] = 0x08
  109. case "CHK": //自检
  110. protocol.Data[1] = 0x09
  111. case "VOL": //自检
  112. protocol.Data[1] = 0x10
  113. }
  114. //操作类型
  115. switch operation {
  116. case "start": //
  117. protocol.Data[2] = 0x01
  118. case "end": //
  119. protocol.Data[2] = 0x02
  120. case "refuse": //
  121. protocol.Data[2] = 0x03
  122. case "fail": //
  123. protocol.Data[2] = 0x04
  124. case "continue": //
  125. protocol.Data[2] = 0x05
  126. }
  127. encoded, errEn := protocol.Encode()
  128. if errEn != nil {
  129. fmt.Println("Encode error:", errEn)
  130. return
  131. }
  132. if active.Actived {
  133. SendToStc(socket.Conn, encoded)
  134. SendToStc(socket.Conn8, encoded)
  135. }
  136. }
  137. // report broadcast status to STC
  138. func OccPad(operation string) {
  139. lfshook.NewLogger().Logger.Infof("===OCC-PAD========action:%s", operation)
  140. protocol := msgdata.NewProtocol()
  141. protocol.MessageID = 0x2A
  142. protocol.DataLength = 0x04
  143. protocol.Data = make([]byte, 4)
  144. //广播发起方
  145. switch operation {
  146. case "start": //mc1
  147. protocol.Data[0] = 0x01
  148. case "end": //mc8
  149. protocol.Data[0] = 0x02
  150. case "": //
  151. protocol.Data[0] = 0x00
  152. }
  153. encoded, errEn := protocol.Encode()
  154. if errEn != nil {
  155. fmt.Println("Encode error:", errEn)
  156. return
  157. }
  158. if active.Actived {
  159. SendToStc(socket.Conn, encoded)
  160. SendToStc(socket.Conn8, encoded)
  161. }
  162. }
  163. // report broadcast status to STC
  164. func SendRecordFile(filename, rcdtype string) {
  165. //time.Sleep(5 * time.Second)
  166. /*
  167. if !utils.FileExists(filename) {
  168. lfshook.NewLogger().Logger.Infof("===Recording filename not exist:%+v=", filename)
  169. return
  170. }
  171. */
  172. protocol := msgdata.NewProtocol()
  173. protocol.MessageID = 0x31
  174. filenameHex := []byte(filename)
  175. dataLen := len(filenameHex) + 1
  176. protocol.DataLength = uint16(dataLen)
  177. protocol.Data = make([]byte, dataLen)
  178. copy(protocol.Data[1:], filenameHex)
  179. switch rcdtype {
  180. case "C2C": //
  181. protocol.Data[0] = 0x01
  182. case "PA": //
  183. protocol.Data[0] = 0x02
  184. case "PAD": //
  185. protocol.Data[0] = 0x05
  186. case "CPA": //
  187. protocol.Data[0] = 0x06
  188. case "OTR": //
  189. protocol.Data[0] = 0x03
  190. //lfshook.NewLogger().Logger.Infof("===Recording filename:%+v=", protocol.Data)
  191. }
  192. encoded, errEn := protocol.Encode()
  193. if errEn != nil {
  194. fmt.Println("Encode error:", errEn)
  195. return
  196. }
  197. if active.Actived {
  198. SendToStc(socket.Conn, encoded)
  199. SendToStc(socket.Conn8, encoded)
  200. }
  201. }