ReceiveController.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. <?php
  2. namespace App\Http\Controllers\Api\thirdPart\flux;
  3. use App\Batch;
  4. use App\Events\WmsReceiveNewEvent;
  5. use App\Http\Controllers\Controller;
  6. use App\Order;
  7. use App\OrderBarcode;
  8. use App\RejectedBill;
  9. use App\RejectedBillItem;
  10. use App\SkuNew;
  11. use App\Store;
  12. use App\WMSReflectReceive;
  13. use App\WMSReflectReceiveSku;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Support\Facades\Auth;
  16. use Illuminate\Support\Facades\Validator;
  17. use Zttp\Zttp;
  18. class ReceiveController extends Controller
  19. {
  20. /**
  21. * 收货任务下发
  22. */
  23. public function new_(Request $request)
  24. {
  25. $errors=$this->validatorForNew($request->all())->errors();
  26. if(count($errors)>0){
  27. $this->log(__METHOD__, 'error_body' . __FUNCTION__, json_encode($request->getContent()));
  28. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,'fields wrong, see Errors report please.'.'|'.json_encode($request).'|'.json_encode($errors));
  29. return response()->json(['response'=>['flag'=>'W','message'=>'fields wrong, see Errors report please.',
  30. 'errors'=>$errors]])
  31. ->setEncodingOptions(JSON_UNESCAPED_UNICODE);
  32. }
  33. $receiveInputs=$request->input('request');
  34. foreach ($receiveInputs as $receiveInput){
  35. $isRepeated=WMSReflectReceive::where('ASNNO',$receiveInput['ASNNO'])->first();
  36. if($isRepeated){
  37. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,'ASNNO重复'.'|'.json_encode($request).'|'.json_encode($errors));
  38. return response()->json(['response'=>['flag'=>'N','code'=>'6666','message'=>'ASNNO重复']])
  39. ->setEncodingOptions(JSON_UNESCAPED_UNICODE);
  40. }
  41. $receive=new WMSReflectReceive($receiveInput);
  42. $receive->save();
  43. // $skus=[];
  44. foreach ($receiveInput['SKU_LIST'] as $skuInput){
  45. $sku=new WMSReflectReceiveSku($skuInput);
  46. $receive->skus()->save($sku);
  47. // $skus[]=$sku;
  48. }
  49. event(new WmsReceiveNewEvent($receive['ASNREFERENCE3'],$receive));
  50. }
  51. return response()->json(['response'=>['flag'=>'Y','code'=>'0000','message'=>'正确接收']])
  52. ->setEncodingOptions(JSON_UNESCAPED_UNICODE);
  53. }
  54. protected function validatorForNew(array $data)
  55. {
  56. return Validator::make($data, [
  57. 'request' => ['required', 'array', 'min:1'],
  58. 'request.*.ASNNO' => ['required', 'string', 'max:191'],
  59. 'request.*.WAREHOUSEID' => ['required', 'string', 'max:191'],
  60. 'request.*.CUSTOMERID' => ['required', 'string', 'max:191'],
  61. 'request.*.ASNTYPE' => ['nullable', 'string', 'max:191'],
  62. 'request.*.ASNREFERENCE1' => ['nullable', 'string', 'max:191'],
  63. 'request.*.ASNREFERENCE2' => ['nullable', 'string', 'max:191'],
  64. 'request.*.ASNREFERENCE3' => ['required', 'string', 'max:191'],
  65. 'request.*.ASNSTATUS' => ['nullable', 'string', 'max:191'],
  66. 'request.*.NOTES' => ['nullable', 'string', 'max:191'],
  67. 'request.*.USERDEFINE1' => ['nullable', 'string', 'max:191'],
  68. 'request.*.USERDEFINE2' => ['nullable', 'string', 'max:191'],
  69. 'request.*.USERDEFINE3' => ['nullable', 'string', 'max:191'],
  70. 'request.*.SKU_LIST' => ['required', 'array', 'min:1'],
  71. 'request.*.SKU_LIST.*.ASNLINENO' => ['nullable', 'string', 'max:191'],
  72. 'request.*.SKU_LIST.*.SKU' => ['required', 'string', 'max:191'],
  73. 'request.*.SKU_LIST.*.ALTERNATE_SKU1' => ['required', 'string', 'max:191'],
  74. 'request.*.SKU_LIST.*.SKUDESCRC' => ['nullable', 'string', 'max:191'],
  75. 'request.*.SKU_LIST.*.EXPECTEDQTY_EACH' => ['nullable', 'string', 'max:191'],
  76. 'request.*.SKU_LIST.*.UOM' => ['nullable', 'string', 'max:191'],
  77. 'request.*.SKU_LIST.*.LINESTATUS' => ['nullable', 'string', 'max:191'],
  78. 'request.*.SKU_LIST.*.LOTATT05' => ['nullable', 'string', 'max:191'],
  79. 'request.*.SKU_LIST.*.USERDEFINE4' => ['nullable', 'string', 'max:191'],
  80. 'request.*.SKU_LIST.*.USERDEFINE5' => ['nullable', 'string', 'max:191'],
  81. 'request.*.SKU_LIST.*.USERDEFINE6' => ['nullable', 'string', 'max:191'],
  82. ],[],[
  83. 'request.ASNNO' => 'ASNNO',
  84. 'request.*.WAREHOUSEID' => 'WAREHOUSEID',
  85. 'request.*.CUSTOMERID' => 'CUSTOMERID',
  86. 'request.*.ASNTYPE' => 'ASNTYPE',
  87. 'request.*.ASNREFERENCE1' => 'ASNREFERENCE1',
  88. 'request.*.ASNREFERENCE2' => 'ASNREFERENCE2',
  89. 'request.*.ASNREFERENCE3' => 'ASNREFERENCE3',
  90. 'request.*.ASNSTATUS' => 'ASNSTATUS',
  91. 'request.*.NOTES' => 'NOTES',
  92. 'request.*.USERDEFINE1' => 'USERDEFINE1',
  93. 'request.*.USERDEFINE2' => 'USERDEFINE2',
  94. 'request.*.USERDEFINE3' => 'USERDEFINE3',
  95. 'request.*.SKU_LIST' => 'SKU_LIST',
  96. 'request.*.SKU_LIST.*.ASNLINENO' => 'SKU_LIST.ASNLINENO',
  97. 'request.*.SKU_LIST.*.SKU' => 'SKU_LIST.SKU',
  98. 'request.*.SKU_LIST.*.ALTERNATE_SKU1' => 'SKU_LIST.ALTERNATE_SKU1',
  99. 'request.*.SKU_LIST.*.SKUDESCRC' => 'SKU_LIST.SKUDESCRC',
  100. 'request.*.SKU_LIST.*.EXPECTEDQTY_EACH' => 'SKU_LIST.EXPECTEDQTY_EACH',
  101. 'request.*.SKU_LIST.*.UOM' => 'SKU_LIST.UOM',
  102. 'request.*.SKU_LIST.*.LINESTATUS' => 'SKU_LIST.LINESTATUS',
  103. 'request.*.SKU_LIST.*.LOTATT05' => 'SKU_LIST.LOTATT05',
  104. 'request.*.SKU_LIST.*.USERDEFINE4' => 'SKU_LIST.USERDEFINE4',
  105. 'request.*.SKU_LIST.*.USERDEFINE5' => 'SKU_LIST.USERDEFINE5',
  106. 'request.*.SKU_LIST.*.USERDEFINE6' => 'SKU_LIST.USERDEFINE6',
  107. ]);
  108. }
  109. /**
  110. * 入库回传给WMS
  111. * @param RejectedBill $rejectedBill
  112. * @return bool
  113. */
  114. static public function accomplishToWMS(RejectedBill $rejectedBill)
  115. {
  116. $bill=$rejectedBill;
  117. $wmsReceiveds=WMSReflectReceive::where('ASNREFERENCE3',$rejectedBill['logistic_number_return'])
  118. ->where('is_uploaded',0)->get();
  119. if($wmsReceiveds->isEmpty()){
  120. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,'没有WMS入库单');
  121. return false;
  122. }
  123. $items=$bill->items()->get();
  124. $amountsItem=(function()use($items){
  125. $result=[];
  126. $items->each(function($item)use(&$result){
  127. $result[$item['id']]= $item['amount'];
  128. });
  129. return $result;
  130. })();
  131. $success=true;
  132. $wmsReceiveds->each(function ($wmsReceived)use(&$bill,&$amountsItem,$items,&$success){
  133. if(!$bill && $bill['is_loaded']!=0)return;
  134. $wmsSkus=$wmsReceived->skus()->get();
  135. $orderNumberCode=$wmsReceived['ASNREFERENCE1']??$bill['order_number'];
  136. $amountsSku=(function()use($wmsSkus){
  137. $result=[];
  138. $wmsSkus->each(function($sku)use(&$result){
  139. $result[$sku['id']]= $sku['EXPECTEDQTY_EACH'];
  140. });
  141. return $result;
  142. })();
  143. $skuStrList=[];
  144. $customerCode=$bill->owner()->first()['code'];
  145. $wmsSkus->each(function(WMSReflectReceiveSku $sku)use(&$items,&$skuList,&$amountsItem,&$amountsSku,&$skuStrList,$wmsReceived,$customerCode){
  146. $items->each(function(RejectedBillItem $item)use(&$sku,&$amountsItem,&$amountsSku,&$skuStrList,$wmsReceived,$customerCode){
  147. if($item['barcode_goods']!=$sku['ALTERNATE_SKU1'])return;
  148. if($amountsItem[$item['id']]==0||$amountsSku[$sku['id']]==0)return;
  149. $uploadingAmount=(function()use(&$item,&$sku,&$amountsItem,&$amountsSku){
  150. if($amountsItem[$item['id']]>$amountsSku[$sku['id']]){
  151. $amountsItem[$item['id']]-=$amountsSku[$sku['id']];
  152. $amount= $amountsSku[$sku['id']];
  153. $amountsSku[$sku['id']]=0;
  154. return $amount;
  155. }
  156. if($amountsItem[$item['id']]<$amountsSku[$sku['id']]){
  157. $amount=$amountsItem[$item['id']];
  158. $amountsSku[$sku['id']]-=$amount;
  159. $amountsItem[$item['id']]=0;
  160. return $amount;
  161. }
  162. $amount=$amountsItem[$item['id']];
  163. $amountsItem[$item['id']]=0;
  164. $amountsSku[$sku['id']]=0;
  165. return $amount;
  166. })();
  167. if($item['is_loaded']=='已入库'){return;}
  168. $STATUS=$item['id_quality_label']==1?'ZP':'CC';
  169. $STATUS_code=$item['id_quality_label']==1?'01':'02';
  170. $skuStr="
  171. {
  172. \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  173. \"ASNLINENO\": \"{$sku['ASNLINENO']}\",
  174. \"SKUCODE\": \"{$sku['SKU']}\",
  175. \"QUANTITY\": \"{$uploadingAmount}\",
  176. \"LOTATT04\": \"{$sku['LOTATT04']}\",
  177. \"LOTATT05\": \"{$sku['LOTATT05']}\",
  178. \"STATUS\": \"{$STATUS}\",
  179. \"PRODUCTION DATE\": \"{$item['made_at']}\",
  180. \"EXPIRATION DATE\": \"{$item['validity_at']}\",
  181. \"USERDEFINE1\": \"{$customerCode}{$STATUS_code}\",
  182. \"USERDEFINE2\": \"\",
  183. \"USERDEFINE3\": \"\",
  184. \"UNIQUE_CODE_LIST\": [".
  185. // {
  186. // \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  187. // \"SKUCODE\": \"{$sku['SKU']}\",
  188. // \"STATUS\": \"{$STATUS}\",
  189. // \"PRODUCTION DATE\": \"{$item['made_at']}\",
  190. // \"EXPIRATION DATE\": \"{$item['validity_at']}\",
  191. // \"LOTATT05\": \"{$sku['LOTATT05']}\",
  192. // \"UNIQUE_CODE\": \"\"
  193. // }
  194. "]
  195. }
  196. ";
  197. $skuStrList[]=$skuStr;
  198. });
  199. });
  200. if(count($skuStrList)==0)return;
  201. $skuStrList = implode(',',$skuStrList);
  202. $json="
  203. {
  204. \"request\": [
  205. {
  206. \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  207. \"CUSTOMERID\": \"{$customerCode}\",
  208. \"ASNTYPE\": \"{$wmsReceived['ASNTYPE']}\",
  209. \"ASNREFERENCE1\": \"{$orderNumberCode}\",
  210. \"ADDWHO\": \"WCS\",
  211. \"USERDEFINE1\": \"\",
  212. \"USERDEFINE2\": \"\",
  213. \"USERDEFINE3\": \"\",
  214. \"SKU_LIST\": [{$skuStrList}]
  215. }
  216. ]
  217. }
  218. ";
  219. $sendingJson = json_decode($json,true);
  220. $url=url(config('api.flux.receive.new'));
  221. $response = Zttp::post($url, $sendingJson);
  222. $noIssues=true;
  223. $json = $response->json();
  224. (new Controller())->log(__METHOD__,__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  225. if(!$json||!isset($json['Response'])||!$json['Response']['return']['returnFlag']=='1'){
  226. $noIssues=false;
  227. }
  228. if($json&&isset($json['Response'])){
  229. if($json['Response']['return']['returnFlag']=='2'){
  230. return true;
  231. }
  232. if(isset($json['Response']['return']['returnDesc'])&&strpos($json['Response']['return']['returnDesc'],'唯一约束')!==false){
  233. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  234. return true;
  235. }
  236. if(isset($json['Response']['return']['errordescr'])&&strpos($json['Response']['return']['errordescr'],'已完成')!==false){
  237. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  238. return true;
  239. }
  240. }
  241. if($noIssues&&$json['Response']['return']['returnFlag']=='1'){
  242. $wmsReceived['is_uploaded']=1;
  243. $wmsReceived->save();
  244. return true;
  245. }else{
  246. $success=false;
  247. (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  248. }
  249. });
  250. return $success;
  251. }
  252. /**
  253. * 入库回传给WMS
  254. * @param RejectedBill $rejectedBill
  255. * @return bool
  256. */
  257. static public function accomplishStoreToWMS(Store $store)
  258. {
  259. // $bill=$rejectedBill;
  260. // $wmsReceiveds=WMSReflectReceive::where('ASNREFERENCE3',$rejectedBill['logistic_number_return'])
  261. // ->where('is_uploaded',0)->get();
  262. // if($wmsReceiveds->isEmpty()){
  263. // (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,'没有WMS入库单');
  264. // return false;
  265. // }
  266. // $items=$bill->items()->get();
  267. // $amountsItem=(function()use($items){
  268. // $result=[];
  269. // $items->each(function($item)use(&$result){
  270. // $result[$item['id']]= $item['amount'];
  271. // });
  272. // return $result;
  273. // })();
  274. // $success=true;
  275. // $wmsReceiveds->each(function ($wmsReceived)use(&$bill,&$amountsItem,$items,&$success){
  276. // if(!$bill && $bill['is_loaded']!=0)return;
  277. //
  278. // $wmsSkus=$wmsReceived->skus()->get();
  279. // $orderNumberCode=$wmsReceived['ASNREFERENCE1']??$bill['order_number'];
  280. // $amountsSku=(function()use($wmsSkus){
  281. // $result=[];
  282. // $wmsSkus->each(function($sku)use(&$result){
  283. // $result[$sku['id']]= $sku['EXPECTEDQTY_EACH'];
  284. // });
  285. // return $result;
  286. // })();
  287. // $skuStrList=[];
  288. // $customerCode=$bill->owner()->first()['code'];
  289. // $wmsSkus->each(function(WMSReflectReceiveSku $sku)use(&$items,&$skuList,&$amountsItem,&$amountsSku,&$skuStrList,$wmsReceived,$customerCode){
  290. // $items->each(function(RejectedBillItem $item)use(&$sku,&$amountsItem,&$amountsSku,&$skuStrList,$wmsReceived,$customerCode){
  291. // if($item['barcode_goods']!=$sku['ALTERNATE_SKU1'])return;
  292. // if($amountsItem[$item['id']]==0||$amountsSku[$sku['id']]==0)return;
  293. // $uploadingAmount=(function()use(&$item,&$sku,&$amountsItem,&$amountsSku){
  294. // if($amountsItem[$item['id']]>$amountsSku[$sku['id']]){
  295. // $amountsItem[$item['id']]-=$amountsSku[$sku['id']];
  296. // $amount= $amountsSku[$sku['id']];
  297. // $amountsSku[$sku['id']]=0;
  298. // return $amount;
  299. // }
  300. // if($amountsItem[$item['id']]<$amountsSku[$sku['id']]){
  301. // $amount=$amountsItem[$item['id']];
  302. // $amountsSku[$sku['id']]-=$amount;
  303. // $amountsItem[$item['id']]=0;
  304. // return $amount;
  305. // }
  306. // $amount=$amountsItem[$item['id']];
  307. // $amountsItem[$item['id']]=0;
  308. // $amountsSku[$sku['id']]=0;
  309. // return $amount;
  310. // })();
  311. // if($item['is_loaded']=='已入库'){return;}
  312. // $STATUS=$item['id_quality_label']==1?'ZP':'CC';
  313. // $STATUS_code=$item['id_quality_label']==1?'01':'02';
  314. // $skuStr="
  315. // {
  316. // \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  317. // \"ASNLINENO\": \"{$sku['ASNLINENO']}\",
  318. // \"SKUCODE\": \"{$sku['SKU']}\",
  319. // \"QUANTITY\": \"{$uploadingAmount}\",
  320. // \"LOTATT04\": \"{$sku['LOTATT04']}\",
  321. // \"LOTATT05\": \"{$sku['LOTATT05']}\",
  322. // \"STATUS\": \"{$STATUS}\",
  323. // \"PRODUCTION DATE\": \"{$item['made_at']}\",
  324. // \"EXPIRATION DATE\": \"{$item['validity_at']}\",
  325. // \"USERDEFINE1\": \"{$customerCode}{$STATUS_code}\",
  326. // \"USERDEFINE2\": \"\",
  327. // \"USERDEFINE3\": \"\",
  328. // \"UNIQUE_CODE_LIST\": [".
  329. //// {
  330. //// \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  331. //// \"SKUCODE\": \"{$sku['SKU']}\",
  332. //// \"STATUS\": \"{$STATUS}\",
  333. //// \"PRODUCTION DATE\": \"{$item['made_at']}\",
  334. //// \"EXPIRATION DATE\": \"{$item['validity_at']}\",
  335. //// \"LOTATT05\": \"{$sku['LOTATT05']}\",
  336. //// \"UNIQUE_CODE\": \"\"
  337. //// }
  338. // "]
  339. // }
  340. // ";
  341. // $skuStrList[]=$skuStr;
  342. // });
  343. // });
  344. // if(count($skuStrList)==0)return;
  345. // $skuStrList = implode(',',$skuStrList);
  346. // $json="
  347. // {
  348. // \"request\": [
  349. // {
  350. // \"ORDERNUMBERCODE\": \"{$wmsReceived['ASNNO']}\",
  351. // \"CUSTOMERID\": \"{$customerCode}\",
  352. // \"ASNTYPE\": \"{$wmsReceived['ASNTYPE']}\",
  353. // \"ASNREFERENCE1\": \"{$orderNumberCode}\",
  354. // \"ADDWHO\": \"WCS\",
  355. // \"USERDEFINE1\": \"\",
  356. // \"USERDEFINE2\": \"\",
  357. // \"USERDEFINE3\": \"\",
  358. // \"SKU_LIST\": [{$skuStrList}]
  359. // }
  360. // ]
  361. // }
  362. // ";
  363. //
  364. // $sendingJson = json_decode($json,true);
  365. // $url=url(config('api.flux.receive.new'));
  366. // $response = Zttp::post($url, $sendingJson);
  367. // $noIssues=true;
  368. // $json = $response->json();
  369. // (new Controller())->log(__METHOD__,__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  370. // if(!$json||!isset($json['Response'])||!$json['Response']['return']['returnFlag']=='1'){
  371. // $noIssues=false;
  372. // }
  373. // if($json&&isset($json['Response'])){
  374. // if($json['Response']['return']['returnFlag']=='2'){
  375. // return true;
  376. // }
  377. // if(isset($json['Response']['return']['returnDesc'])&&strpos($json['Response']['return']['returnDesc'],'唯一约束')!==false){
  378. // (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  379. // return true;
  380. // }
  381. // if(isset($json['Response']['return']['errordescr'])&&strpos($json['Response']['return']['errordescr'],'已完成')!==false){
  382. // (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  383. // return true;
  384. // }
  385. // }
  386. // if($noIssues&&$json['Response']['return']['returnFlag']=='1'){
  387. // $wmsReceived['is_uploaded']=1;
  388. // $wmsReceived->save();
  389. // return true;
  390. // }else{
  391. // $success=false;
  392. // (new Controller())->log(__METHOD__,'error_'.__FUNCTION__,$response->body().'|'.json_encode($sendingJson));
  393. // }
  394. // });
  395. //
  396. //
  397. // return $success;
  398. }
  399. }