minutes.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. <?php
  2. /**
  3. * 任务计划 - 分钟执行的任务
  4. *
  5. *
  6. *
  7. *
  8. */
  9. defined('InShopNC') or exit('Access Invalid!');
  10. class minutesControl extends BaseCronControl
  11. {
  12. public function indexOp()
  13. {
  14. Log::record(__FUNCTION__ . " start",Log::DEBUG);
  15. //未付款订单超期自动关闭
  16. $this->_order_timeout_cancel();
  17. $this->_cron_common();
  18. $this->_web_index_update();
  19. $this->_cron_mail_send();
  20. Log::record(__FUNCTION__ . " end",Log::DEBUG);
  21. }
  22. /**
  23. * 未付款订单超期自动关闭
  24. */
  25. private function _order_timeout_cancel()
  26. {
  27. Log::record(__FUNCTION__,Log::DEBUG);
  28. //实物订单超期未支付系统自动关闭
  29. $_break = false;
  30. $model_order = Model('order');
  31. $logic_order = Logic('order');
  32. $condition = array();
  33. $condition['order_state'] = ORDER_STATE_NEW;
  34. $condition['add_time'] = array('lt',time() - ORDER_AUTO_CANCEL_DAY * 86400);
  35. //分批,每批处理100个订单,最多处理5W个订单
  36. for ($i = 0; $i < 500; $i++)
  37. {
  38. if ($_break) {
  39. break;
  40. }
  41. $order_list = $model_order->getOrderList($condition, '', '*', '', 100);
  42. if (empty($order_list)) break;
  43. foreach ($order_list as $order_info)
  44. {
  45. Log::record("1",Log::DEBUG);
  46. $result = $logic_order->changeOrderStateCancel($order_info,'system','系统','超期未支付系统自动关闭订单',true,false);
  47. Log::record("2",Log::DEBUG);
  48. if (!$result['state']) {
  49. $this->log('实物订单超期未支付关闭失败SN:'.$order_info['order_sn']); $_break = true; break;
  50. } else {
  51. Log::record("3",Log::DEBUG);
  52. account_helper::onPredeposit('order_cancel',$order_info['buyer_id'],$order_info['order_sn']);
  53. Log::record("4",Log::DEBUG);
  54. }
  55. }
  56. }
  57. //虚拟订单超期未支付系统自动关闭
  58. $_break = false;
  59. $model_vr_order = Model('vr_order');
  60. $logic_vr_order = Logic('vr_order');
  61. $condition = array();
  62. $condition['order_state'] = ORDER_STATE_NEW;
  63. $condition['add_time'] = array('lt',time() - ORDER_AUTO_CANCEL_DAY * self::EXE_TIMES);
  64. //分批,每批处理100个订单,最多处理5W个订单
  65. for ($i = 0; $i < 500; $i++)
  66. {
  67. if ($_break) {
  68. break;
  69. }
  70. $order_list = $model_vr_order->getOrderList($condition, '', '*', '',100);
  71. if (empty($order_list)) break;
  72. foreach ($order_list as $order_info) {
  73. $result = $logic_vr_order->changeOrderStateCancel($order_info,'system','超期未支付系统自动关闭订单',false);
  74. }
  75. if (!$result['state']) {
  76. $this->log('虚拟订单超期未支付关闭失败SN:'.$order_info['order_sn']); $_break = true; break;
  77. }
  78. }
  79. }
  80. /**
  81. * 更新首页的商品价格信息
  82. */
  83. private function _web_index_update()
  84. {
  85. Model('web_config')->updateWebGoods();
  86. }
  87. /**
  88. * 发送邮件消息
  89. */
  90. private function _cron_mail_send()
  91. {
  92. //每次发送数量
  93. $_num = 50;
  94. $model_storemsgcron = Model('mail_cron');
  95. $cron_array = $model_storemsgcron->getMailCronList(array(), $_num);
  96. if (!empty($cron_array))
  97. {
  98. $email = new Email();
  99. $mail_array = array();
  100. foreach ($cron_array as $val)
  101. {
  102. $return = $email->send_sys_email($val['mail'],$val['subject'],$val['contnet']);
  103. if ($return) {
  104. // 记录需要删除的id
  105. $mail_array[] = $val['mail_id'];
  106. }
  107. }
  108. // 删除已发送的记录
  109. $model_storemsgcron->delMailCron(array('mail_id' => array('in', $mail_array)));
  110. }
  111. }
  112. /**
  113. * 执行通用任务
  114. */
  115. private function _cron_common()
  116. {
  117. Log::record(__FUNCTION__,Log::DEBUG);
  118. //查找待执行任务
  119. $model_cron = Model('cron');
  120. $cron = $model_cron->getCronList(array('exetime'=>array('elt',time())));
  121. if (!is_array($cron)) return ;
  122. $cron_array = array();
  123. $cronid = array();
  124. foreach ($cron as $v) {
  125. $cron_array[$v['type']][$v['exeid']] = $v;
  126. }
  127. foreach ($cron_array as $k=>$v)
  128. {
  129. // 如果方法不存是,直接删除id
  130. if (!method_exists($this,'_cron_'.$k)) {
  131. $tmp = current($v);
  132. $cronid[] = $tmp['id'];
  133. continue;
  134. }
  135. $method = '_cron_'.$k;
  136. Log::record("crontab minutest err:{$method}",Log::DEBUG);
  137. $result = call_user_func_array(array($this,'_cron_'.$k),array($v));
  138. if (is_array($result)){
  139. $cronid = array_merge($cronid,$result);
  140. }
  141. else {
  142. $method = '_cron_'.$k;
  143. Log::record("crontab minutest err:{$method}",Log::ERR);
  144. }
  145. }
  146. //删除执行完成的cron信息
  147. if (!empty($cronid) && is_array($cronid)){
  148. $model_cron->delCron(array('id'=>array('in',$cronid)));
  149. }
  150. }
  151. //'任务类型 1商品上架 2根据商品id更新商品促销价格 3优惠套装过期 4推荐展位过期 5团购开始更新商品促销价格 6团购过期 7限时折扣过期',
  152. //1商品上架
  153. private function _cron_1($cron = array())
  154. {
  155. $condition = array('goods_commonid' => array('in',array_keys($cron)));
  156. $update = Model('goods')->editProducesOnline($condition);
  157. if ($update){
  158. //返回执行成功的cronid
  159. $cronid = array();
  160. foreach ($cron as $v) {
  161. $cronid[] = $v['id'];
  162. }
  163. } else {
  164. return false;
  165. }
  166. return $cronid;
  167. }
  168. //2根据商品id更新商品促销价格
  169. private function _cron_2($cron = array())
  170. {
  171. $condition = array('goods_id' => array('in',array_keys($cron)));
  172. $update = Model('goods')->editGoodsPromotionPrice($condition);
  173. if ($update){
  174. //返回执行成功的cronid
  175. $cronid = array();
  176. foreach ($cron as $v) {
  177. $cronid[] = $v['id'];
  178. }
  179. }else{
  180. return false;
  181. }
  182. return $cronid;
  183. }
  184. //3优惠套装过期
  185. private function _cron_3($cron = array())
  186. {
  187. $condition = array('store_id' => array('in', array_keys($cron)));
  188. $update = Model('p_bundling')->editBundlingQuotaClose($condition);
  189. if ($update) {
  190. //返回执行成功的cronid
  191. $cronid = array();
  192. foreach ($cron as $v) {
  193. $cronid[] = $v['id'];
  194. }
  195. } else {
  196. return false;
  197. }
  198. return $cronid;
  199. }
  200. //4推荐展位过期
  201. private function _cron_4($cron = array())
  202. {
  203. $condition = array('store_id' => array('in', array_keys($cron)));
  204. $update = Model('p_booth')->editBoothClose($condition);
  205. if ($update) {
  206. //返回执行成功的cronid
  207. $cronid = array();
  208. foreach ($cron as $v) {
  209. $cronid[] = $v['id'];
  210. }
  211. } else {
  212. return false;
  213. }
  214. return $cronid;
  215. }
  216. //5团购开始更新商品促销价格
  217. private function _cron_5($cron = array())
  218. {
  219. $condition = array();
  220. $condition['goods_commonid'] = array('in', array_keys($cron));
  221. $condition['start_time'] = array('lt', time());
  222. $condition['end_time'] = array('gt', time());
  223. $groupbuy = Model('groupbuy')->getGroupbuyList($condition);
  224. foreach ($groupbuy as $val) {
  225. Model('goods')->editGoods(array('goods_promotion_price' => $val['groupbuy_price'], 'goods_promotion_type' => 1), array('goods_commonid' => $val['goods_commonid']));
  226. }
  227. //返回执行成功的cronid
  228. $cronid = array();
  229. foreach ($cron as $v) {
  230. $cronid[] = $v['id'];
  231. }
  232. return $cronid;
  233. }
  234. /**
  235. * 抢购过期
  236. *
  237. * @param array $cron
  238. */
  239. private function _cron_6($cron = array())
  240. {
  241. $condition = array('goods_commonid' => array('in', array_keys($cron)));
  242. //抢购活动过期
  243. $update = Model('groupbuy')->editExpireGroupbuy($condition);
  244. if ($update){
  245. //返回执行成功的cronid
  246. $cronid = array();
  247. foreach ($cron as $v) {
  248. $cronid[] = $v['id'];
  249. }
  250. }else{
  251. return false;
  252. }
  253. return $cronid;
  254. }
  255. /**
  256. * 限时折扣过期
  257. *
  258. * @param array $cron
  259. */
  260. private function _cron_7($cron = array())
  261. {
  262. $condition = array('xianshi_id' => array('in', array_keys($cron)));
  263. //限时折扣过期
  264. $update = Model('p_xianshi')->editExpireXianshi($condition);
  265. if ($update){
  266. //返回执行成功的cronid
  267. $cronid = array();
  268. foreach ($cron as $v) {
  269. $cronid[] = $v['id'];
  270. }
  271. }else{
  272. return false;
  273. }
  274. return $cronid;
  275. }
  276. }