trigger_init.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. package config
  2. import (
  3. "cicv-data-closedloop/aarch64/pjisuv/common/config"
  4. "cicv-data-closedloop/common/config/c_log"
  5. "cicv-data-closedloop/common/util"
  6. "cicv-data-closedloop/pjisuv_msgs"
  7. entity "cicv-data-closedloop/pjisuv_param"
  8. "github.com/bluenviron/goroslib/v2/pkg/msgs/geometry_msgs"
  9. "github.com/bluenviron/goroslib/v2/pkg/msgs/nav_msgs"
  10. "github.com/bluenviron/goroslib/v2/pkg/msgs/sensor_msgs"
  11. "github.com/bluenviron/goroslib/v2/pkg/msgs/tf2_msgs"
  12. "github.com/bluenviron/goroslib/v2/pkg/msgs/visualization_msgs"
  13. "plugin"
  14. )
  15. func InitTriggerConfig() {
  16. var triggerLocalPaths []string
  17. c_log.GlobalLogger.Info("主节点加载触发器插件 - 开始。")
  18. // 1 获取数采任务的触发器列表
  19. cloudTriggers := &config.PlatformConfig.TaskTriggers
  20. // 2 获取本地触发器列表(触发器目录的一级子目录为【触发器ID_触发器Label】)
  21. localTriggerIds := util.GetFirstLevelSubdirectories(config.CloudConfig.TriggersDir)
  22. // 3 对比触发器列表,本地没有的则下载
  23. for _, trigger := range *cloudTriggers {
  24. label := util.GetFileNameWithoutExtension(config.CloudConfig.TriggersDir + trigger.TriggerScriptPath)
  25. id := util.ToString(trigger.TriggerId)
  26. triggerLocalPath := config.CloudConfig.TriggersDir + label + "_" + id + "/" + label + ".so"
  27. triggerLocalPaths = append(triggerLocalPaths, triggerLocalPath)
  28. _ = util.CreateParentDir(triggerLocalPath)
  29. contains, _ := util.ContainsElement(localTriggerIds, id)
  30. if contains { // 已存在的触发器不需要再次下载
  31. continue
  32. }
  33. config.OssMutex.Lock()
  34. err := config.OssBucket.GetObjectToFile(trigger.TriggerScriptPath, triggerLocalPath)
  35. config.OssMutex.Unlock()
  36. if err != nil {
  37. c_log.GlobalLogger.Error("下载 oss 上的触发器插件失败:", err)
  38. continue
  39. }
  40. c_log.GlobalLogger.Info("下载触发器插件从 ", trigger.TriggerScriptPath, " 到 ", triggerLocalPath)
  41. }
  42. // 下载所有触发器的文件
  43. for _, triggerLocalPath := range triggerLocalPaths {
  44. // 载入插件到数组
  45. open, err := plugin.Open(triggerLocalPath)
  46. if err != nil {
  47. c_log.GlobalLogger.Error("加载本地插件", triggerLocalPath, "失败。", err)
  48. continue
  49. }
  50. topic0, err := open.Lookup("Topic")
  51. if err != nil {
  52. c_log.GlobalLogger.Error("加载本地插件", triggerLocalPath, "中的Topic方法失败。", err)
  53. continue
  54. }
  55. topic1, ok := topic0.(func() string)
  56. if ok != true {
  57. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func() string):", err)
  58. continue
  59. }
  60. topic2 := topic1()
  61. rule, err := open.Lookup("Rule")
  62. if err != nil {
  63. c_log.GlobalLogger.Error("加载本地插件", triggerLocalPath, "中的Rule方法失败。", err)
  64. continue
  65. }
  66. if TopicOfCicvExtend == topic2 { // 自定义扩展
  67. f, ok := rule.(func(param entity.PjisuvParam) string)
  68. if ok != true {
  69. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(param entity.ExtendParam):", err)
  70. continue
  71. }
  72. RuleOfCicvExtend = append(RuleOfCicvExtend, f)
  73. } else if TopicOfAmrPose == topic2 { //1
  74. f, ok := rule.(func(data *visualization_msgs.MarkerArray) string)
  75. if ok != true {
  76. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *visualization_msgs.MarkerArray) string):", err)
  77. continue
  78. }
  79. RuleOfAmrPose = append(RuleOfAmrPose, f)
  80. } else if TopicOfBoundingBoxesFast == topic2 { //2
  81. f, ok := rule.(func(data *pjisuv_msgs.BoundingBoxArray) string)
  82. if ok != true {
  83. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.BoundingBoxArray) string):", err)
  84. continue
  85. }
  86. RuleOfBoundingBoxesFast = append(RuleOfBoundingBoxesFast, f)
  87. } else if TopicOfCameraFault == topic2 { //3
  88. f, ok := rule.(func(data *pjisuv_msgs.FaultVec) string)
  89. if ok != true {
  90. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.FaultVec) string):", err)
  91. continue
  92. }
  93. RuleOfCameraFault = append(RuleOfCameraFault, f)
  94. } else if TopicOfCanData == topic2 { //4
  95. f, ok := rule.(func(data *pjisuv_msgs.Frame) string)
  96. if ok != true {
  97. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.Frame) string):", err)
  98. continue
  99. }
  100. RuleOfCanData = append(RuleOfCanData, f)
  101. } else if TopicOfCh128x1LslidarPointCloud == topic2 { //5
  102. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  103. if ok != true {
  104. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  105. continue
  106. }
  107. RuleOfCh128x1LslidarPointCloud = append(RuleOfCh128x1LslidarPointCloud, f)
  108. } else if TopicOfCh64wLLslidarPointCloud == topic2 { //6
  109. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  110. if ok != true {
  111. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  112. continue
  113. }
  114. RuleOfCh64wLLslidarPointCloud = append(RuleOfCh64wLLslidarPointCloud, f)
  115. } else if TopicOfCh64wLScan == topic2 { //7
  116. f, ok := rule.(func(data *sensor_msgs.LaserScan) string)
  117. if ok != true {
  118. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.LaserScan) string):", err)
  119. continue
  120. }
  121. RuleOfCh64wLScan = append(RuleOfCh64wLScan, f)
  122. } else if TopicOfCh64wRLslidarPointCloud == topic2 { //8
  123. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  124. if ok != true {
  125. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  126. continue
  127. }
  128. RuleOfCh64wRLslidarPointCloud = append(RuleOfCh64wRLslidarPointCloud, f)
  129. } else if TopicOfCh64wRScan == topic2 { //9
  130. f, ok := rule.(func(data *sensor_msgs.LaserScan) string)
  131. if ok != true {
  132. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.LaserScan) string):", err)
  133. continue
  134. }
  135. RuleOfCh64wRScan = append(RuleOfCh64wRScan, f)
  136. } else if TopicOfCicvLidarclusterMovingObjects == topic2 { //10
  137. f, ok := rule.(func(data *pjisuv_msgs.PerceptionCicvMovingObjects) string)
  138. if ok != true {
  139. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.PerceptionCicvMovingObjects) string):", err)
  140. continue
  141. }
  142. RuleOfCicvLidarclusterMovingObjects = append(RuleOfCicvLidarclusterMovingObjects, f)
  143. } else if TopicOfCicvAmrTrajectory == topic2 { //11
  144. f, ok := rule.(func(data *pjisuv_msgs.Trajectory, param entity.PjisuvParam) string)
  145. if ok != true {
  146. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.Trajectory,param entity.PjisuvParam) string):", err)
  147. continue
  148. }
  149. RuleOfCicvAmrTrajectory = append(RuleOfCicvAmrTrajectory, f)
  150. } else if TopicOfCicvLocation == topic2 { //12
  151. f, ok := rule.(func(data *pjisuv_msgs.PerceptionLocalization) string)
  152. if ok != true {
  153. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.PerceptionLocalization) string):", err)
  154. continue
  155. }
  156. RuleOfCicvLocation = append(RuleOfCicvLocation, f)
  157. } else if TopicOfCloudClusters == topic2 { //13
  158. f, ok := rule.(func(data *pjisuv_msgs.AutowareCloudClusterArray) string)
  159. if ok != true {
  160. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.AutowareCloudClusterArray) string):", err)
  161. continue
  162. }
  163. RuleOfCloudClusters = append(RuleOfCloudClusters, f)
  164. } else if TopicOfHeartbeatInfo == topic2 { //14
  165. f, ok := rule.(func(data *pjisuv_msgs.HeartBeatInfo) string)
  166. if ok != true {
  167. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.HeartBeatInfo) string):", err)
  168. continue
  169. }
  170. RuleOfHeartbeatInfo = append(RuleOfHeartbeatInfo, f)
  171. } else if TopicOfLidarPretreatmentCost == topic2 { //15
  172. f, ok := rule.(func(data *geometry_msgs.Vector3Stamped) string)
  173. if ok != true {
  174. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *geometry_msgs.Vector3Stamped) string):", err)
  175. continue
  176. }
  177. RuleOfLidarPretreatmentCost = append(RuleOfLidarPretreatmentCost, f)
  178. } else if TopicOfLidarPretreatmentOdometry == topic2 { //16
  179. f, ok := rule.(func(data *nav_msgs.Odometry) string)
  180. if ok != true {
  181. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Odometry) string):", err)
  182. continue
  183. }
  184. RuleOfLidarPretreatmentOdometry = append(RuleOfLidarPretreatmentOdometry, f)
  185. } else if TopicOfLidarRoi == topic2 { //17
  186. f, ok := rule.(func(data *geometry_msgs.PolygonStamped) string)
  187. if ok != true {
  188. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *geometry_msgs.PolygonStamped) string):", err)
  189. continue
  190. }
  191. RuleOfLidarRoi = append(RuleOfLidarRoi, f)
  192. } else if TopicOfLine1 == topic2 { //18
  193. f, ok := rule.(func(data *nav_msgs.Path) string)
  194. if ok != true {
  195. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Path) string):", err)
  196. continue
  197. }
  198. RuleOfLine1 = append(RuleOfLine1, f)
  199. } else if TopicOfLine2 == topic2 { //19
  200. f, ok := rule.(func(data *nav_msgs.Path) string)
  201. if ok != true {
  202. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Path) string):", err)
  203. continue
  204. }
  205. RuleOfLine2 = append(RuleOfLine2, f)
  206. } else if TopicOfMapPolygon == topic2 { //20
  207. f, ok := rule.(func(data *pjisuv_msgs.PolygonStamped) string)
  208. if ok != true {
  209. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.PolygonStamped) string):", err)
  210. continue
  211. }
  212. RuleOfMapPolygon = append(RuleOfMapPolygon, f)
  213. } else if TopicOfObstacleDisplay == topic2 { //21
  214. f, ok := rule.(func(data *visualization_msgs.MarkerArray) string)
  215. if ok != true {
  216. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *visualization_msgs.MarkerArray) string):", err)
  217. continue
  218. }
  219. RuleOfObstacleDisplay = append(RuleOfObstacleDisplay, f)
  220. } else if TopicOfPjControlPub == topic2 { //22
  221. f, ok := rule.(func(data *pjisuv_msgs.CommonVehicleCmd) string)
  222. if ok != true {
  223. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.CommonVehicleCmd) string):", err)
  224. continue
  225. }
  226. RuleOfPjControlPub = append(RuleOfPjControlPub, f)
  227. } else if TopicOfPointsCluster == topic2 { //23
  228. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  229. if ok != true {
  230. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  231. continue
  232. }
  233. RuleOfPointsCluster = append(RuleOfPointsCluster, f)
  234. } else if TopicOfPointsConcat == topic2 { //24
  235. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  236. if ok != true {
  237. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  238. continue
  239. }
  240. RuleOfPointsConcat = append(RuleOfPointsConcat, f)
  241. } else if TopicOfReferenceDisplay == topic2 { //25
  242. f, ok := rule.(func(data *nav_msgs.Path) string)
  243. if ok != true {
  244. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Path) string):", err)
  245. continue
  246. }
  247. RuleOfReferenceDisplay = append(RuleOfReferenceDisplay, f)
  248. } else if TopicOfReferenceTrajectory == topic2 { //26
  249. f, ok := rule.(func(data *pjisuv_msgs.Trajectory) string)
  250. if ok != true {
  251. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.Trajectory) string):", err)
  252. continue
  253. }
  254. RuleOfReferenceTrajectory = append(RuleOfReferenceTrajectory, f)
  255. } else if TopicOfRoiPoints == topic2 { //27
  256. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  257. if ok != true {
  258. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  259. continue
  260. }
  261. RuleOfRoiPoints = append(RuleOfRoiPoints, f)
  262. } else if TopicOfRoiPolygon == topic2 { //28
  263. f, ok := rule.(func(data *nav_msgs.Path) string)
  264. if ok != true {
  265. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Path) string):", err)
  266. continue
  267. }
  268. RuleOfRoiPolygon = append(RuleOfRoiPolygon, f)
  269. } else if TopicOfTf == topic2 { //29
  270. f, ok := rule.(func(data *tf2_msgs.TFMessage) string)
  271. if ok != true {
  272. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *tf2_msgs.TFMessage) string):", err)
  273. continue
  274. }
  275. RuleOfTf = append(RuleOfTf, f)
  276. } else if TopicOfTpperception == topic2 { //30
  277. f, ok := rule.(func(data *pjisuv_msgs.PerceptionObjects, param entity.PjisuvParam) string)
  278. if ok != true {
  279. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.PerceptionObjects, param entity.ExtendParam) string):", err)
  280. continue
  281. }
  282. RuleOfTpperception = append(RuleOfTpperception, f)
  283. } else if TopicOfTpperceptionVis == topic2 { //31
  284. f, ok := rule.(func(data *visualization_msgs.MarkerArray) string)
  285. if ok != true {
  286. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *visualization_msgs.MarkerArray) string):", err)
  287. continue
  288. }
  289. RuleOfTpperceptionVis = append(RuleOfTpperceptionVis, f)
  290. } else if TopicOfTprouteplan == topic2 { //32
  291. f, ok := rule.(func(data *pjisuv_msgs.RoutePlan) string)
  292. if ok != true {
  293. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.RoutePlan) string):", err)
  294. continue
  295. }
  296. RuleOfTprouteplan = append(RuleOfTprouteplan, f)
  297. } else if TopicOfTrajectoryDisplay == topic2 { //33
  298. f, ok := rule.(func(data *nav_msgs.Path) string)
  299. if ok != true {
  300. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *nav_msgs.Path) string):", err)
  301. continue
  302. }
  303. RuleOfTrajectoryDisplay = append(RuleOfTrajectoryDisplay, f)
  304. } else if TopicOfUngroundCloudpoints == topic2 { //34
  305. f, ok := rule.(func(data *sensor_msgs.PointCloud2) string)
  306. if ok != true {
  307. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.PointCloud2) string):", err)
  308. continue
  309. }
  310. RuleOfUngroundCloudpoints = append(RuleOfUngroundCloudpoints, f)
  311. } else if TopicOfCameraImage == topic2 { //35
  312. f, ok := rule.(func(data *sensor_msgs.Image) string)
  313. if ok != true {
  314. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *sensor_msgs.Image) string):", err)
  315. continue
  316. }
  317. RuleOfCameraImage = append(RuleOfCameraImage, f)
  318. } else if TopicOfDataRead == topic2 { //36
  319. f, ok := rule.(func(data *pjisuv_msgs.Retrieval) string)
  320. if ok != true {
  321. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.Retrieval) string):", err)
  322. continue
  323. }
  324. RuleOfDataRead = append(RuleOfDataRead, f)
  325. } else if TopicOfPjVehicleFdbPub == topic2 { //39
  326. f, ok := rule.(func(data *pjisuv_msgs.VehicleFdb, param *entity.PjisuvParam) string)
  327. if ok != true {
  328. c_log.GlobalLogger.Error("插件", triggerLocalPath, "中的Topic方法必须是(func(data *pjisuv_msgs.VehicleFdb) string):", err)
  329. continue
  330. }
  331. RuleOfPjVehicleFdbPub = append(RuleOfPjVehicleFdbPub, f)
  332. } else {
  333. c_log.GlobalLogger.Error("未知的topic:", topic2)
  334. continue
  335. }
  336. _, err = open.Lookup("Label")
  337. if err != nil {
  338. c_log.GlobalLogger.Error("加载本地插件 ", triggerLocalPath, " 中的 Label 方法失败。", err)
  339. continue
  340. }
  341. }
  342. c_log.GlobalLogger.Info("一共有", len(config.PlatformConfig.TaskTriggers), "个触发器。")
  343. }