Model_logic_u9mgwx.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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 (type = 22) 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. return ;
  38. //exit('没有需要处理的数据');
  39. }
  40. echo "<pre>";
  41. foreach($list as $k=>$v){
  42. $this->_mgxxdo_one($v,$start_time);
  43. }
  44. }
  45. private function _mgxxdo_one($info,$start_time){
  46. $tmp_list = $this->db->get_where('whlabel_bh_scan', [
  47. 'orderinfo' => $info['orderinfo'],
  48. 'scantime >=' => $start_time,
  49. 'status'=>0,
  50. ])->result_array();
  51. $goods_list = [];
  52. foreach($tmp_list as $k=>$v){
  53. if(isset($goods_list[$v['jm']])){
  54. $goods_list[$v['jm']]['dcsl'] += $v['sl'];
  55. }else{
  56. $goods_list[$v['jm']] = [
  57. 'jm'=>$v['jm'],
  58. 'pm'=>$v['pm'],
  59. 'dcsl'=>$v['sl'],
  60. 'final_price'=>1,//让财务录入价格
  61. ];
  62. }
  63. }
  64. echo "<pre>";
  65. print_r($goods_list);
  66. die;
  67. $final_list = array_values($goods_list);
  68. //避免一天内的东西被多次推送
  69. $order_number = $info['orderinfo']."_".date("md",time());
  70. $num = $this->db->where('order_no',$order_number)->from('zzquque_u9')->count_all_results();
  71. //如果已经存在,则不再处理
  72. if($num > 0){
  73. return ;
  74. }
  75. $this->db->insert('zzquque_u9',[
  76. 'type'=>22,
  77. 'order_no'=>$order_number,
  78. 'create_time'=>time(),
  79. 'update_time'=>time(),
  80. ]);
  81. //获取到相关信息的id
  82. $zzquque_u9_id = $this->db->insert_id();
  83. $this->db->where([
  84. 'orderinfo'=>$info['orderinfo'],
  85. 'scantime >= ' => $start_time,
  86. 'status'=>0,
  87. 'zzquque_u9_id'=>0,
  88. ])->update("whlabel_bh_scan",[
  89. 'status'=>1,
  90. 'update_time'=>time(),
  91. 'zzquque_u9_id'=>$zzquque_u9_id,
  92. ]);
  93. //创建要执行的队列信息
  94. $params = [
  95. 'yyid'=>'02031',
  96. 'number'=>$order_number,
  97. 'time'=>time(),
  98. 'list'=>$final_list,
  99. ];
  100. $xsd_res = $this->apiyyv1->xsdCreate($params,$this->getToken(130));
  101. if(empty($xsd_res[0]['Data'][0]['m_code'])){
  102. $this->editData($zzquque_u9_id,['xs_status'=>-1,'update_time'=>time()],$order_number,2,1,'xs',$xsd_res[1],$xsd_res[0]);
  103. return ;
  104. }
  105. //更新销售单数据
  106. $xs_no = $xsd_res[0]['Data'][0]["m_code"];
  107. $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]);
  108. }
  109. public function _cx_xsdandbzch($info){
  110. $res = $this->apiyyv1->xsdCxByNo($info['xs_no'],$this->getToken(130));
  111. //如果没审核 那么就不管
  112. if(empty($res[0]['Data'])){
  113. return ;
  114. }
  115. // 审核了
  116. $list = $res[0]['Data'];
  117. if($list[0]['status'] < 3){
  118. return ;
  119. }
  120. foreach($list as $k=>$v){
  121. $list[$k]['dcsl'] = $v['shipplanqtypu'];
  122. }
  123. $tmp_info = [
  124. 'zq_u9_id'=>$info['id'],
  125. 'drckbm'=> '13001',
  126. 'number'=>$info['order_no'],
  127. 'order_no'=>$info['order_no'],
  128. 'xs_no'=>$info['xs_no'],
  129. 'xs_two_no'=>$info['xs_no'],
  130. 'list'=>$list
  131. ];
  132. $res = $this->apiyyv1->bzchCreate($tmp_info,$this->getToken(130));
  133. if($res[0]['Data'][0]['m_isSucess'] != 1){
  134. $this->editData($info['id'],['bzch_status'=>-1,'update_time'=>time()],$info['order_no'],5,1,'bzch',$res[1],$res[0]);
  135. return $this->logic_tools->ret_arr(-1,"标准出库的信息异常,请查看");
  136. }else{
  137. $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]);
  138. return $this->logic_tools->ret_arr(1,"标准出库创建成功");
  139. }
  140. }
  141. //对标准出货单进行审核
  142. public function checkBzch($info){
  143. $res = $this->apiyyv1->bzchSubmitAndApprove(['number'=>$info['bzch_no']],$this->getToken(120));
  144. // print_r($res[0]);
  145. // print_r($res[1]);
  146. if($res[0]['Data'][0]['m_isSucess'] != 1){
  147. $this->editData($info['id'],['bzch_status'=>-2,'update_time'=>time()],$info['order_no'],5,2,'bzch_sh',$res[1],$res[0]);
  148. }else{
  149. $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]);
  150. }
  151. }
  152. protected function editData($zq_u9_id,$z_qu_arr,$number,$one_type,$two_type,$apply_api,$apply_data,$ret_data){
  153. $this->zzquque_u9->save($z_qu_arr,$zq_u9_id);
  154. $this->zzququeu9_logs->insert([
  155. 'oid'=>$zq_u9_id,
  156. 'number'=>$number,
  157. 'one_type'=>$one_type,
  158. 'two_type'=>$two_type,
  159. 'apply_api'=>$apply_api,
  160. 'apply_data'=>json_encode($apply_data,JSON_UNESCAPED_UNICODE),
  161. 'ret_data'=>json_encode($ret_data,JSON_UNESCAPED_UNICODE),
  162. 'create_time'=>time(),
  163. 'read_time'=>date("Y-m-d H:i:s")
  164. ]);
  165. }
  166. }