Model_logic_u9mgwx.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <?php
  2. /**
  3. * 系统自动处理在途库存的香港问题
  4. */
  5. class Model_logic_u9mgwx extends Lin_Model {
  6. //切记要修改token_120的token真正的token!!!!
  7. function __construct(){
  8. parent::__construct();
  9. $this->load->_model('Model_settingtest','settingtest');
  10. $this->load->_model("Model_apiyyv1","apiyyv1");
  11. $this->load->_model("Model_zzquque_u9","zzquque_u9");
  12. }
  13. public function getToken($type){
  14. $name = "get_yytoken_".$type;
  15. $token = $this->settingtest->$name();
  16. return $token;
  17. }
  18. /**
  19. * 工厂加工生产外销的订单
  20. */
  21. public function doaction(){
  22. $this->_add_xsd();
  23. sleep(2);
  24. $list = $this->zzquque_u9->find_all("( xs_status > 0 ) and ( bzch_status = 0 )");
  25. foreach($list as $k=>$v){
  26. $this->_cx_xsdandbzch($v);
  27. }
  28. }
  29. // 第一步 创建销售单
  30. private function _add_xsd(){
  31. $start_time = strtotime(date('Y-m-d',time()));
  32. $list = $this->db->select("id,orderinfo")->where(
  33. ['scantime >=' => $start_time,]
  34. )->from('whlabel_bh_scan')->group_by('orderinfo')->get();
  35. $list= $list->result_array();
  36. if(empty($list)){
  37. exit('没有需要处理的数据');
  38. }
  39. echo "<pre>";
  40. foreach($list as $k=>$v){
  41. $this->_mgxxdo_one($v,$start_time);
  42. }
  43. }
  44. private function _mgxxdo_one($info,$start_time){
  45. $tmp_list = $this->db->get_where('whlabel_bh_scan', [
  46. 'orderinfo' => $info['orderinfo'],
  47. 'scantime >=' => $start_time,
  48. ])->result_array();
  49. $goods_list = [];
  50. foreach($tmp_list as $k=>$v){
  51. if(isset($goods_list[$v['jm']])){
  52. $goods_list[$v['jm']]['dcsl'] += 1;
  53. }else{
  54. $goods_list[$v['jm']] = [
  55. 'jm'=>$v['jm'],
  56. 'pm'=>$v['pm'],
  57. 'dcsl'=>1,
  58. 'final_price'=>1,//让财务录入价格
  59. ];
  60. }
  61. }
  62. $final_list = array_values($goods_list);
  63. //避免一天内的东西被多次推送
  64. $order_number = $info['orderinfo']."_".date("md",time());
  65. $num = $this->db->where('order_no',$order_number)->from('zzquque_u9')->count_all_results();
  66. //如果已经存在,则不再处理
  67. if($num > 0){
  68. return ;
  69. }
  70. $this->db->insert('zzquque_u9',[
  71. 'type'=>22,
  72. 'order_no'=>$order_number,
  73. 'create_time'=>time(),
  74. 'update_time'=>time(),
  75. ]);
  76. //获取到相关信息的id
  77. $zzquque_u9_id = $this->db->insert_id();
  78. $this->db->where([
  79. 'orderinfo'=>$info['orderinfo'],
  80. 'scantime >= ' => $start_time,
  81. 'status'=>0,
  82. 'zzquque_u9_id'=>0,
  83. ])->update("whlabel_bh_scan",[
  84. 'status'=>1,
  85. 'update_time'=>time(),
  86. 'zzquque_u9_id'=>$zzquque_u9_id,
  87. ]);
  88. //创建要执行的队列信息
  89. $params = [
  90. 'yyid'=>'02031',
  91. 'number'=>$order_number,
  92. 'time'=>time(),
  93. 'list'=>$final_list,
  94. ];
  95. $xsd_res = $this->apiyyv1->xsdCreate($params,$this->getToken(130));
  96. if(empty($xsd_res[0]['Data'][0]['m_code'])){
  97. $this->editData($zzquque_u9_id,['xs_status'=>-1,'update_time'=>time()],$order_number,2,1,'xs',$xsd_res[1],$xsd_res[0]);
  98. return ;
  99. }
  100. //更新销售单数据
  101. $xs_no = $xsd_res[0]['Data'][0]["m_code"];
  102. $this->editData($zzquque_u9_id,['xs_no'=>$xs_no,'xs_status'=>1,'update_time'=>time()],$order_number,2,1,'xs',$xsd_res[1],$xsd_res[0]);
  103. }
  104. public function _cx_xsdandbzch($info){
  105. $res = $this->apiyyv1->xsdCxByNo($info['xs_no'],$this->getToken(130));
  106. //如果没审核 那么就不管
  107. if(empty($res[0]['Data'])){
  108. return ;
  109. }
  110. // 审核了
  111. $list = $res[0]['Data'];
  112. if($list[0]['status'] < 3){
  113. return ;
  114. }
  115. foreach($list as $k=>$v){
  116. $list[$k]['dcsl'] = $v['shipplanqtypu'];
  117. }
  118. $tmp_info = [
  119. 'zq_u9_id'=>$info['id'],
  120. 'drckbm'=> '13001',
  121. 'number'=>$info['order_no'],
  122. 'order_no'=>$info['order_no'],
  123. 'xs_no'=>$info['xs_no'],
  124. 'xs_two_no'=>$info['xs_no'],
  125. 'list'=>$list
  126. ];
  127. $res = $this->apiyyv1->bzchCreate($tmp_info,$this->getToken(130));
  128. if($res[0]['Data'][0]['m_isSucess'] != 1){
  129. $this->editData($info['id'],['bzch_status'=>-1,'update_time'=>time()],$info['order_no'],5,1,'bzch',$res[1],$res[0]);
  130. return $this->logic_tools->ret_arr(-1,"标准出库的信息异常,请查看");
  131. }else{
  132. $this->editData($info['id'],['bzch_no'=>$res[0]['Data'][0]['m_code'],'bzch_status'=>1,'xs_status'=>3,'update_time'=>time()],$info['order_no'],5,1,'bzch',$res[1],$res[0]);
  133. return $this->logic_tools->ret_arr(1,"标准出库创建成功");
  134. }
  135. }
  136. //对标准出货单进行审核
  137. public function checkBzch($info){
  138. $res = $this->apiyyv1->bzchSubmitAndApprove(['number'=>$info['bzch_no']],$this->getToken(120));
  139. // print_r($res[0]);
  140. // print_r($res[1]);
  141. if($res[0]['Data'][0]['m_isSucess'] != 1){
  142. $this->editData($info['id'],['bzch_status'=>-2,'update_time'=>time()],$info['order_no'],5,2,'bzch_sh',$res[1],$res[0]);
  143. }else{
  144. $this->editData($info['id'],['bzch_no'=>$res[0]['Data'][0]['m_code'],'bzch_status'=>3,'update_time'=>time()],$info['order_no'],5,2,'bzch_sh',$res[1],$res[0]);
  145. }
  146. }
  147. protected function editData($zq_u9_id,$z_qu_arr,$number,$one_type,$two_type,$apply_api,$apply_data,$ret_data){
  148. $this->zzquque_u9->save($z_qu_arr,$zq_u9_id);
  149. $this->zzququeu9_logs->insert([
  150. 'oid'=>$zq_u9_id,
  151. 'number'=>$number,
  152. 'one_type'=>$one_type,
  153. 'two_type'=>$two_type,
  154. 'apply_api'=>$apply_api,
  155. 'apply_data'=>json_encode($apply_data,JSON_UNESCAPED_UNICODE),
  156. 'ret_data'=>json_encode($ret_data,JSON_UNESCAPED_UNICODE),
  157. 'create_time'=>time(),
  158. 'read_time'=>date("Y-m-d H:i:s")
  159. ]);
  160. }
  161. }