PackageController.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. <?php
  2. namespace App\Http\Controllers\Api\thirdPart\weight;
  3. use App\Events\WeighedEvent;
  4. use App\Http\Controllers\Controller;
  5. use App\Http\Controllers\LogisticNumberFeatureController;
  6. use App\Jobs\FetchPackageFromOracle;
  7. use App\MeasuringMachine;
  8. use App\Order;
  9. use App\OrderPackage;
  10. use App\Services\OrderService;
  11. use App\Waybill;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Carbon;
  14. use Illuminate\Support\Facades\Validator;
  15. class PackageController extends Controller
  16. {
  17. // public function new_(Request $requestInitial){
  18. // $request=[];
  19. // foreach ($requestInitial->all() as $k=>$v){
  20. // $request[strtolower($k)]=$v;
  21. // }
  22. // $reqDate=isset($request['time'])?$request['time']:Carbon::now();
  23. // $errors=$this->validatorWeight($request)->errors();
  24. //
  25. // if (count($errors)>0){
  26. // $this->log(__METHOD__,'error'.__FUNCTION__,json_encode($request).'||'.json_encode($errors),null);
  27. // $response=["msg"=>$errors,"code"=>500,"data"=>null];
  28. // return json_encode($response);
  29. // }
  30. //
  31. // $measuringMachine=MeasuringMachine::where('code',$request['id'])->first();
  32. // if (!$measuringMachine){
  33. // $measuringMachine=new MeasuringMachine([
  34. // 'name'=>$request['id'],
  35. // 'code'=>$request['id'],
  36. // 'status'=>'在线'
  37. // ]);
  38. // $measuringMachine->save();
  39. // $this->log(__METHOD__,'weightApi(new measuring machine)'.__FUNCTION__,json_encode($request),null);
  40. // }else{
  41. // $measuringMachineStatus=new MeasuringMachine();
  42. // $measuringMachineStatus->changeStatus($measuringMachine);
  43. // }
  44. // MeasuringMachineQueue::dispatch($measuringMachine)->delay(Carbon::now()->addMinutes(30));
  45. //
  46. // $package=Package::where('logistic_number',$request['barcode'])->first();
  47. // if (isset($request['length'])&&isset($request['width'])&&isset($request['height'])){
  48. // $length=$request['length'];
  49. // $width=$request['width'];
  50. // $height=$request['height'];
  51. // $max=($length>=($width>=$height?$width:$height)?$length:($width>=$height?$width:$height));
  52. // if ($max==$length){
  53. // $centre=$width>=$height?$width:$height;
  54. // $min=$width<$height?$width:$height;
  55. // }elseif ($max==$width){
  56. // $centre=$length>=$height?$length:$height;
  57. // $min=$length<$height?$length:$height;
  58. // }else{
  59. // $centre=$width>=$length?$width:$length;
  60. // $min=$width<$length?$width:$length;
  61. // }
  62. // }else{
  63. // $max=0;$centre=0;$min=0;
  64. // }
  65. // $apiController=new \App\Http\Controllers\Api\thirdPart\flux\PackageController();
  66. // if ($package){
  67. // $packageController=new \App\Http\Controllers\PackageController();
  68. // $package->fetchPaperBox($max,$centre,$min,$package->owner_id);
  69. // //处理活动波次
  70. // if ($package->batch_rule&&strstr($package->batch_rule,'组合')){
  71. // $packageController->syncBatch($package->batch_number,$request['weight'],$max,$centre,$min,$reqDate,$package['paper_box_id']);
  72. // }else{
  73. // $package->measuring_machine_id=$measuringMachine->id;
  74. // $package->weight=$request['weight'];
  75. // $package->length=$max;
  76. // $package->width=$centre;
  77. // $package->height=$min;
  78. // $package->bulk=$max*$centre*$min;
  79. // $package->weighed_at=$reqDate;
  80. // $package->status="未上传";
  81. // $this->log(__METHOD__,'Batch_'.__FUNCTION__,json_encode($package),null);
  82. // $package->save();
  83. // $result=$apiController->accomplishToWMS($package);
  84. // if ($result['result']){
  85. // if ($package->status=="记录异常")$package->status="已上传异常";
  86. // else $package->status="已上传";
  87. // }else{
  88. // $package->status="上传异常";
  89. // }
  90. // $package->save();
  91. // }
  92. // if ($package->order_code){
  93. // $waybill=Waybill::where('wms_bill_number',$package->order_code)->where('status','!=','已完结')
  94. // ->where('status','!=','无模型')->first();
  95. // if ($waybill){
  96. // $waybill->warehouse_weight_other=$package->weight;
  97. // $waybill->warehouse_weight_unit_id_other=1;
  98. // $waybill->update();
  99. // }
  100. // }
  101. // event(new WeighedEvent($package));
  102. // $response=["msg"=>"保存成功",
  103. // "code"=>200,
  104. // "data"=>true,
  105. // "serverMsg"=>null,
  106. // "requestor"=>[
  107. // "requestor"=>"1",
  108. // "eventCode"=>"0",
  109. // "reqDate"=>$reqDate,
  110. // "resDate"=>Carbon::now()]
  111. // ];
  112. // $this->log(__METHOD__,'weightApi'.__FUNCTION__,json_encode($request).'|'.json_encode($response),null);
  113. // return json_encode($response,JSON_UNESCAPED_UNICODE);
  114. // }
  115. // if (!$package){
  116. // $logisticNumber=$request['barcode'];
  117. // $createPackage=new Package([
  118. // 'logistic_number'=>$logisticNumber,
  119. // 'delivery_number'=>$logisticNumber,
  120. // 'measuring_machine_id'=>$measuringMachine->id,
  121. // 'weight'=>$request['weight'],
  122. // 'length'=>$max,
  123. // 'width'=>$centre,
  124. // 'height'=>$min,
  125. // 'bulk'=>$max*$centre*$min,
  126. // 'weighed_at'=>$reqDate,
  127. // 'status'=>"未下发",
  128. // ]);
  129. // $createPackage->fetchAllFromOracle();
  130. // $createPackage->fetchPaperBox($max, $centre, $min);
  131. // $result=$apiController->accomplishToWMS($createPackage);
  132. // if(!$result['result']){
  133. // $this->log(__METHOD__,'weightApi'.__FUNCTION__,json_encode($request).'||'.json_encode($createPackage),null);
  134. // $response=["msg"=>"写入WMS失败!","code"=>500,"data"=>null];
  135. // return json_encode($response,JSON_UNESCAPED_UNICODE);
  136. // }
  137. // if ($createPackage->save()){
  138. // $measuringMachine->touch();
  139. // MeasuringMachineQueue::dispatch($measuringMachine)->delay(Carbon::now()->addMinutes(30));
  140. // MarkPackageExcepted::dispatch($createPackage)->delay(Carbon::now()->addMinutes(1440));
  141. // event(new WeighedEvent($createPackage));
  142. // $response=["msg"=>"保存成功",
  143. // "code"=>200,
  144. // "data"=>true,
  145. // "serverMsg"=>null,
  146. // "requestor"=>[
  147. // "requestor"=>"1",
  148. // "eventCode"=>"0",
  149. // "reqDate"=>$reqDate,
  150. // "resDate"=>Carbon::now()]
  151. // ];
  152. // $this->log(__METHOD__,'weightApi'.__FUNCTION__,json_encode($request).'||'.json_encode($response),null);
  153. // return json_encode($response,JSON_UNESCAPED_UNICODE);
  154. // }
  155. //
  156. // $response=["msg"=>"保存时发生错误(未下发)!","code"=>500,"data"=>null];
  157. // $this->log(__METHOD__,'weightApi(ERROR)'.__FUNCTION__,json_encode($request).'||'.json_encode($response),null);
  158. // return json_encode($response,JSON_UNESCAPED_UNICODE);
  159. // }
  160. // }
  161. public function new_(Request $requestInitial){
  162. $request=[];
  163. foreach ($requestInitial->all() as $k=>$v){
  164. $request[strtolower($k)]=$v;
  165. }
  166. $reqDate=isset($request['time'])?$request['time']:Carbon::now();
  167. $errors=$this->validatorWeight($request)->errors();
  168. if (count($errors)>0){
  169. $this->log(__METHOD__,'error'.__FUNCTION__,json_encode($request).'||'.json_encode($errors),null);
  170. return json_encode(["msg"=>$errors,"code"=>500,"data"=>null]);
  171. }
  172. $measuringMachine=MeasuringMachine::query()->firstOrCreate(['code'=>$request['id']]);
  173. $measuringMachine->turnOn();
  174. $measuringMachine->turnOffInMinutes(30);
  175. /** @var OrderPackage $package */
  176. $package=OrderPackage::query()->where('logistic_number',$request['barcode'])->first();
  177. $edges=[$request['length']??0,$request['width']??0,$request['height']??0];
  178. rsort($edges);
  179. $fluxController=new \App\Http\Controllers\Api\thirdPart\flux\PackageController();
  180. if ($package){
  181. $package['measuring_machine_id']=$measuringMachine->id;
  182. $package['weight']=$request['weight'];
  183. $package['length']=$edges[0];
  184. $package['width']=$edges[1];
  185. $package['height']=$edges[2];
  186. $package['weighed_at']=$reqDate;
  187. $package->fetchAllFromOracle();
  188. $package->fetchPaperBox();
  189. $package['bulk']=$edges[0]*$edges[1]*$edges[2];
  190. if ($package->isActivityBatch()){//处理活动波次
  191. $this->log(__METHOD__,__FUNCTION__,"依波次号同步所有包裹:".json_encode($package),null);
  192. $package->unifyThisMeasureUnderSameBatch();
  193. $result=$fluxController->markWMSOnBatch($package['batch_number'], $request['weight']);
  194. if(!$result['result']){
  195. $package->status="上传异常";
  196. }
  197. }else{
  198. $this->log(__METHOD__,__FUNCTION__,"写入包裹至WMS:".json_encode($package),null);
  199. try{
  200. $result=$fluxController->accomplishToWMS($package);
  201. if ($result['result']){
  202. $package->status="已上传";
  203. }else{
  204. $package->status="上传异常";
  205. }
  206. }catch (\Exception $e){
  207. $package->status="未上传";
  208. }
  209. }
  210. try{
  211. $package->save();
  212. $package->load(['order'=>function($query){
  213. $query->with('owner','logistic');
  214. },'paperBox','measuringMachine']);
  215. $logisticNumberController = new LogisticNumberFeatureController();
  216. if (!$package->order){
  217. $package->order = new Order();
  218. }
  219. if (!$package->order->logistic){
  220. $package->order->logistic = $logisticNumberController->getLogisticByFeatures($package->logistic_number);
  221. }
  222. }catch (\Exception $e){
  223. $response=["msg"=>"称重下发修改时发生错误!".json_encode($e),"code"=>500,"data"=>null];
  224. $this->log(__METHOD__,'weightApi(ERROR)'.__FUNCTION__,json_encode($request).'||'.json_encode($response).'||'.json_encode($e),null);
  225. return json_encode($response,JSON_UNESCAPED_UNICODE);
  226. }
  227. }
  228. if (!$package){
  229. $logisticNumber=$request['barcode'];
  230. /** @var $orderService OrderService */
  231. $orderService = app('orderService');
  232. $order = $orderService->logisticNumberFirstOrCreateOrder($logisticNumber);
  233. if (!$order) {
  234. $response=["msg"=>"保存时发生错误(未在WMS找到该单)!","code"=>500,"data"=>null];
  235. return json_encode($response,JSON_UNESCAPED_UNICODE);
  236. }
  237. $package=new OrderPackage([
  238. 'order_id' => $order->id,
  239. 'logistic_number'=>$logisticNumber,
  240. 'measuring_machine_id'=>$measuringMachine->id,
  241. 'weight'=>$request['weight'],
  242. 'length'=>$edges[0],
  243. 'width'=>$edges[1],
  244. 'height'=>$edges[2],
  245. 'bulk'=>$edges[0]*$edges[1]*$edges[2],
  246. 'weighed_at'=>$reqDate,
  247. 'status'=>"无",
  248. ]);
  249. $package->fetchAllFromOracle();
  250. $package->fetchPaperBox();
  251. try{
  252. $package->save();
  253. $package->load(['order'=>function($query){
  254. $query->with('owner','logistic');
  255. },'paperBox','measuringMachine']);
  256. $logisticNumberController = new LogisticNumberFeatureController();
  257. if (!$package->order){
  258. $package->order = new Order();
  259. }
  260. if (!$package->order->logistic){
  261. $package->order->logistic = $logisticNumberController->getLogisticByFeatures($package->logistic_number);
  262. }
  263. }catch (\Exception $e){
  264. $response=["msg"=>$e->getMessage(),"code"=>500,"data"=>$e->getTraceAsString()];
  265. $this->log(__METHOD__,'weightApi(ERROR)'.__FUNCTION__,json_encode($request).'||'.json_encode($response).'||'.$e->getTraceAsString(),null);
  266. return json_encode($response,JSON_UNESCAPED_UNICODE);
  267. }
  268. $result=$fluxController->accomplishToWMS($package);
  269. if(!$package['batch_number'])
  270. FetchPackageFromOracle::dispatch($package)->delay(Carbon::now()->addMinutes(1440));
  271. if(!$result['result']){
  272. $this->log(__METHOD__,'weightApi'.__FUNCTION__,json_encode($request).'||'.json_encode($package),null);
  273. $response=["msg"=>"写入WMS失败!","code"=>500,"data"=>null];
  274. return json_encode($response,JSON_UNESCAPED_UNICODE);
  275. }
  276. }
  277. if(!empty($package->order_id))
  278. Waybill::setWeightByOrderCode($package->order_code,$package->weight);
  279. event(new WeighedEvent($package));
  280. $response=["msg"=>"保存成功",
  281. "code"=>200,
  282. "data"=>true,
  283. "serverMsg"=>null,
  284. "requestor"=>[
  285. "requestor"=>"1",
  286. "eventCode"=>"0",
  287. "reqDate"=>$reqDate,
  288. "resDate"=>Carbon::now()]
  289. ];
  290. $this->log(__METHOD__,__FUNCTION__,"下发写入包裹成功:".json_encode($request).'|'.json_encode($response),null);
  291. return json_encode($response,JSON_UNESCAPED_UNICODE);
  292. }
  293. public function validatorWeight(array $request){
  294. $validator=Validator::make($request,[
  295. 'id'=>['required','max:30',/*function ($attribute, $value, $fail) {
  296. $measuringMachine=MeasuringMachine::where('code',$value)->first();
  297. if (!$measuringMachine) {
  298. $fail($attribute.' 设备未录入在系统中!');
  299. }}*/],
  300. 'barcode'=>['required','max:191'],
  301. 'weight'=>['required','numeric','min:0'],
  302. 'length'=>['nullable','numeric','min:0'],
  303. 'width'=>['nullable','numeric','min:0'],
  304. 'height'=>['nullable','numeric','min:0'],
  305. ],[
  306. 'required'=>':attribute 为必填项',
  307. 'max'=>':attribute 字符过多或数值过大',
  308. 'min'=>':attribute 不得为负',
  309. 'numeric'=>':attribute 应为数字',
  310. ],[]);
  311. return $validator;
  312. }
  313. }