Model_logic_u9mgwx.php 6.3 KB

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