deviceMgr.go 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. package tcp
  2. import (
  3. "encoding/hex"
  4. "errors"
  5. "fmt"
  6. "go.uber.org/zap"
  7. "gorm.io/gorm"
  8. "net"
  9. Dev "server/dao/devices"
  10. deviceDao "server/dao/devices"
  11. promodel "server/model/common/devices"
  12. "server/protocol"
  13. "server/utils/logger"
  14. "strings"
  15. "time"
  16. )
  17. var (
  18. Devices = make(map[string]*Device) // 存储连接的全局 map
  19. )
  20. type Device struct {
  21. Info deviceDao.Screens
  22. Conn net.Conn
  23. LastTime time.Time
  24. }
  25. // 实例所有设备
  26. func InitDevices() {
  27. // 将数据库中的设备全部离线
  28. devs, _ := deviceDao.QueryAllScreens()
  29. for _, screen := range devs {
  30. if screen.Status != 0 {
  31. screen.Status = 0
  32. now := time.Now()
  33. screen.LastOfflineTime = &now
  34. }
  35. Devices[screen.Sn] = &Device{Info: screen}
  36. }
  37. }
  38. func (s *Device) Start(conn net.Conn) {
  39. s.Conn = conn
  40. go s.Process()
  41. }
  42. func (s *Device) Process() {
  43. // 函数执行完之后关闭连接
  44. defer s.Conn.Close()
  45. for {
  46. buf := make([]byte, 256)
  47. // 将tcp连接读取到的数据读取到byte数组中, 返回读取到的byte的数目
  48. n, err := s.Conn.Read(buf)
  49. if err != nil {
  50. // 从客户端读取数据的过程中发生错误 这里如果没读到可以视为设备离线了
  51. logger.Logger.Errorf("read from client failed [离线了], err:%v", err)
  52. break
  53. }
  54. data := hex.EncodeToString(buf[:n])
  55. if !strings.Contains(strings.ToLower(data), "fe5c4b89") {
  56. continue
  57. }
  58. switch data[16:18] {
  59. case "61":
  60. // fe5c4b89 2a000000 62 00000000 17000000 31 23 32303233(年) 3035(月) 3135(日) 3031(星期) 3038(时) 3334(分) 3135(秒) 23 303630(心跳包时间) 23 ffff
  61. //目前登录只做查找设备的操作 (假登录)
  62. buffer := protocol.AuthDataPack{}.AuthLogin()
  63. // 通过sn 查设备是否存在 不存在return 存在就保存con 和 info
  64. _, err := deviceDao.QueryScreenBySn(data[34:50])
  65. if errors.Is(err, gorm.ErrRecordNotFound) {
  66. logger.Logger.Errorf("Process[case '61'] SN not found \n")
  67. break
  68. }
  69. s.Conn.Write(buffer.Bytes())
  70. case "91":
  71. dev := Devices[data[34:50]]
  72. if dev.Info.Status == 0 {
  73. state := 1
  74. //上线 则修改数据库上线时间
  75. err := Dev.UpdateScreensStatusAndOnline(dev.Info.Sn, state)
  76. if err != nil {
  77. logger.Logger.Error("Process[case '91'] UpdateScreensStatusAndOnline err", zap.Error(err))
  78. continue
  79. }
  80. dev.Info.Status = 1
  81. now := time.Now()
  82. dev.Info.LastOnlineTime = &now
  83. logger.Logger.Debugf("设备 [%v] 上线", dev.Info.ScreensName) // 登录
  84. }
  85. dev.Conn = s.Conn
  86. dev.LastTime = time.Now()
  87. logger.Logger.Debugf("设备 [%v] 心跳", dev.Info.ScreensName)
  88. default:
  89. fmt.Println("读取:", data)
  90. }
  91. }
  92. }
  93. func IsOnline() {
  94. t := time.NewTicker(1 * time.Minute) //每分钟
  95. for {
  96. select {
  97. case <-t.C:
  98. for _, device := range Devices {
  99. //符合条件
  100. if (time.Now().Add(-5*time.Minute).After(device.LastTime) || device.LastTime.IsZero()) && device.Info.Status != 0 {
  101. //修改数据库和内存
  102. //离线
  103. state := 0
  104. err := Dev.UpdateScreensStatusAndOffline(device.Info.Sn, state)
  105. if err != nil {
  106. logger.Logger.Error("[Handle] UpdateScreensStatus err", zap.Error(err))
  107. continue
  108. }
  109. device.Info.Status = 0
  110. now := time.Now()
  111. device.Info.LastOfflineTime = &now
  112. logger.Logger.Debugf("设备 [%v] 离线了...", device.Info.ScreensName)
  113. }
  114. }
  115. }
  116. }
  117. }
  118. func (s *Device) SwitchScreen(onOff int) error {
  119. if s.Conn == nil {
  120. return errors.New("connection is nil")
  121. }
  122. pack := protocol.SwitchDataPack{Type: 0x52} //熄屏
  123. if onOff == 1 {
  124. pack = protocol.SwitchDataPack{Type: 0x51} //亮屏
  125. }
  126. buf := pack.SwitchScreens() //获取开关屏指令
  127. _, err := s.Conn.Write(buf.Bytes())
  128. if err != nil {
  129. logger.Logger.Errorf("SwitchScreen write failed, err:%v", err)
  130. return err
  131. }
  132. return nil
  133. }
  134. func (s *Device) SendInternalCode(content []promodel.InternalCodeContent) error {
  135. if s.Conn == nil {
  136. return errors.New("connection is nil")
  137. }
  138. pack := protocol.InternalCodeDataPack{}
  139. //获取要写入连接的字节数组
  140. buf := pack.SendInternalCode(content)
  141. _, err := s.Conn.Write(buf.Bytes())
  142. if err != nil {
  143. logger.Logger.Errorf("SendInternalCode write failed, err:%v", err)
  144. return err
  145. }
  146. return nil
  147. }
  148. func (s *Device) VoiceBroad(broad string) error {
  149. if s.Conn == nil {
  150. return errors.New("connection is nil")
  151. }
  152. pack := protocol.VoiceBroadDataPack{}
  153. buf := pack.VoiceBroad(broad)
  154. _, err := s.Conn.Write(buf.Bytes())
  155. if err != nil {
  156. logger.Logger.Errorf("VoiceBroad write failed, err:%v", err)
  157. return err
  158. }
  159. return nil
  160. }
  161. func (s *Device) SetBrightness(bright byte) error {
  162. if s.Conn == nil {
  163. return errors.New("connection is nil")
  164. }
  165. pack := protocol.SetBrightnessDataPack{}
  166. buf := pack.SetBrightness(bright)
  167. _, err := s.Conn.Write(buf.Bytes())
  168. if err != nil {
  169. logger.Logger.Errorf("SetBrightness write failed, err:%v", err)
  170. return err
  171. }
  172. return nil
  173. }
  174. func SwitchScreen(sn string, onOff int) error {
  175. device := Devices[sn]
  176. err := device.SwitchScreen(onOff)
  177. if err != nil {
  178. return err
  179. }
  180. return nil
  181. }
  182. func SendInternalCode(sn string, content []promodel.InternalCodeContent) error {
  183. device := Devices[sn]
  184. err := device.SendInternalCode(content)
  185. if err != nil {
  186. return err
  187. }
  188. return nil
  189. }
  190. func VoiceBroad(sn string, broad string) error {
  191. device := Devices[sn]
  192. err := device.VoiceBroad(broad)
  193. if err != nil {
  194. return err
  195. }
  196. return nil
  197. }
  198. func SetBrightness(sn string, bright int) error {
  199. device := Devices[sn]
  200. err := device.SetBrightness(brightnessMap[bright])
  201. if err != nil {
  202. return err
  203. }
  204. return nil
  205. }
  206. var brightnessMap = map[int]byte{
  207. 0: 0x19,
  208. 10: 0x18,
  209. 20: 0x16,
  210. 30: 0x14,
  211. 40: 0x12,
  212. 50: 0x10,
  213. 60: 0x08,
  214. 70: 0x06,
  215. 80: 0x04,
  216. 90: 0x02,
  217. 100: 0x00,
  218. }