AccordingToOwnersManualBack.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Components\Database;
  4. use App\OracleDOCOrderHeader;
  5. use App\Owner;
  6. use App\Services\OrderService;
  7. use App\ValueStore;
  8. use Carbon\Carbon;
  9. use Illuminate\Console\Command;
  10. use Illuminate\Database\Eloquent\HigherOrderBuilderProxy;
  11. class AccordingToOwnersManualBack extends Command
  12. {
  13. use Database;
  14. /**
  15. * The name and signature of the console command.
  16. *
  17. * @var string
  18. */
  19. protected $signature = 'AccordingToOwnersManualBack';
  20. /**
  21. * The console command description.
  22. *
  23. * @var string
  24. */
  25. protected $description = '根据货主自动回传奇门标记';
  26. /**
  27. * Create a new command instance.
  28. *
  29. * @return void
  30. */
  31. public function __construct()
  32. {
  33. parent::__construct();
  34. }
  35. /**
  36. * Execute the console command.
  37. */
  38. public function handle()
  39. {
  40. ini_set('max_execution_time', 2500);
  41. ini_set('memory_limit', '512M');
  42. $owners=Owner::query()->where('is_manual_back',1)->orderBy('interval_time')->get();
  43. $sys_last_manual_back_time=$this->getOrderManualBackAt();//系统上次回传时间
  44. $now=Carbon::now()->toDateTimeString();//当前时间
  45. $manualBackTime=null;
  46. $ownerCodes=[];
  47. foreach ($owners as $owner){
  48. $intervalTime=Carbon::parse($now)->diffInMinutes(Carbon::parse($owner->last_manual_back_time));
  49. if ($intervalTime>16*60 || !$owner->last_manual_back_time){ // 隔天回传情况 或者 货主上次回传时间为null
  50. $manualBackTime=$sys_last_manual_back_time;
  51. $ownerCodes=array_unique(data_get($owners,'*.code'));
  52. break;
  53. }
  54. if ($owner->interval_time==30 && $intervalTime>=25 &&$intervalTime<=35){ //存在每30分钟一回传的货主
  55. $manualBackTime=$owner->last_manual_back_time;
  56. $ownerCodes[]=$owner->code;
  57. }else if ($owner->interval_time==60 && $intervalTime>=55 &&$intervalTime<=65){ //存在每1小时一回传的货主
  58. $manualBackTime=$owner->last_manual_back_time;
  59. $ownerCodes[]=$owner->code;
  60. }else if ($owner->interval_time==120 && $intervalTime>=115 &&$intervalTime<=125){ //存在每2小时一回传的货主
  61. $manualBackTime=$owner->last_manual_back_time;
  62. $ownerCodes[]=$owner->code;
  63. }else if ($owner->interval_time==180 && $intervalTime>=175 &&$intervalTime<=185){ //存在每3小时一回传的货主
  64. $manualBackTime=$owner->last_manual_back_time;
  65. $ownerCodes[]=$owner->code;
  66. }
  67. }
  68. try {
  69. $ordernos=$this->allocation($manualBackTime, $now, $ownerCodes);//分配是创建状态订单
  70. $this->manualBack($manualBackTime,$now, $ownerCodes,$ordernos);//回传
  71. } catch (\Exception $e) {
  72. app('LogService')->log(__METHOD__, __FUNCTION__, "自动回传失败" . $manualBackTime . ' || '
  73. .$now. ' || ' . json_encode($ownerCodes).' || ' . json_encode($e->getMessage()));
  74. }
  75. $this->changeOwnerLastManualTime($ownerCodes,$now);//更新回传货主的回传时间
  76. $this->setOrderManualBackAt();//回传结束时间标记
  77. }
  78. /**
  79. * @param $last_order_manual_back_at
  80. * @param $now
  81. * @param $ownerCodes
  82. * @return array|void
  83. * 分配 状态:创建订单、部分预配、预配完成 的订单
  84. */
  85. private function allocation($last_order_manual_back_at,$now,$ownerCodes)
  86. {
  87. $orders=OracleDOCOrderHeader::query()
  88. ->whereIn('sostatus',['00','10','20'])//状态:创建订单、部分预配、预配完成
  89. ->where('edittime','>=',$last_order_manual_back_at)
  90. ->where('edittime','<=',$now)
  91. ->whereNotNull('soreference5') //快递单号不为空
  92. ->whereIn('customerid',$ownerCodes) //指定货主
  93. ->where('releasestatus','!=','H')//订单非冻结状态
  94. ->get();
  95. if($orders->count()==0)return;
  96. /** @var OrderService $orderService */
  97. $orderService=app("OrderService");
  98. $conn = null;
  99. $allocationOrderNos=[];
  100. foreach ($orders as $order){
  101. if (!$order->soreference5) continue;
  102. if (!$conn)$conn = $this->getFluxConnection();
  103. $res=$orderService->allocation($order->orderno,null,$order->warehouseid,$conn);
  104. if (mb_substr($res,0,3)=='000') array_push($allocationOrderNos,$order->orderno);
  105. }
  106. if ($conn)$this->releaseFluxConnection($conn);
  107. return $allocationOrderNos;
  108. }
  109. /**
  110. * @param $last_order_manual_back_at
  111. * @param $now
  112. * @param $ownerCodes
  113. * 回传修改标记状态
  114. */
  115. private function manualBack($last_order_manual_back_at,$now, $ownerCodes,$ordernos)
  116. {
  117. OracleDOCOrderHeader::query()
  118. ->whereIn('sostatus',['40','50','60','61'])
  119. ->where('edittime','>=',$last_order_manual_back_at)
  120. ->where('edittime','<=',$now)
  121. ->whereNotNull('soreference5')
  122. ->where('manualflag','N')
  123. ->whereIn('customerid',$ownerCodes) //指定货主
  124. ->where('releasestatus','!=','H')
  125. ->update(['manualflag'=>'Y','edittime'=>$now]);
  126. if (count($ordernos)==0)return;
  127. OracleDOCOrderHeader::query()
  128. ->whereIn('orderno',$ordernos)
  129. ->whereIn('sostatus',['40','50','60','61'])
  130. ->whereNotNull('soreference5')
  131. ->where('manualflag','N')
  132. ->where('releasestatus','!=','H')
  133. ->update(['manualflag'=>'Y','edittime'=>$now]);
  134. }
  135. /**
  136. * @return HigherOrderBuilderProxy|mixed|null
  137. * 获取订单上次自动回传时间
  138. */
  139. private function getOrderManualBackAt()
  140. {
  141. $val = ValueStore::query()
  142. ->select("value")
  143. ->where("name", "last_order_manual_back_at")
  144. ->lockForUpdate()
  145. ->first();
  146. if (!$val) $val = ValueStore::query()
  147. ->create(["name" => "last_order_manual_back_at",'value'=>Carbon::now()->toDateTimeString()]);
  148. return $val->value ?? null;
  149. }
  150. /**
  151. * 设置订单上次自动回传时间
  152. */
  153. private function setOrderManualBackAt()
  154. {
  155. ValueStore::query()
  156. ->select("value")
  157. ->where("name", "last_order_manual_back_at")
  158. ->update(["value" => Carbon::now()->toDateTimeString()]);
  159. }
  160. private function changeOwnerLastManualTime($ownerCodes,$now)
  161. {
  162. Owner::query()->whereIn('code',$ownerCodes)
  163. ->update(['last_manual_back_time'=>$now]);
  164. }
  165. }