proxy.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. use refill;
  3. use mtopcard;
  4. require_once (BASE_ROOT_PATH . '/helper/model_helper.php');
  5. class proxy
  6. {
  7. const max_retry = 5;
  8. const max_time_out = 120;
  9. public function add($params)
  10. {
  11. $refill_order = Model('refill_order');
  12. $mchid = $params['mchid'];
  13. $buyer_id = $params['buyer_id'];
  14. $amount = intval($params['amount']);
  15. $card_no = $params['card_no'];
  16. $mch_order = $params['mch_order'];
  17. $notify_url = $params['notify_url'];
  18. $idcard = $params['idcard'] ?? '';
  19. $card_name = $params['card_name'] ?? '';
  20. $order_time = $params['order_time'] ?? time();
  21. $commit_times = $params['commit_times'] ?? 0;
  22. $last_order_id = $params['order_id'] ?? 0;
  23. $org_quality = intval($params['org_quality']) ?? 0;
  24. $card_type = intval($params['card_type']) ?? 0;
  25. Log::record("proxy::add 1" ,Log::DEBUG);
  26. $need_check = false;
  27. if($card_type == 0)
  28. {
  29. $card_type = mtopcard\card_type($card_no);
  30. if($card_type != mtopcard\PetroChinaCard && $card_type != mtopcard\SinopecCard) {
  31. $need_check = true;
  32. }
  33. }
  34. Log::record("proxy::add 2" ,Log::DEBUG);
  35. [$org_quality,$quality] = refill\RefillFactory::instance()->find_quality($mchid,$amount,$card_type,$org_quality,$commit_times,time() - $order_time);
  36. Log::record("org_quality = {$org_quality} quality = {$quality}",Log::DEBUG);
  37. if ($need_check)
  38. {
  39. $valided = mtopcard\valid_phone($card_no);
  40. if (!$valided) {
  41. $order_id = refill\RefillFactory::instance()->zero_order($mchid, $buyer_id, $amount, $card_no,
  42. $mch_order, $idcard, $card_name, $notify_url, $quality, $org_quality, $order_time, $commit_times,
  43. "无效的手机号");
  44. QueueClient::push("NotifyMerchantComplete", ['order_id' => $order_id, 'manual' => false]);
  45. return;
  46. }
  47. }
  48. Log::record("proxy::add 3" ,Log::DEBUG);
  49. [$errcode, $errmsg, $order_id, $neterr] = refill\RefillFactory::instance()->add($mchid, $buyer_id, $amount, $card_no,
  50. $mch_order, $idcard, $card_name, $notify_url, $quality,$org_quality,
  51. $order_time, $commit_times, $last_order_id,$card_type);
  52. $params['commit_times'] += 1;
  53. $commit_times += 1;
  54. Log::record("proxy::add 4" ,Log::DEBUG);
  55. if($errcode !== true)
  56. {
  57. $fNotify = true;
  58. if(($errcode === refill\errcode::MERCHANT_REFILL_ERROR && $neterr) || $errcode == refill\errcode::PROVIDER_OVERLOAD)
  59. {
  60. [$org_quality,$quality] = refill\RefillFactory::instance()->find_quality($mchid,$amount,$card_type,$org_quality,$commit_times,time() - $order_time);
  61. if ($quality > 0) {
  62. $fNotify = false;
  63. $params['order_id'] = $order_id;
  64. if($order_id > 0) {
  65. $refill_order->edit($order_id, ['is_retrying' => 1]);
  66. }
  67. \Swoole\Coroutine::sleep(2);
  68. refill\util::push_add($params);
  69. }
  70. }
  71. if($fNotify)
  72. {
  73. if ($order_id === 0)
  74. {
  75. $order_info = $this->latest_order($refill_order, $mchid, $mch_order);
  76. if (empty($order_info)) {
  77. $order_id = refill\RefillFactory::instance()->zero_order($mchid, $buyer_id, $amount, $card_no,
  78. $mch_order, $idcard, $card_name, $notify_url, $quality, $org_quality, $order_time, $commit_times, $errmsg);
  79. } else {
  80. $order_id = $order_info['order_id'];
  81. }
  82. }
  83. else {
  84. $refill_order->edit($order_id, ['notify_time' => time(), 'notify_state' => 1]);
  85. }
  86. QueueClient::push("NotifyMerchantComplete", ['order_id' => $order_id,'manual' => false]);
  87. }
  88. }
  89. }
  90. private function latest_order($refill_order,$mchid,$mch_order)
  91. {
  92. $orders = $refill_order->getMerchantOrderList(['mchid' => $mchid,'mch_order' => $mch_order]);
  93. if(empty($orders)) {
  94. return [];
  95. }
  96. else {
  97. $orders[0];
  98. }
  99. }
  100. public function notify($channel,$input)
  101. {
  102. return refill\RefillFactory::instance()->notify($channel,$input);
  103. }
  104. public function notify_merchant($order_id,$manual)
  105. {
  106. return refill\RefillFactory::instance()->notify_merchant($order_id,$manual);
  107. }
  108. public function query($order_id)
  109. {
  110. return refill\RefillFactory::instance()->query($order_id);
  111. }
  112. }