Model_logic_u9zt.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450
  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. if(empty($dcd_res[0]['Data'][0]["Code"])){
  125. $this->editData($info['id'],['dc_status'=>-1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  126. return ;
  127. }
  128. //更新
  129. $dcd_no = $dcd_res[0]['Data'][0]["Code"];
  130. $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]);
  131. }
  132. //查询调出单是否审核 审核了 就更新
  133. public function cxDxcheck($info){
  134. $r = $this->apiyyv1->xdlsCxDcd($info['dc_no'],$this->getToken(130));
  135. if(empty($r[0]['Data'])){
  136. return ;
  137. }
  138. //更新销售单数据
  139. $xs_no = json_encode($r[0]['Data']);
  140. $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]);
  141. }
  142. //创建销售单 和 采购单
  143. public function createXsAndCg($info){
  144. $tmp_data = $info['dc_data'];
  145. if(empty($tmp_data)){
  146. return ;
  147. }
  148. $tmp_data = json_decode($info['dc_data'],true);
  149. if(empty($tmp_data)){
  150. return ;
  151. }
  152. $list = [];
  153. foreach($tmp_data as $key=>$val){
  154. $list[] = [
  155. 'jm'=>$val['iteminfo_itemcode'],
  156. 'zh'=>$val['iteminfo_itemname'],
  157. 'final_price'=>$val['costprice'],
  158. 'dcsl'=>$val['costuomqty'],
  159. ];
  160. }
  161. $time = time();
  162. $do_params = [
  163. 'gys'=>$this->gys,//供应商
  164. 'number'=>$info['order_no'],//erp订单编码
  165. "TransOutDocType_Code"=>"TransOut001",//组织间调拨
  166. "time"=>$time,
  167. 'TransferDirection'=>0,//普通
  168. 'yyid'=>$this->yyid,//来源店铺 这种需要在店铺表中有
  169. 'shipremarks'=>$tmp_data[0]['descflexfield_pubdescseg5'],//订单的备注
  170. 'dcckbm'=>$this->xccp_code,//调出仓库编码
  171. 'drckbm'=>$this->xgzt_code,//调入仓库编码
  172. 'drzz_code'=>$this->xgzzcode,//调入组织Code
  173. 'owner_code'=>$this->xczzcode,//货主组织Code
  174. 'ztcode'=>$this->ztcode,//账套
  175. 'tb_org_arr'=>$this->tb_org_arr,//要同步的组织列表
  176. 'list'=>$list
  177. ];
  178. //创建许昌成品库的销售单
  179. $xsd_res = $this->apiyyv1->xsdCreate($do_params,$this->getToken(130));
  180. if(empty($xsd_res[0]['Data'][0]['m_code'])){
  181. $this->editData($info['id'],['xs_status'=>-1,'update_time'=>time()],$info['order_no'],2,1,'xs',$xsd_res[1],$xsd_res[0]);
  182. return ;
  183. }
  184. //更新销售单数据
  185. $xs_no = $xsd_res[0]['Data'][0]["m_code"];
  186. $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]);
  187. //创建香港公司的采购单
  188. $cgd_res = $this->apiyyv1->cgdCreate($do_params,$this->getToken(140));
  189. if(empty($cgd_res[0]['Data'][0]["Code"])){
  190. $this->editData($info['id'],['cg_status'=>-1,'update_time'=>time()],$info['order_no'],3,1,'cg',$cgd_res[1],$cgd_res[0]);
  191. return ;
  192. }
  193. $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]);
  194. }
  195. //审核的调出单后 直接查询对应调入单 直接提交和审核
  196. public function cxDrByDc($info){
  197. $r = $this->apiyyv1->drdcxBydcd($info['dc_no'],$this->getToken(140));
  198. //如果获取对应调入单没有成功
  199. if(empty($r[0]['Data'][0]['docno'])){
  200. $this->editData($info['id'],['dr_status'=>-1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  201. return ;
  202. }
  203. $dr_no = $r[0]['Data'][0]["docno"];
  204. $this->editData($info['id'],['dr_no'=>$dr_no,'dr_status'=>1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  205. //提交调入单
  206. $rr = $this->apiyyv1->drdSubmit(['number'=>$dr_no],$this->getToken(140));
  207. if(!$rr[0]['Data'][0]['IsSucess']){
  208. $this->editData($info['id'],['dr_status'=>-2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  209. return;
  210. }
  211. $this->editData($info['id'],['dr_status'=>2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  212. //审核调入单
  213. $rrr = $this->apiyyv1->drdApprove(['number'=>$dr_no],$this->getToken(140));
  214. if(!$rrr[0]['Data'][0]['IsSucess']){
  215. $this->editData($info['id'],['dr_status'=>-3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  216. return;
  217. }
  218. $this->editData($info['id'],['dr_status'=>3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  219. }
  220. //提交和审核销售单
  221. public function shCgAndXs($info){
  222. $r = $this->apiyyv1->cgdSubmit([
  223. 'number'=>$info['cg_no']
  224. ],$this->getToken(140));
  225. if(!$r[0]['Data'][0]['IsSucess']){
  226. $this->editData($info['id'],['cg_status'=>-2,'update_time'=>time()],$info['order_no'],3,2,'cg',$r[1],$r[0]);
  227. return false;
  228. }
  229. //更新采购单
  230. $this->editData($info['id'],['cg_status'=>2,'update_time'=>time()],$info['order_no'],3,2,'cg',$r[1],$r[0]);
  231. $rr = $this->apiyyv1->cgdApprove([
  232. 'number'=>$info['cg_no']
  233. ],$this->getToken(140));
  234. if(!$rr[0]['Data'][0]['IsSucess']){
  235. $this->editData($info['id'],['cg_status'=>-3,'update_time'=>time()],$info['order_no'],3,3,'cg',$rr[1],$rr[0]);
  236. return false;
  237. }
  238. $this->editData($info['id'],['cg_status'=>3,'update_time'=>time()],$info['order_no'],3,3,'cg',$rr[1],$rr[0]);
  239. $r = $this->apiyyv1->xsdSubmit([
  240. 'number'=>$info['xs_no']
  241. ],$this->getToken(130));
  242. if(!$r[0]['Data'][0]['m_isSucess']){
  243. $this->editData($info['id'],['xs_status'=>-2,'update_time'=>time()],$info['order_no'],2,2,'xs',$r[1],$r[0]);
  244. return false;
  245. }
  246. $this->editData($info['id'],['xs_status'=>2,'update_time'=>time()],$info['order_no'],2,2,'xs',$r[1],$r[0]);
  247. $rr = $this->apiyyv1->xsdApprove([
  248. 'number'=>$info['xs_no']
  249. ],$this->getToken(130));
  250. if(!$rr[0]['Data'][0]['m_isSucess']){
  251. $this->editData($info['id'],['xs_status'=>-3,'update_time'=>time()],$info['order_no'],2,3,'xs',$rr[1],$rr[0]);
  252. return false;
  253. }
  254. $this->editData($info['id'],['xs_status'=>3,'update_time'=>time()],$info['order_no'],2,3,'xs',$rr[1],$rr[0]);
  255. return true;
  256. }
  257. //创建在途库存调入美仓的调出单
  258. public function createDcTwo($info){
  259. $time = time();
  260. $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");
  261. if(empty($tmp_list)){
  262. return ;
  263. }
  264. $tmp_info = $tmp_list[0];
  265. if(empty($tmp_info['dc_data'])){
  266. return ;
  267. }
  268. $tmp_data = json_decode($tmp_info['dc_data'],true);
  269. if(empty($tmp_data)){
  270. return ;
  271. }
  272. $dc_list = [];
  273. foreach($tmp_data as $key=>$val){
  274. $dc_list[] = [
  275. 'jm'=>$val['iteminfo_itemcode'],
  276. 'dcsl'=>$val['costuomqty'],
  277. ];
  278. }
  279. $dc_params = [
  280. 'gys'=>$this->gys,//供应商
  281. 'number'=>$info['order_no'],//erp订单编码
  282. "TransOutDocType_Code"=>"TransOut002",//仓库转储
  283. "time"=>$time,
  284. 'TransferDirection'=>0,//普通
  285. 'yyid'=>"",//来源店铺 这种需要在店铺表中有
  286. 'shipremarks'=>$tmp_data[0]['descflexfield_pubdescseg5'],//订单的备注
  287. 'dcckbm'=>$this->xgzt_code,//调出仓库编码 在途库
  288. 'drckbm'=>$this->xgmc_code,//调入仓库编码 美仓
  289. 'drzz_code'=>$this->xgzzcode,//调入组织Code
  290. 'owner_code'=>$this->xgzzcode,//货主组织Code
  291. 'ztcode'=>$this->ztcode,//账套
  292. 'tb_org_arr'=>$this->tb_org_arr,//要同步的组织列表
  293. 'list'=>$dc_list
  294. ];
  295. //创建调出单
  296. $dcd_res = $this->apiyyv1->dcdCrate($dc_params,$this->getToken(140));
  297. if(empty($dcd_res[0]['Data'][0]["Code"])){
  298. $this->editData($info['id'],['dc_status'=>-1,'update_time'=>time()],$info['order_no'],1,1,'dc',$dcd_res[1],$dcd_res[0]);
  299. return ;
  300. }
  301. //更新
  302. $dcd_no = $dcd_res[0]['Data'][0]["Code"];
  303. $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]);
  304. sleep(2);
  305. $info['dc_no'] = $dcd_no;
  306. $info['dc_status'] = 1;
  307. $r = $this->shDcTwo($info);
  308. if(!$r){
  309. return false;
  310. }
  311. sleep(2);
  312. $info['dc_status'] = 3;
  313. $r = $this->cxDcTwo($info);
  314. }
  315. //提交审核
  316. public function shDcTwo($info){
  317. $r = $this->apiyyv1->dcdSubmit([
  318. 'number'=>$info['dc_no']
  319. ],$this->getToken(140));
  320. if(!$r[0]['Data'][0]['IsSucess']){
  321. $this->editData($info['id'],['dc_status'=>-2,'update_time'=>time()],$info['order_no'],1,2,'dc',$r[1],$r[0]);
  322. return false;
  323. }
  324. //更新调出单
  325. $this->editData($info['id'],['dc_status'=>2,'update_time'=>time()],$info['order_no'],1,2,'dc',$r[1],$r[0]);
  326. $rr = $this->apiyyv1->dcdApprove([
  327. 'number'=>$info['dc_no']
  328. ],$this->getToken(140));
  329. if(!$rr[0]['Data'][0]['IsSucess']){
  330. $this->editData($info['id'],['dc_status'=>-3,'update_time'=>time()],$info['order_no'],1,3,'dc',$rr[1],$rr[0]);
  331. return false;
  332. }
  333. $this->editData($info['id'],['dc_status'=>3,'update_time'=>time()],$info['order_no'],1,3,'dc',$rr[1],$rr[0]);
  334. return true;
  335. }
  336. //查询调出单审核调出单 同时更新的
  337. public function cxDcTwo($info){
  338. $r = $this->apiyyv1->drdcxBydcd($info['dc_no'],$this->getToken(140));
  339. //如果获取对应调入单没有成功
  340. if(empty($r[0]['Data'][0]['docno'])){
  341. $this->editData($info['id'],['dr_status'=>-1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  342. return ;
  343. }
  344. $dr_no = $r[0]['Data'][0]["docno"];
  345. $this->editData($info['id'],['dr_no'=>$dr_no,'dr_status'=>1,'update_time'=>time()],$info['order_no'],6,1,'dr',$r[1],$r[0]);
  346. //提交调入单
  347. $rr = $this->apiyyv1->drdSubmit(['number'=>$dr_no],$this->getToken(140));
  348. if(!$rr[0]['Data'][0]['IsSucess']){
  349. $this->editData($info['id'],['dr_status'=>-2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  350. return;
  351. }
  352. $this->editData($info['id'],['dr_status'=>2,'update_time'=>time()],$info['order_no'],6,2,'dr',$rr[1],$rr[0]);
  353. //审核调入单
  354. $rrr = $this->apiyyv1->drdApprove(['number'=>$dr_no],$this->getToken(140));
  355. if(!$rrr[0]['Data'][0]['IsSucess']){
  356. $this->editData($info['id'],['dr_status'=>-3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  357. return;
  358. }
  359. $this->editData($info['id'],['dr_status'=>3,'update_time'=>time()],$info['order_no'],6,3,'dr',$rrr[1],$rrr[0]);
  360. }
  361. //根据返回的状态修改对应的值
  362. protected function editData($zq_u9_id,$z_qu_arr,$number,$one_type,$two_type,$apply_api,$apply_data,$ret_data){
  363. $this->zzquque_u9->save($z_qu_arr,$zq_u9_id);
  364. $this->zzququeu9_logs->insert([
  365. 'oid'=>$zq_u9_id,
  366. 'number'=>$number,
  367. 'one_type'=>$one_type,
  368. 'two_type'=>$two_type,
  369. 'apply_api'=>$apply_api,
  370. 'apply_data'=>json_encode($apply_data,JSON_UNESCAPED_UNICODE),
  371. 'ret_data'=>json_encode($ret_data,JSON_UNESCAPED_UNICODE),
  372. 'create_time'=>time(),
  373. 'read_time'=>date("Y-m-d H:i:s")
  374. ]);
  375. }
  376. //检查u9编码是否存在 如果不存在 请先添加并
  377. protected function checkLp($info,$token){
  378. //未注册的货品的列表
  379. $unregister_goods = [];
  380. $r = $this->apiyyv1->cxLp($info['list'],$token);
  381. if(!$r[0]['Success']){
  382. return $this->logic_tools->ret_arr(-1,'查询商品信息异常'.json_encode($r,JSON_UNESCAPED_UNICODE));
  383. }
  384. foreach($r[0]['Data'] as $k=>$v)
  385. {
  386. foreach($info['list'] as $kk => $vv){
  387. if($v['m_code'] == $vv['jm']){
  388. $info['list'][$kk]['is_register'] = 1;
  389. }
  390. }
  391. }
  392. foreach($info['list'] as $k => $v){
  393. if($v['is_register'] == 0){
  394. $unregister_goods[] = $v;
  395. }
  396. }
  397. if(empty($unregister_goods)){
  398. return $this->logic_tools->ret_arr(1,"料品无异常");
  399. }
  400. $tb_info = $info;
  401. $tb_info['list'] = $unregister_goods;
  402. // //return $this->tbXgLp($tb_info,$token);
  403. return $this->tbXgLp($tb_info);
  404. }
  405. //将许昌仓的料品同步到香港仓
  406. public function tbXgLp($tb_info){
  407. $rr = $this->apiyyv1->tbLp($tb_info,$this->getToken(130));
  408. if($rr[0]['Success']){
  409. return $this->logic_tools->ret_arr(1,$rr);
  410. }else{
  411. return $this->logic_tools->ret_arr(-1,$rr);
  412. }
  413. }
  414. }