Queueu9.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. <?php defined('BASEPATH') OR exit('No direct script access allowed');
  2. /**
  3. * 该类执行队列使用
  4. */
  5. class Queueu9 extends Start_Controller {
  6. private $url = "http://git.wepolicy.cn/";
  7. private $api = 20250217;
  8. public function __construct(){
  9. parent::__construct();
  10. $this->load->_model("Model_zzquque_u9",'zzquque_u9');
  11. $this->load->_model("Model_aaconf","aaconf");
  12. $this->load->_model("Model_logic_u9xg",'logic_u9xg');
  13. $this->load->_model("Model_logic_order","logic_order");
  14. $this->load->_model("Model_logic_u9zt","logic_u9zt");
  15. $this->load->_model('Model_classid','classid');
  16. $this->load->_model('Model_typeclass','typeclass');
  17. $this->load->_model("Model_logic_u9mgwx","logic_u9mgwx");
  18. $this->load->_model("Model_settingtest","settingtest");
  19. }
  20. //定义方法的调用规则 获取URI第二段值
  21. public function _remap($arg,$arg_array)
  22. {
  23. $api = $this->input->get('api',true);
  24. if($api != $this->api){
  25. exit('No direct script access allowed');
  26. }
  27. if($arg == 'xdls')//执行小单的流转到临时仓的队列
  28. {
  29. $this->_xdls();
  30. }
  31. else if($arg == 'ztdl')//执行在途的队列
  32. {
  33. $this->_zt();
  34. }
  35. else if($arg == 'mgxxdo'){
  36. $this->_mgxxdo();
  37. }else if($arg == 'doxcbh'){
  38. $this->_doXcBh();
  39. }
  40. else
  41. {
  42. $this->_index();
  43. }
  44. }
  45. public function _index(){
  46. // echo "<pre>";
  47. // $user_agent = $_SERVER['HTTP_USER_AGENT'];
  48. // $token = $_SERVER['HTTP_X_AUTH_TOKEN'];
  49. // $time = $this->input->get('time',true);
  50. // $check_str = "ququexd_".$time;
  51. // if(empty($user_agent)){
  52. // exit('No direct script access allowed');
  53. // }
  54. // if($user_agent != 'XuChangLongYi/1.0 (Erp)'){
  55. // exit('Illegal request');
  56. // }
  57. // if(empty($token)){
  58. // exit('No access permission');
  59. // }
  60. // $sercet_str = md5($check_str);
  61. // if($sercet_str != $token){
  62. // exit("Request permission is illegal");
  63. // }
  64. // exit("执行完毕");
  65. }
  66. //执行小单的流转到临时仓的队列
  67. public function _xdls(){
  68. $start_time = time() - 20 * 24 * 60 * 60;
  69. //第一步生成 许昌成品库的调出单
  70. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 0 and cg_status = 0 and xs_status = 0 and create_time >= ".$start_time,'*','id asc');
  71. $do_list = [];
  72. foreach($list as $k=>$v){
  73. $tmp_info = $this->logic_order->getInfoByPlat($v['platform'],$v['order_no']);
  74. $tmp_info['zq_u9_id'] = $v['id'];
  75. $do_list[] = $tmp_info;
  76. }
  77. $this->logic_u9xg->xdlsOneStep($do_list);
  78. //新加一步 查询修改调出单的审核结果
  79. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 1 and cg_status = 0 and xs_status = 0 and create_time >= ".$start_time,'*','id asc');
  80. $this->logic_u9xg->xdlsOneExtraStep($list);
  81. //var_dump($list);
  82. //第二步 创建的采购单和销售单
  83. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and dc_data_status = 1 and cg_status = 0 and xs_status = 0 and create_time >= ".$start_time);
  84. // var_dump($list);
  85. // die;
  86. //var_dump($list);
  87. $this->logic_u9xg->xdlsTwoStep($list);
  88. //审核销售单和采购单
  89. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and dc_data_status = 1 and cg_status = 1 and xs_status = 1 and create_time >= ".$start_time);
  90. //var_dump($list);
  91. $this->logic_u9xg->xdlsTwoExtraStep($list);
  92. sleep(3);
  93. //第三步 查询调出单生成的调入单是否生成 如果生成了就审核 如果没生成 说明异常了 这种都是按步骤走的
  94. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and cg_status = 3 and xs_status = 3 and dr_status = 0 and create_time >= ".$start_time);
  95. $this->logic_u9xg->xdlsThreeStep($list);
  96. //第四步 建立香港的销售单 标准出库单有源的需要先审核 先创建销售单
  97. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and cg_status = 3 and xs_status = 3 and dr_status = 3 and xs_two_status = 0 and create_time >= ".$start_time);
  98. $do_list = [];
  99. foreach($list as $k=>$v){
  100. $tmp_info = $this->logic_order->getInfoByPlat($v['platform'],$v['order_no']);
  101. $tmp_info['zq_u9_id'] = $v['id'];
  102. $tmp_info['dc_no'] = $v['dc_no'];
  103. $tmp_info['dc_data'] = $v['dc_data'];
  104. $do_list[] = $tmp_info;
  105. }
  106. $this->logic_u9xg->xdlsFourStep($do_list);
  107. //执行第五步骤 审核销售单 并同时生成标准出货单
  108. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and cg_status = 3 and xs_status = 3 and dr_status = 3 and xs_two_status = 1 and bzch_status = 0 and create_time >= ".$start_time);
  109. if(!empty($list)){
  110. $this->logic_u9xg->xdlsFiveStep($list);
  111. }
  112. sleep(3);
  113. $list = $this->zzquque_u9->find_all("type = 10 and dc_status = 3 and cg_status = 3 and xs_status = 3 and dr_status = 3 and xs_two_status = 3 and bzch_status = 1 and create_time >= ".$start_time);
  114. $this->logic_u9xg->xdlsSixStep($list);
  115. }
  116. public function _zt(){
  117. echo "<pre>";
  118. $classid = $this->classid->sku();
  119. $tcall = $this->typeclass->find_all();
  120. foreach ($tcall as $v)
  121. {
  122. $tcjm[$v['id']] = array($v['jm'],$v['classid']);
  123. $typeclass[$v['id']] = array('zh'=>$v['zh'],'classid'=>$v['classid'],'bm'=>$v['bm'],'title'=>$v['title'],'jm'=>$v['jm']);
  124. }
  125. //第一步生成 许昌成品库的调出单
  126. $list = $this->zzquque_u9->find_all("type = 1 and dc_status = 0 and cg_status = 0 and xs_status = 0 ",'*','id asc',0,5);
  127. //ZT250314172219
  128. // $list = $this->zzquque_u9->find_all("order_no = 'ZT250314173250' and cg_status = 0 and xs_status = 0 ",'*','id asc',0,1);
  129. foreach($list as $k=>$v){
  130. $this->logic_u9zt->createdDc($v,$classid,$typeclass);
  131. }
  132. //第二步查询调出但状态
  133. $list = $this->zzquque_u9->find_all("type = 1 and dc_status = 1 and cg_status = 0 and xs_status = 0 ",'*','id asc');
  134. foreach($list as $k=>$v){
  135. $this->logic_u9zt->cxDxcheck($v);
  136. }
  137. //第三步创建销售单和采购单
  138. $list = $this->zzquque_u9->find_all("type = 1 and dc_status = 3 and dc_data_status = 1 and cg_status = 0 and xs_status = 0 ",'*','id asc');
  139. foreach($list as $k=>$v){
  140. $this->logic_u9zt->createXsAndCg($v);
  141. }
  142. sleep(2);
  143. //第四部查询调出单产生的调入单
  144. $list = $this->zzquque_u9->find_all("type = 1 and dc_status = 3 and dc_data_status = 1 and cg_status = 1 and xs_status = 1 and dr_status = 0 ",'*','id asc');
  145. foreach($list as $k=>$v){
  146. $this->logic_u9zt->cxDrByDc($v);
  147. }
  148. //第五步审核产生的销售单和采购单
  149. $list = $this->zzquque_u9->find_all("type = 1 and dc_status = 3 and dc_data_status = 1 and cg_status = 1 and xs_status = 1 and dr_status = 3 ",'*','id asc');
  150. foreach($list as $k=>$v){
  151. $this->logic_u9zt->shCgAndXs($v);
  152. }
  153. //第六步更新在途库存
  154. $list = $this->zzquque_u9->find_all("type = 2 and dc_status = 0 and dc_data_status = 0 and dr_status = 0 ",'*','id asc');
  155. foreach($list as $k=>$v){
  156. $this->logic_u9zt->createDcTwo($v);
  157. }
  158. }
  159. //定时执行美国销售
  160. private function _mgxxdo(){
  161. $this->logic_u9mgwx->doaction();
  162. }
  163. //执行许昌备货的调入单查询
  164. private function _doXcBh(){
  165. $this->db->select("dcd_no,status");
  166. $this->db->from("bhdcd");
  167. $this->db->where("status",0);
  168. $this->db->group_by('dcd_no');
  169. $query = $this->db->get();
  170. $rows = $query->result_array();
  171. echo "<pre>";
  172. foreach($rows as $row){
  173. $token = $this->settingtest->get_yytoken_120();
  174. $dcd_no = $row['dcd_no'];
  175. $res = $this->apiyyv1->drdcxBydcd($dcd_no,$token);
  176. if(!empty($res[0]['Data'])){
  177. if(!empty($res[0]['Data'][0]['docno']) && !empty($res[0]['Data'][0]['srcdocinfo_srcdocno'])){
  178. $u9_dcd_no = $res[0]['Data'][0]['srcdocinfo_srcdocno'];
  179. $u9_drd_no = $res[0]['Data'][0]['docno'];
  180. if($u9_dcd_no == $dcd_no){
  181. $this->db->where('dcd_no',$dcd_no);
  182. $this->db->update('bhdcd',[
  183. 'drd_no' => $u9_drd_no,
  184. 'status'=>1,
  185. ]);
  186. }
  187. usleep(100);
  188. }
  189. }
  190. }
  191. $this->db->select("dcd_no,status,drd_no");
  192. $this->db->from("bhdcd");
  193. $this->db->where("status",1);
  194. $this->db->group_by('dcd_no');
  195. $query = $this->db->get();
  196. $rows = $query->result_array();
  197. foreach($rows as $row){
  198. $drd_no = $row['drd_no'];
  199. $token = $this->settingtest->get_yytoken_120();
  200. $res = $this->apiyyv1->drdcxBydrd($drd_no,$token);
  201. if(!empty($res[0]['Data'])){
  202. if(!empty($res[0]['Data'][0])){
  203. if(!empty($res[0]['Data'][0]['docno'])){
  204. $u9_status = $res[0]['Data'][0]['status'];
  205. $u9_drd_no = $res[0]['Data'][0]['docno'];
  206. if($u9_status == 2){
  207. if($u9_drd_no == $drd_no){
  208. $this->db->where('drd_no',$drd_no);
  209. $this->db->update('bhdcd',[
  210. 'status'=>2,
  211. ]);
  212. }
  213. }
  214. }
  215. }
  216. }
  217. usleep(100);
  218. }
  219. echo "SUCCESS";
  220. }
  221. }