platform_cfg.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. package cfg
  2. import (
  3. "cicv-data-closedloop/common/config/c_log"
  4. "cicv-data-closedloop/kinglong/common/log"
  5. "cicv-data-closedloop/pji/common/cutil"
  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. var err error
  37. c_log.GlobalLogger.Info("获取数据闭环平台配置 - 开始")
  38. // 1 如果车辆没有配置任务,则阻塞在这里,不启动任务
  39. for {
  40. time.Sleep(time.Duration(1))
  41. c_log.GlobalLogger.Info("获取数据闭环平台配置 - 进行中")
  42. // 判断是否有配置,第一次访问状态应该为:CHANGE(一共三种状态 CHANGE|UNCHANGE|NONE)
  43. PlatformConfig, err = getConfig()
  44. if err != nil {
  45. c_log.GlobalLogger.Error("获取配置status失败:", err)
  46. continue
  47. }
  48. break
  49. }
  50. c_log.GlobalLogger.Info("获取数据闭环平台配置 - 成功。")
  51. }
  52. /*
  53. {
  54. "data": {
  55. "accessToken": "YWRmYWRzZmFzZGZhZHNmYWRmYWRm=",
  56. "expireTime": "28800",
  57. "equipmentNo": "robot-001"
  58. },
  59. "success": true,
  60. "message": "ok",
  61. "code": 1,
  62. "nowTime": "2023-12-09 22:41:00"
  63. }
  64. */
  65. // GetAccessToken 认证接口,获取access_token
  66. func GetAccessToken() (string, error) {
  67. respJson, err := cutil.HttpPostJsonResponseString(
  68. CloudConfig.Platform.UrlDeviceAuth,
  69. map[string]string{
  70. "equipmentNo": LocalConfig.EquipmentNo,
  71. "secretKey": LocalConfig.SecretKey,
  72. },
  73. )
  74. if err != nil {
  75. return "", nil
  76. }
  77. respMap, err := cutil.JsonStringToMap(respJson)
  78. if err != nil {
  79. c_log.GlobalLogger.Error("解析返回结果", respJson, "失败:", err)
  80. return "", nil
  81. }
  82. dataMap := respMap["data"].(map[string]interface{})
  83. if err != nil {
  84. c_log.GlobalLogger.Error("解析返回结果.data", dataMap, "失败:", err)
  85. return "", nil
  86. }
  87. return dataMap["accessToken"].(string), nil
  88. }
  89. /*
  90. {
  91. "data": {
  92. "status": "UNCHANGE"
  93. "taskConfigld": "xxx"
  94. },
  95. "success": true,
  96. "message": "ok",
  97. "code": 1,
  98. "nowTime": "2023-12-09 21:08:49"
  99. }
  100. */
  101. //GetStatus 根据taskConfigId获取任务status,如果传入空代表车端没有配置,直接获取新的配置
  102. func GetStatus(taskConfigId string) (string, error) {
  103. token, err := GetAccessToken()
  104. if err != nil {
  105. return "", err
  106. }
  107. resp, err := cutil.HttpGetStringAddHeadersResponseString(
  108. CloudConfig.Platform.UrlTaskPoll,
  109. map[string]string{
  110. "authorization": token,
  111. },
  112. map[string]string{
  113. "equipmentNo": LocalConfig.EquipmentNo,
  114. "taskConfigId": taskConfigId,
  115. },
  116. )
  117. if err != nil {
  118. c_log.GlobalLogger.Error("访问接口", CloudConfig.Platform.UrlTask, "失败:", err)
  119. return "", err
  120. }
  121. respMap, err := cutil.JsonStringToMap(resp)
  122. if err != nil {
  123. c_log.GlobalLogger.Error("解析【返回结果1】", resp, "失败:", err)
  124. return "", err
  125. }
  126. dataMap, ok := respMap["data"].(map[string]interface{})
  127. if !ok {
  128. log.GlobalLogger.Errorf("解析【返回结果.data】的类型不是(map[string]interface{}),【dataMap】=%v", dataMap)
  129. return "", err
  130. }
  131. return dataMap["status"].(string), nil
  132. }
  133. func getConfig() (platformConfig, error) {
  134. token, err := GetAccessToken()
  135. if err != nil {
  136. return platformConfig{}, err
  137. }
  138. // 下载插件和获取配置
  139. // 2 访问配置获取接口
  140. resp, err := cutil.HttpGetStringAddHeadersResponseString(
  141. CloudConfig.Platform.UrlTask,
  142. map[string]string{
  143. "authorization": token,
  144. },
  145. map[string]string{
  146. "equipmentNo": LocalConfig.EquipmentNo,
  147. },
  148. )
  149. if err != nil {
  150. c_log.GlobalLogger.Error("访问接口", CloudConfig.Platform.UrlTask, "失败:", err)
  151. return platformConfig{}, err
  152. }
  153. var result response
  154. err = json.Unmarshal([]byte(resp), &result)
  155. if err != nil {
  156. c_log.GlobalLogger.Error("解析【返回结果】", resp, "失败:", err)
  157. return platformConfig{}, err
  158. }
  159. return result.Data, nil
  160. }