PackageController.php 15 KB

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