Model_logic_u9zt.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  1. <?php
  2. /**
  3. * 系统自动处理在途库存的香港问题
  4. */
  5. class Model_logic_u9zt extends Lin_Model {
  6. public $xczzcode = '130';//许昌销售公司编码
  7. public $xccp_code = '13001';//许昌成品库的编码
  8. public $xgzzcode = '140';//香港组织公司编码
  9. public $xgzt_code = '14001';//香港在途库的编码
  10. public $xgmc_code = '14002';//香港美仓的编码
  11. public $ztcode = '001';//账套的code;
  12. public $tb_org_arr =[140];//同步组织
  13. public $gys = "98002";//供应商 98001 龙盈 98002 龙熠
  14. public $yyid = "98003";
  15. //切记要修改token_120的token真正的token!!!!
  16. function __construct(){
  17. parent::__construct();
  18. $this->load->_model('Model_settingtest','settingtest');
  19. $this->load->_model("Model_apiyyv1",'apiyyv1');
  20. $this->load->_model('Model_classid','classid');
  21. $this->load->_model('Model_typeclass','typeclass');
  22. $this->load->_model('Model_shop','shop');
  23. $this->load->_model('Model_zzquque_u9','zzquque_u9');
  24. $this->load->_model('Model_zzququeu9_logs','zzququeu9_logs');
  25. $this->load->_model('Model_logic_tools','logic_tools');
  26. $this->load->_model('Model_logic_u9tools','logic_u9tools');
  27. $this->load->_model("Model_logic_order","logic_order");
  28. $this->load->_model('Model_whlabeltransport', 'whlabeltransport');
  29. }
  30. public function getToken($type){
  31. $name = "get_yytoken_".$type;
  32. $token = $this->settingtest->$name();
  33. return $token;
  34. }
  35. //转码准备数据
  36. public function transPrepare(){
  37. $classid = $this->classid->sku();
  38. $tcall = $this->typeclass->find_all();
  39. foreach ($tcall as $v)
  40. {
  41. $tcjm[$v['id']] = array($v['jm'],$v['classid']);
  42. $typeclass[$v['id']] = array('zh'=>$v['zh'],'classid'=>$v['classid'],'bm'=>$v['bm'],'title'=>$v['title'],'jm'=>$v['jm']);
  43. }
  44. return [
  45. 'classid'=>$classid,
  46. 'typeclass'=>$typeclass,
  47. ];
  48. }
  49. //创建调出单
  50. public function createdDc($info,$classid,$typeclass){
  51. $list = $this->whlabeltransport->find_all("order_no = '".$info['order_no']."'");
  52. $do_flag = true;
  53. foreach($list as $k=>$v){
  54. if($v['cz'] ==1 ){
  55. $do_flag = false;
  56. }
  57. }
  58. if(!$do_flag){
  59. $this->editData($info['id'],[
  60. 'dc_status'=>-1,
  61. 'update_time'=>time()
  62. ],$info['order_no'],1,1,'dc',[],$this->logic_tools->ret_arr(-1,'此单有已经完成的数据,不能进行同步'));
  63. return ;
  64. }
  65. $shipremarks = "";
  66. $dc_list = [];
  67. foreach($list as $k=>$v){
  68. if(stripos($v['features'],'-131-') !== false)
  69. {
  70. continue;
  71. }
  72. $v['features'] = str_replace(array('-163-','-164-','-165-','-166-'),'-',$v['features']);
  73. $shipremarks = $v["text"];
  74. $tmp_ret = $this->logic_u9tools->getOneU9bm($v['features'],$classid,$typeclass);
  75. $dc_list[] =[
  76. 'jm'=>$tmp_ret['jm'],
  77. 'bm'=>$tmp_ret['bm'],
  78. 'zh'=>$tmp_ret['zh'],
  79. 'dcsl'=>$v['num'],
  80. 'is_register'=>0,//商品是否被注册 先都当没注册 后面会先确认下
  81. ];
  82. }
  83. if(empty($dc_list)){
  84. $this->editData($info['id'],[
  85. 'dc_status'=>-1,
  86. 'update_time'=>time()
  87. ],$info['order_no'],1,1,'dc',[],$this->logic_tools->ret_arr(-1,'此单sku转化为u9编码,发现没有匹配数据'));
  88. return ;
  89. }
  90. $time = time();
  91. $dc_params = [
  92. 'gys'=>$this->gys,//供应商
  93. 'number'=>$info['order_no'],//erp订单编码
  94. "TransOutDocType_Code"=>"TransOut001",//组织间调拨
  95. "time"=>$time,
  96. 'TransferDirection'=>0,//普通
  97. 'yyid'=>"",//来源店铺 这种需要在店铺表中有
  98. 'shipremarks'=>$shipremarks,//订单的备注
  99. 'dcckbm'=>$this->xccp_code,//调出仓库编码
  100. 'drckbm'=>$this->xgzt_code,//调入仓库编码
  101. 'drzz_code'=>$this->xgzzcode,//调入组织Code
  102. 'owner_code'=>$this->xczzcode,//货主组织Code
  103. 'ztcode'=>$this->ztcode,//账套
  104. 'tb_org_arr'=>$this->tb_org_arr,//要同步的组织列表
  105. 'list'=>$dc_list
  106. ];
  107. $cxdcd_r = $this->apiyyv1->xcDcdByOtherId($dc_params['number'],$this->getToken(130));
  108. $ret_data = $cxdcd_r[0]['Data'];
  109. //调出单存在就不在执行了
  110. if(isset($ret_data[0])){
  111. $descflexfield_pubdescseg4 = $ret_data[0]['descflexfield_pubdescseg4'];
  112. if($dc_params['number'] == $descflexfield_pubdescseg4){
  113. return ;
  114. }
  115. }
  116. //检测料品是否在u9被添加 检测香港组织有没有 许昌组织一定要有 没有
  117. $r = $this->checkLp($dc_params,$this->getToken(140));
  118. if($r['code'] !=1){
  119. $this->editData($info['id'],['dc_status'=>-1,'update_time'=>time()],$info['order_no'],1,1,'lpck',$r['msg'][1],$r['msg'][0]);
  120. return ;
  121. }
  122. //创建调出单
  123. $dcd_res = $this->apiyyv1->dcdCrate($dc_params,$this->getToken(130));
  124. var_dump($dcd_res);
  125. if(empty($dcd_res[0]['Data'][0]["Code"])){
  126. $this->editData($info['id'],['dc_status'=>-1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  127. return ;
  128. }
  129. //更新
  130. $dcd_no = $dcd_res[0]['Data'][0]["Code"];
  131. $this->editData($info['id'],['dc_no'=>$dcd_no,'dc_status'=>1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  132. }
  133. //查询调出单是否审核 审核了 就更新
  134. public function cxDxcheck($info){
  135. $r = $this->apiyyv1->xdlsCxDcd($info['dc_no'],$this->getToken(130));
  136. if(empty($r[0]['Data'])){
  137. return ;
  138. }
  139. //更新销售单数据
  140. $xs_no = json_encode($r[0]['Data']);
  141. $this->editData($info['id'],['dc_data'=>$xs_no,'dc_data_status'=>1,'dc_status'=>3,'update_time'=>time()],$info['order_no'],8,1,'dc_xc',$r[1],$r[0]);
  142. }
  143. //创建销售单 和 采购单
  144. public function createXsAndCg($info){
  145. $tmp_data = $info['dc_data'];
  146. if(empty($tmp_data)){
  147. return ;
  148. }
  149. $tmp_data = json_decode($info['dc_data'],true);
  150. if(empty($tmp_data)){
  151. return ;
  152. }
  153. $list = [];
  154. foreach($tmp_data as $key=>$val){
  155. $list[] = [
  156. 'jm'=>$val['iteminfo_itemcode'],
  157. 'zh'=>$val['iteminfo_itemname'],
  158. 'final_price'=>$val['costprice'],
  159. 'dcsl'=>$val['costuomqty'],
  160. ];
  161. }
  162. $time = time();
  163. $do_params = [
  164. 'gys'=>$this->gys,//供应商
  165. 'number'=>$info['order_no'],//erp订单编码
  166. "TransOutDocType_Code"=>"TransOut001",//组织间调拨
  167. "time"=>$time,
  168. 'TransferDirection'=>0,//普通
  169. 'yyid'=>$this->yyid,//来源店铺 这种需要在店铺表中有
  170. 'shipremarks'=>$tmp_data[0]['descflexfield_pubdescseg5'],//订单的备注
  171. 'dcckbm'=>$this->xccp_code,//调出仓库编码
  172. 'drckbm'=>$this->xgzt_code,//调入仓库编码
  173. 'drzz_code'=>$this->xgzzcode,//调入组织Code
  174. 'owner_code'=>$this->xczzcode,//货主组织Code
  175. 'ztcode'=>$this->ztcode,//账套
  176. 'tb_org_arr'=>$this->tb_org_arr,//要同步的组织列表
  177. 'list'=>$list
  178. ];
  179. //创建许昌成品库的销售单
  180. $xsd_res = $this->apiyyv1->xsdCreate($do_params,$this->getToken(130));
  181. if(empty($xsd_res[0]['Data'][0]['m_code'])){
  182. $this->editData($info['id'],['xs_status'=>-1,'update_time'=>time()],$info['order_no'],2,1,'xs',$xsd_res[1],$xsd_res[0]);
  183. return ;
  184. }
  185. //更新销售单数据
  186. $xs_no = $xsd_res[0]['Data'][0]["m_code"];
  187. $this->editData($info['id'],['xs_no'=>$xs_no,'xs_status'=>1,'update_time'=>time()],$info['order_no'],2,1,'xs',$xsd_res[1],$xsd_res[0]);
  188. //创建香港公司的采购单
  189. $cgd_res = $this->apiyyv1->cgdCreate($do_params,$this->getToken(140));
  190. if(empty($cgd_res[0]['Data'][0]["Code"])){
  191. $this->editData($info['id'],['cg_status'=>-1,'update_time'=>time()],$info['order_no'],3,1,'cg',$cgd_res[1],$cgd_res[0]);
  192. return ;
  193. }
  194. $this->editData($info['id'],['cg_no'=>$cgd_res[0]['Data'][0]["Code"],'cg_status'=>1,'update_time'=>time()],$info['order_no'],3,1,'cg',$cgd_res[1],$cgd_res[0]);
  195. }
  196. //审核的调出单后 直接查询对应调入单 直接提交和审核
  197. public function cxDrByDc($info){
  198. $r = $this->apiyyv1->drdcxBydcd($info['dc_no'],$this->getToken(140));
  199. //如果获取对应调入单没有成功
  200. if(empty($r[0]['Data'][0]['docno'])){
  201. $this->editData($info['id'],['dr_status'=>-1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  202. return ;
  203. }
  204. $dr_no = $r[0]['Data'][0]["docno"];
  205. $this->editData($info['id'],['dr_no'=>$dr_no,'dr_status'=>1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  206. //提交调入单
  207. $rr = $this->apiyyv1->drdSubmit(['number'=>$dr_no],$this->getToken(140));
  208. if(!$rr[0]['Data'][0]['IsSucess']){
  209. $this->editData($info['id'],['dr_status'=>-2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  210. return;
  211. }
  212. $this->editData($info['id'],['dr_status'=>2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  213. //审核调入单
  214. $rrr = $this->apiyyv1->drdApprove(['number'=>$dr_no],$this->getToken(140));
  215. if(!$rrr[0]['Data'][0]['IsSucess']){
  216. $this->editData($info['id'],['dr_status'=>-3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  217. return;
  218. }
  219. $this->editData($info['id'],['dr_status'=>3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  220. }
  221. //提交和审核销售单
  222. public function shCgAndXs($info){
  223. $r = $this->apiyyv1->cgdSubmit([
  224. 'number'=>$info['cg_no']
  225. ],$this->getToken(140));
  226. if(!$r[0]['Data'][0]['IsSucess']){
  227. $this->editData($info['id'],['cg_status'=>-2,'update_time'=>time()],$info['order_no'],3,2,'cg',$r[1],$r[0]);
  228. return false;
  229. }
  230. //更新采购单
  231. $this->editData($info['id'],['cg_status'=>2,'update_time'=>time()],$info['order_no'],3,2,'cg',$r[1],$r[0]);
  232. $rr = $this->apiyyv1->cgdApprove([
  233. 'number'=>$info['cg_no']
  234. ],$this->getToken(140));
  235. if(!$rr[0]['Data'][0]['IsSucess']){
  236. $this->editData($info['id'],['cg_status'=>-3,'update_time'=>time()],$info['order_no'],3,3,'cg',$rr[1],$rr[0]);
  237. return false;
  238. }
  239. $this->editData($info['id'],['cg_status'=>3,'update_time'=>time()],$info['order_no'],3,3,'cg',$rr[1],$rr[0]);
  240. $r = $this->apiyyv1->xsdSubmit([
  241. 'number'=>$info['xs_no']
  242. ],$this->getToken(130));
  243. if(!$r[0]['Data'][0]['m_isSucess']){
  244. $this->editData($info['id'],['xs_status'=>-2,'update_time'=>time()],$info['order_no'],2,2,'xs',$r[1],$r[0]);
  245. return false;
  246. }
  247. $this->editData($info['id'],['xs_status'=>2,'update_time'=>time()],$info['order_no'],2,2,'xs',$r[1],$r[0]);
  248. $rr = $this->apiyyv1->xsdApprove([
  249. 'number'=>$info['xs_no']
  250. ],$this->getToken(130));
  251. if(!$rr[0]['Data'][0]['m_isSucess']){
  252. $this->editData($info['id'],['xs_status'=>-3,'update_time'=>time()],$info['order_no'],2,3,'xs',$rr[1],$rr[0]);
  253. return false;
  254. }
  255. $this->editData($info['id'],['xs_status'=>3,'update_time'=>time()],$info['order_no'],2,3,'xs',$rr[1],$rr[0]);
  256. return true;
  257. }
  258. //创建在途库存调入美仓的调出单
  259. public function createDcTwo($info){
  260. $time = time();
  261. $tmp_list = $this->zzquque_u9->find_all("order_no = '".$info['order_no']."' and type = 1 and dc_status = 3 and xs_status = 3 and cg_status = 3 and dr_status = 3");
  262. if(empty($tmp_list)){
  263. return ;
  264. }
  265. $tmp_info = $tmp_list[0];
  266. if(empty($tmp_info['dc_data'])){
  267. return ;
  268. }
  269. $tmp_data = json_decode($tmp_info['dc_data'],true);
  270. if(empty($tmp_data)){
  271. return ;
  272. }
  273. $dc_list = [];
  274. foreach($tmp_data as $key=>$val){
  275. $dc_list[] = [
  276. 'jm'=>$val['iteminfo_itemcode'],
  277. 'dcsl'=>$val['costuomqty'],
  278. ];
  279. }
  280. $dc_params = [
  281. 'gys'=>$this->gys,//供应商
  282. 'number'=>$info['order_no'],//erp订单编码
  283. "TransOutDocType_Code"=>"TransOut002",//仓库转储
  284. "time"=>$time,
  285. 'TransferDirection'=>0,//普通
  286. 'yyid'=>"",//来源店铺 这种需要在店铺表中有
  287. 'shipremarks'=>$tmp_data[0]['descflexfield_pubdescseg5'],//订单的备注
  288. 'dcckbm'=>$this->xgzt_code,//调出仓库编码 在途库
  289. 'drckbm'=>$this->xgmc_code,//调入仓库编码 美仓
  290. 'drzz_code'=>$this->xgzzcode,//调入组织Code
  291. 'owner_code'=>$this->xgzzcode,//货主组织Code
  292. 'ztcode'=>$this->ztcode,//账套
  293. 'tb_org_arr'=>$this->tb_org_arr,//要同步的组织列表
  294. 'list'=>$dc_list
  295. ];
  296. //创建调出单
  297. $dcd_res = $this->apiyyv1->dcdCrate($dc_params,$this->getToken(140));
  298. if(empty($dcd_res[0]['Data'][0]["Code"])){
  299. $this->editData($info['id'],['dc_status'=>-1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  300. return ;
  301. }
  302. //更新
  303. $dcd_no = $dcd_res[0]['Data'][0]["Code"];
  304. $this->editData($info['id'],['dc_no'=>$dcd_no,'dc_status'=>1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  305. sleep(2);
  306. $info['dc_no'] = $dcd_no;
  307. $info['dc_status'] = 1;
  308. $r = $this->shDcTwo($info);
  309. if(!$r){
  310. return false;
  311. }
  312. sleep(2);
  313. $info['dc_status'] = 3;
  314. $r = $this->cxDcTwo($info);
  315. }
  316. //提交审核
  317. public function shDcTwo($info){
  318. $r = $this->apiyyv1->dcdSubmit([
  319. 'number'=>$info['dc_no']
  320. ],$this->getToken(140));
  321. if(!$r[0]['Data'][0]['IsSucess']){
  322. $this->editData($info['id'],['dc_status'=>-2,'update_time'=>time()],$info['order_no'],1,2,'dc',$r[1],$r[0]);
  323. return false;
  324. }
  325. //更新调出单
  326. $this->editData($info['id'],['dc_status'=>2,'update_time'=>time()],$info['order_no'],1,2,'dc',$r[1],$r[0]);
  327. $rr = $this->apiyyv1->dcdApprove([
  328. 'number'=>$info['dc_no']
  329. ],$this->getToken(140));
  330. if(!$rr[0]['Data'][0]['IsSucess']){
  331. $this->editData($info['id'],['dc_status'=>-3,'update_time'=>time()],$info['order_no'],1,3,'dc',$rr[1],$rr[0]);
  332. return false;
  333. }
  334. $this->editData($info['id'],['dc_status'=>3,'update_time'=>time()],$info['order_no'],1,3,'dc',$rr[1],$rr[0]);
  335. return true;
  336. }
  337. //查询调出单审核调出单 同时更新的
  338. public function cxDcTwo($info){
  339. $r = $this->apiyyv1->drdcxBydcd($info['dc_no'],$this->getToken(140));
  340. //如果获取对应调入单没有成功
  341. if(empty($r[0]['Data'][0]['docno'])){
  342. $this->editData($info['id'],['dr_status'=>-1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  343. return ;
  344. }
  345. $dr_no = $r[0]['Data'][0]["docno"];
  346. $this->editData($info['id'],['dr_no'=>$dr_no,'dr_status'=>1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  347. //提交调入单
  348. $rr = $this->apiyyv1->drdSubmit(['number'=>$dr_no],$this->getToken(140));
  349. if(!$rr[0]['Data'][0]['IsSucess']){
  350. $this->editData($info['id'],['dr_status'=>-2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  351. return;
  352. }
  353. $this->editData($info['id'],['dr_status'=>2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  354. //审核调入单
  355. $rrr = $this->apiyyv1->drdApprove(['number'=>$dr_no],$this->getToken(140));
  356. if(!$rrr[0]['Data'][0]['IsSucess']){
  357. $this->editData($info['id'],['dr_status'=>-3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  358. return;
  359. }
  360. $this->editData($info['id'],['dr_status'=>3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  361. }
  362. //根据返回的状态修改对应的值
  363. protected function editData($zq_u9_id,$z_qu_arr,$number,$one_type,$two_type,$apply_api,$apply_data,$ret_data){
  364. $this->zzquque_u9->save($z_qu_arr,$zq_u9_id);
  365. $this->zzququeu9_logs->insert([
  366. 'oid'=>$zq_u9_id,
  367. 'number'=>$number,
  368. 'one_type'=>$one_type,
  369. 'two_type'=>$two_type,
  370. 'apply_api'=>$apply_api,
  371. 'apply_data'=>json_encode($apply_data,JSON_UNESCAPED_UNICODE),
  372. 'ret_data'=>json_encode($ret_data,JSON_UNESCAPED_UNICODE),
  373. 'create_time'=>time(),
  374. 'read_time'=>date("Y-m-d H:i:s")
  375. ]);
  376. }
  377. //检查u9编码是否存在 如果不存在 请先添加并
  378. protected function checkLp($info,$token){
  379. //未注册的货品的列表
  380. $unregister_goods = [];
  381. $r = $this->apiyyv1->cxLp($info['list'],$token);
  382. if(!$r[0]['Success']){
  383. return $this->logic_tools->ret_arr(-1,'查询商品信息异常'.json_encode($r,JSON_UNESCAPED_UNICODE));
  384. }
  385. foreach($r[0]['Data'] as $k=>$v)
  386. {
  387. foreach($info['list'] as $kk => $vv){
  388. if($v['m_code'] == $vv['jm']){
  389. $info['list'][$kk]['is_register'] = 1;
  390. }
  391. }
  392. }
  393. foreach($info['list'] as $k => $v){
  394. if($v['is_register'] == 0){
  395. $unregister_goods[] = $v;
  396. }
  397. }
  398. if(empty($unregister_goods)){
  399. return $this->logic_tools->ret_arr(1,"料品无异常");
  400. }
  401. $tb_info = $info;
  402. $tb_info['list'] = $unregister_goods;
  403. // //return $this->tbXgLp($tb_info,$token);
  404. return $this->tbXgLp($tb_info);
  405. }
  406. //将许昌仓的料品同步到香港仓
  407. public function tbXgLp($tb_info){
  408. $rr = $this->apiyyv1->tbLp($tb_info,$this->getToken(130));
  409. if($rr[0]['Success']){
  410. return $this->logic_tools->ret_arr(1,$rr);
  411. }else{
  412. return $this->logic_tools->ret_arr(-1,$rr);
  413. }
  414. }
  415. }