platform_cfg.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package cfg
  2. import (
  3. "cicv-data-closedloop/common/util"
  4. "cicv-data-closedloop/kinglong/common/cutil"
  5. "cicv-data-closedloop/kinglong/common/log"
  6. "encoding/json"
  7. "time"
  8. )
  9. type taskTrigger struct {
  10. TriggerId int `json:"triggerId"`
  11. TriggerName string `json:"triggerName"`
  12. TriggerScriptPath string `json:"triggerScriptPath"`
  13. TriggerType string `json:"triggerType"`
  14. }
  15. type platformConfig struct {
  16. TaskConfigId string `json:"taskConfigId"` // 配置ID
  17. TaskConfigName string `json:"taskConfigName"` // 配置名称
  18. DropUploadData bool `json:"dropUploadData"` // 更新任务时 true 先上传旧任务 false 删除旧任务
  19. TaskMaxTime int `json:"taskMaxTime"`
  20. TaskBeforeTime int `json:"taskBeforeTime"`
  21. TaskAfterTime int `json:"taskAfterTime"`
  22. TaskCachePolicy string `json:"taskCachePolicy"`
  23. Lru []string `json:"LRU"`
  24. TaskTriggers []taskTrigger `json:"taskTriggers"`
  25. }
  26. type response struct {
  27. Data platformConfig `json:"data"`
  28. Success bool `json:"success"`
  29. Message string `json:"message"`
  30. Code int `json:"code"`
  31. NowTime string `json:"nowTime"`
  32. }
  33. var PlatformConfig platformConfig
  34. // InitPlatformConfig 初始化数据闭环平台的配置
  35. func InitPlatformConfig() {
  36. log.GlobalLogger.Info("获取数据闭环平台配置 - 开始")
  37. // 1 如果车辆没有配置任务,则阻塞在这里,不启动任务
  38. for {
  39. time.Sleep(time.Duration(1))
  40. log.GlobalLogger.Info("获取数据闭环平台配置 - 进行中")
  41. status, err := GetStatus("")
  42. if err != nil {
  43. log.GlobalLogger.Error("获取配置status失败:", err)
  44. continue
  45. }
  46. // 判断是否有配置,第一次访问状态应该为:CHANGE(一共三种状态 CHANGE|UNCHANGE|NONE)
  47. if status == "CHANGE" {
  48. PlatformConfig, err = getConfig()
  49. if err != nil {
  50. log.GlobalLogger.Error("获取配置status失败:", err)
  51. continue
  52. } else {
  53. break
  54. }
  55. } else {
  56. log.GlobalLogger.Error("车辆没有配置采集任务,等待平台配置。status=", status)
  57. }
  58. }
  59. log.GlobalLogger.Info("获取数据闭环平台配置 - 成功。")
  60. }
  61. /*
  62. {
  63. "data": {
  64. "accessToken": "YWRmYWRzZmFzZGZhZHNmYWRmYWRm=",
  65. "expireTime": "28800",
  66. "equipmentNo": "robot-001"
  67. },
  68. "success": true,
  69. "message": "ok",
  70. "code": 1,
  71. "nowTime": "2023-12-09 22:41:00"
  72. }
  73. */
  74. // GetAccessToken 认证接口,获取access_token
  75. func GetAccessToken() (string, error) {
  76. respJson, err := cutil.HttpPostJsonResponseString(
  77. CloudConfig.Platform.UrlDeviceAuth,
  78. map[string]string{
  79. "equipmentNo": LocalConfig.EquipmentNo,
  80. "secretKey": LocalConfig.SecretKey,
  81. },
  82. )
  83. if err != nil {
  84. return "", nil
  85. }
  86. respMap, err := util.JsonStringToMap(respJson)
  87. if err != nil {
  88. log.GlobalLogger.Error("解析返回结果", respJson, "失败:", err)
  89. return "", nil
  90. }
  91. dataMap := respMap["data"].(map[string]interface{})
  92. if err != nil {
  93. log.GlobalLogger.Error("解析返回结果.data", dataMap, "失败:", err)
  94. return "", nil
  95. }
  96. return dataMap["accessToken"].(string), nil
  97. }
  98. /*
  99. {
  100. "data": {
  101. "status": "UNCHANGE"
  102. "taskConfigld": "xxx"
  103. },
  104. "success": true,
  105. "message": "ok",
  106. "code": 1,
  107. "nowTime": "2023-12-09 21:08:49"
  108. }
  109. */
  110. //GetStatus 根据taskConfigId获取任务status,如果传入空代表车端没有配置,直接获取新的配置
  111. func GetStatus(taskConfigId string) (string, error) {
  112. token, err := GetAccessToken()
  113. if err != nil {
  114. return "", err
  115. }
  116. resp, err := cutil.HttpGetStringAddHeadersResponseString(
  117. CloudConfig.Platform.UrlTaskPoll,
  118. map[string]string{
  119. "authorization": token,
  120. },
  121. map[string]string{
  122. "equipmentNo": LocalConfig.EquipmentNo,
  123. "taskConfigId": taskConfigId,
  124. },
  125. )
  126. if err != nil {
  127. log.GlobalLogger.Error("访问接口", CloudConfig.Platform.UrlTask, "失败:", err)
  128. return "", err
  129. }
  130. respMap, err := util.JsonStringToMap(resp)
  131. if err != nil {
  132. log.GlobalLogger.Error("解析【返回结果1】", resp, "失败:", err)
  133. return "", err
  134. }
  135. dataMap, ok := respMap["data"].(map[string]interface{})
  136. if !ok {
  137. log.GlobalLogger.Errorf("解析【返回结果.data】的类型不是(map[string]interface{}),【dataMap】=%v", dataMap)
  138. return "", err
  139. }
  140. return dataMap["status"].(string), nil
  141. }
  142. func getConfig() (platformConfig, error) {
  143. token, err := GetAccessToken()
  144. if err != nil {
  145. return platformConfig{}, err
  146. }
  147. // 下载插件和获取配置
  148. // 2 访问配置获取接口
  149. resp, err := cutil.HttpGetStringAddHeadersResponseString(
  150. CloudConfig.Platform.UrlTask,
  151. map[string]string{
  152. "authorization": token,
  153. },
  154. map[string]string{
  155. "equipmentNo": LocalConfig.EquipmentNo,
  156. },
  157. )
  158. if err != nil {
  159. log.GlobalLogger.Error("访问接口", CloudConfig.Platform.UrlTask, "失败:", err)
  160. return platformConfig{}, err
  161. }
  162. var result response
  163. err = json.Unmarshal([]byte(resp), &result)
  164. if err != nil {
  165. log.GlobalLogger.Error("解析【返回结果】", resp, "失败:", err)
  166. return platformConfig{}, err
  167. }
  168. return result.Data, nil
  169. }