PackageController.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  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. // app('LogService')->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. // app('LogService')->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. // app('LogService')->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. // app('LogService')->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. // app('LogService')->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. // app('LogService')->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. // app('LogService')->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. $reqDate=Carbon::now();
  168. $errors=$this->validatorWeight($request)->errors();
  169. if (count($errors)>0){
  170. app('LogService')->log(__METHOD__,'error'.__FUNCTION__,json_encode($request).'||'.json_encode($errors),null);
  171. return json_encode(["msg"=>$errors,"code"=>500,"data"=>null]);
  172. }
  173. $id = $request['id']??'无ID设备';
  174. $measuringMachine=MeasuringMachine::query()->firstOrCreate(['code'=> $id]);
  175. $measuringMachine->turnOn();
  176. $measuringMachine->turnOffInMinutes(30);
  177. /** @var OrderPackage $package */
  178. $package=OrderPackage::query()->where('logistic_number',$request['barcode'])->first();
  179. $edges=[$request['length']??0,$request['width']??0,$request['height']??0];
  180. rsort($edges);
  181. $fluxController=new \App\Http\Controllers\Api\thirdPart\flux\PackageController();
  182. if ($package){
  183. $package['measuring_machine_id']=$measuringMachine->id;
  184. $package['weight']=$request['weight'];
  185. $package['length']=$edges[0];
  186. $package['width']=$edges[1];
  187. $package['height']=$edges[2];
  188. $package['weighed_at']=$reqDate;
  189. $package->fetchAllFromOracle();
  190. $package->fetchPaperBox();
  191. $package['bulk']=$edges[0]*$edges[1]*$edges[2];
  192. if ($package->isActivityBatch()){//处理活动波次
  193. app('LogService')->log(__METHOD__,__FUNCTION__,"依波次号同步所有包裹:".json_encode($package),null);
  194. $package->unifyThisMeasureUnderSameBatch();
  195. $result=$fluxController->markWMSOnBatch($package['batch_number'], $request['weight']);
  196. if(!$result['result']){
  197. $package->status="上传异常";
  198. }
  199. }else{
  200. app('LogService')->log(__METHOD__,__FUNCTION__,"写入包裹至WMS:".json_encode($package),null);
  201. try{
  202. $result=$fluxController->accomplishToWMS($package);
  203. if ($result['result']){
  204. $package->status="已上传";
  205. }else{
  206. $package->status="上传异常";
  207. }
  208. }catch (\Exception $e){
  209. $package->status="未上传";
  210. }
  211. }
  212. try{
  213. $package->save();
  214. $package->load(['order'=>function($query){
  215. $query->with('owner','logistic');
  216. },'paperBox','measuringMachine']);
  217. $logisticNumberController = new LogisticNumberFeatureController();
  218. if (!$package->order){
  219. $package->order = new Order();
  220. $logistic=$logisticNumberController->getLogisticByFeatures($package->logistic_number);
  221. $package->order->logistic = $logistic;
  222. }else{
  223. if(!$package->order->logistic){
  224. $logistic=$logisticNumberController->getLogisticByFeatures($package->logistic_number);
  225. $package->order->logistic_id = $logistic['id'];
  226. $package->order->save();
  227. }
  228. }
  229. }catch (\Exception $e){
  230. $response=["msg"=>"称重下发修改时发生错误!".json_encode($e),"code"=>500,"data"=>null];
  231. app('LogService')->log(__METHOD__,'weightApi(ERROR)'.__FUNCTION__,json_encode($request).'||'.json_encode($response).'||'.json_encode($e),null);
  232. return json_encode($response,JSON_UNESCAPED_UNICODE);
  233. }
  234. }
  235. if (!$package){
  236. $logisticNumber=$request['barcode'];
  237. /** @var $orderService OrderService */
  238. $orderService = app('OrderService');
  239. $order = $orderService->logisticNumberFirstOrCreateOrder($logisticNumber);
  240. if (!$order) {
  241. $response=["msg"=>"保存时发生错误(未在WMS找到该单)!","code"=>500,"data"=>null];
  242. return json_encode($response,JSON_UNESCAPED_UNICODE);
  243. }
  244. $package=new OrderPackage([
  245. 'order_id' => $order->id,
  246. 'logistic_number'=>$logisticNumber,
  247. 'measuring_machine_id'=>$measuringMachine->id,
  248. 'weight'=>$request['weight'],
  249. 'length'=>$edges[0],
  250. 'width'=>$edges[1],
  251. 'height'=>$edges[2],
  252. 'bulk'=>$edges[0]*$edges[1]*$edges[2],
  253. 'weighed_at'=>$reqDate,
  254. 'status'=>"无",
  255. ]);
  256. $package->fetchAllFromOracle();
  257. $package->fetchPaperBox();
  258. try{
  259. $package->save();
  260. $package->load(['order'=>function($query){
  261. $query->with('owner','logistic');
  262. },'paperBox','measuringMachine']);
  263. $logisticNumberController = new LogisticNumberFeatureController();
  264. if (!$package->order){
  265. $package->order = new Order();
  266. $logistic=$logisticNumberController->getLogisticByFeatures($package->logistic_number);
  267. $package->order->logistic = $logistic;
  268. }else{
  269. if(!$package->order->logistic){
  270. $logistic=$logisticNumberController->getLogisticByFeatures($package->logistic_number);
  271. $package->order->logistic_id = $logistic['id'];
  272. $package->order->save();
  273. }
  274. }
  275. }catch (\Exception $e){
  276. $response=["msg"=>$e->getMessage(),"code"=>500,"data"=>$e->getTraceAsString()];
  277. app('LogService')->log(__METHOD__,'weightApi(ERROR)'.__FUNCTION__,json_encode($request).'||'.json_encode($response).'||'.$e->getTraceAsString(),null);
  278. return json_encode($response,JSON_UNESCAPED_UNICODE);
  279. }
  280. $result=$fluxController->accomplishToWMS($package);
  281. if(!$package['batch_number'])
  282. FetchPackageFromOracle::dispatch($package)->delay(Carbon::now()->addMinutes(1440));
  283. if(!$result['result']){
  284. app('LogService')->log(__METHOD__,'weightApi'.__FUNCTION__,json_encode($request).'||'.json_encode($package),null);
  285. $response=["msg"=>"写入WMS失败!","code"=>500,"data"=>null];
  286. return json_encode($response,JSON_UNESCAPED_UNICODE);
  287. }
  288. }
  289. if(!empty($package->order))
  290. Waybill::setWeightByOrderCode($package->order->code,$package->weight);
  291. event(new WeighedEvent($package));
  292. $response=["msg"=>"保存成功",
  293. "code"=>200,
  294. "data"=>true,
  295. "serverMsg"=>null,
  296. "requestor"=>[
  297. "requestor"=>"1",
  298. "eventCode"=>"0",
  299. "reqDate"=>$reqDate,
  300. "resDate"=>Carbon::now()]
  301. ];
  302. app('LogService')->log(__METHOD__,__FUNCTION__,"下发写入包裹成功:".json_encode($request).'|'.json_encode($response),null);
  303. return json_encode($response,JSON_UNESCAPED_UNICODE);
  304. }
  305. public function validatorWeight(array $request){
  306. $validator=Validator::make($request,[
  307. 'id'=>['nullable','max:30',/*function ($attribute, $value, $fail) {
  308. $measuringMachine=MeasuringMachine::where('code',$value)->first();
  309. if (!$measuringMachine) {
  310. $fail($attribute.' 设备未录入在系统中!');
  311. }}*/],
  312. 'barcode'=>['required','max:191'],
  313. 'weight'=>['required','numeric','min:0'],
  314. 'length'=>['nullable','numeric','min:0'],
  315. 'width'=>['nullable','numeric','min:0'],
  316. 'height'=>['nullable','numeric','min:0'],
  317. ],[
  318. 'required'=>':attribute 为必填项',
  319. 'max'=>':attribute 字符过多或数值过大',
  320. 'min'=>':attribute 不得为负',
  321. 'numeric'=>':attribute 应为数字',
  322. ],[]);
  323. return $validator;
  324. }
  325. }