UpdateHkList.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. use Modules\Camera\Entities\CameraList;
  5. use Modules\Camera\Enum\CameraEnum;
  6. use Modules\Camera\Services\CameraServices;
  7. use Modules\Mine\Entities\MineList;
  8. use Modules\Mine\Entities\MineListExt;
  9. use Modules\Mine\Services\MineServices;
  10. class UpdateHkList extends Command
  11. {
  12. /**
  13. * The name and signature of the console command.
  14. *
  15. * @var string
  16. */
  17. protected $signature = 'hklist:update';
  18. /**
  19. * The console command description.
  20. *
  21. * @var string
  22. */
  23. protected $description = '同步海康区域及摄像头列表';
  24. /**
  25. * Create a new command instance.
  26. *
  27. * @return void
  28. */
  29. public function __construct()
  30. {
  31. parent::__construct();
  32. }
  33. /**
  34. * Execute the console command.
  35. *
  36. * @return mixed
  37. */
  38. public function handle()
  39. {
  40. $this->updateAreaList();
  41. $this->updateCameraList();
  42. }
  43. //同步区域列表
  44. public function updateAreaList()
  45. {
  46. //查询使用海康服务器的矿区id
  47. $mine_id_list = MineListExt::where('is_hak', 1)->pluck('mine_id')->all();
  48. foreach ($mine_id_list as $key => $val) {
  49. MineServices::getHaiKangArea($val, CameraEnum::REQUEST_TYPE_LOCAL);
  50. }
  51. }
  52. public function updateCameraList()
  53. {
  54. //查询存在index_code列表
  55. $index_code_list = MineList::where('index_code', '!=', null)->get();
  56. foreach ($index_code_list as $key => $val) {
  57. $degree = explode('|', $val->degree);
  58. // $trans_result = CameraServices::getHaiKangTransList($degree[0]);
  59. $result = CameraServices::getHaiKangCamera($degree[0], $val->index_code, CameraEnum::CAMERA_TYPE_ALL);
  60. if ($result['status'])) {
  61. $trans_arr = [];
  62. // foreach ($trans_result['data'] as $tk => $tv) {
  63. // $trans_arr[$tv['indexCode']]['ip'] = $tv['ip'];
  64. // }
  65. $index_code_arr = [];
  66. $arr_count = count($result['data']);
  67. foreach ($result['data'] as $k => $v) {
  68. $ip = '';
  69. $port = '';
  70. $com_number = '';
  71. // if (isset($trans_arr[$v['trans_code']])) {
  72. // $ip = $trans_arr[$v['trans_code']]['ip'];
  73. // $port = CameraEnum::HAK_DEFAULT_PORT;
  74. // $com_number = $v['com_number'];
  75. // }
  76. //当前摄像头index_code数组
  77. $index_code_arr[$k] = $v['camera_id'];
  78. $params = [
  79. 'mine_id' => $val->id,
  80. 'camera_name' => $this->transformCameraName($v['camera_name']),
  81. 'index_code' => $v['camera_id'],
  82. 'revert_id' => CameraEnum::CAMERA_DEFAULT_REVERT_ID,
  83. 'camera_source' => CameraEnum::CAMERA_SOURCE_2,
  84. 'ip' => $ip,
  85. 'port' => $port,
  86. 'com_number' => $com_number,
  87. 'sort' => $arr_count - $k,
  88. ];
  89. CameraList::updateOrCreate(['index_code' => $v['camera_id']], $params);
  90. }
  91. //删除不存在的摄像头
  92. CameraList::where('mine_id', $val->id)->where('index_code', '!=', NULL)->whereNotIn('index_code', $index_code_arr)->delete();
  93. }
  94. }
  95. }
  96. //转义摄像头名称中的特殊字符
  97. public function transformCameraName($camera_name)
  98. {
  99. $camera_name = trim($camera_name);
  100. $camera_name = str_replace('#', '号', $camera_name);
  101. $camera_name = str_replace(' ', '-', $camera_name);
  102. $camera_name = str_replace('+', '', $camera_name);
  103. return $camera_name;
  104. }
  105. }