lzrefill.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. <?php
  2. class lzrefillControl extends lzbaseControl
  3. {
  4. public function __construct()
  5. {
  6. parent::__construct();
  7. }
  8. public function goodsOp()
  9. {
  10. $result = refill\RefillFactory::instance()->goods();
  11. $sorter = function (array $items) {
  12. $ret = [];
  13. foreach ($items as $key => $val) {
  14. sort($val);
  15. $ret[$key] = $val;
  16. }
  17. return $ret;
  18. };
  19. $result = $sorter($result);
  20. return self::outsuccess($result);
  21. }
  22. private function check_params($params)
  23. {
  24. if(empty($params['mob'])) {
  25. return -9;
  26. }
  27. if(empty($params['amt'])) {
  28. return -9;
  29. }
  30. $card_no = $params['mob'];
  31. if(empty($card_no)) {
  32. return -11;
  33. }
  34. if(empty($params['notifyurl'])) {
  35. return -9;
  36. }
  37. if(empty($params['ord'])) {
  38. return -9;
  39. }
  40. if(empty($params['tim'])) {
  41. return -9;
  42. }
  43. $tim = strtotime($params['tim']);
  44. if($tim === false) {
  45. return -9;
  46. }
  47. $cur = time();
  48. $start = strtotime(date('Y-m-d',$cur - 1800));
  49. if($tim < $start || $tim > $cur + 1800) {
  50. return -9;
  51. }
  52. return true;
  53. }
  54. public function add_mobOp()
  55. {
  56. $code = $this->check_params($_GET);
  57. if($code !== true) {
  58. return self::outerr($code,$this->merchant_available);
  59. }
  60. $amount = intval($_GET['amt']);
  61. $card_no = $_GET['mob'];
  62. $notify_url = $_GET['notifyurl'];
  63. $mch_order = $_GET['ord']; //对方的order编号
  64. $quality = $_GET['quality'] ?? 0;
  65. //此处判断是对的
  66. if($amount > $this->member_available) {
  67. return self::outerr(4,$this->merchant_available);
  68. }
  69. if(!$this->check_mchorder($this->mchid(),$mch_order)) {
  70. return self::outerr(11,$this->merchant_available);
  71. }
  72. // if(!$this->can_refill($card_no)) {
  73. // return self::outerr(10,$this->merchant_available);
  74. // }
  75. $params = [ 'mchid' => $this->mchid(),
  76. 'buyer_id' => $this->adminid(),
  77. 'amount' => $amount,
  78. 'card_no' => $card_no,
  79. 'mch_order' => $mch_order,
  80. 'notify_url' => $notify_url,
  81. 'org_quality' => $quality
  82. ];
  83. $ret = refill\util::push_add($params);
  84. if ($ret) {
  85. refill\util::push_queue_order($this->mchid(), $mch_order, ORDER_STATE_QUEUE);
  86. return self::outsuccess($this->merchant_available);
  87. } else {
  88. return self::outerr(-6, $this->merchant_available);
  89. }
  90. }
  91. private function check_third($params)
  92. {
  93. if(empty($params['product_code'])) {
  94. Log::record("check_third product_code",Log::ERR);
  95. return -9;
  96. }
  97. $pcode = $params['product_code'];
  98. if($this->check_pcode($pcode) == false) {
  99. Log::record("check_third check_pcode",Log::ERR);
  100. return -10;
  101. }
  102. if(empty($params['quantity']) || intval($params['quantity']) < 1) {
  103. Log::record("check_third quantity",Log::ERR);
  104. return -9;
  105. }
  106. $card_no = $params['mob'];
  107. if(empty($card_no)) {
  108. Log::record("check_third mob",Log::ERR);
  109. return -9;
  110. }
  111. $third_card_type = $params['card_type'];
  112. if(empty($third_card_type)) {
  113. Log::record("check_third card_type",Log::ERR);
  114. return -9;
  115. }
  116. if(empty($params['notifyurl'])) {
  117. Log::record("check_third notifyurl",Log::ERR);
  118. return -9;
  119. }
  120. if(empty($params['ord'])) {
  121. Log::record("check_third ord",Log::ERR);
  122. return -9;
  123. }
  124. if(empty($params['tim'])) {
  125. Log::record("check_third tim",Log::ERR);
  126. return -9;
  127. }
  128. $tim = strtotime($params['tim']);
  129. if($tim === false) {
  130. Log::record("check_third strtotime tim",Log::ERR);
  131. return -9;
  132. }
  133. $cur = time();
  134. $start = strtotime(date('Y-m-d',$cur - 1800));
  135. if($tim < $start || $tim > $cur + 1800) {
  136. Log::record("check_third check tim",Log::ERR);
  137. return -9;
  138. }
  139. return true;
  140. }
  141. private function check_pcode($pcode)
  142. {
  143. $mod_third = Model('thrid_refill');
  144. $product = $mod_third->getProduct(['system_code' => $pcode]);
  145. return !empty($product);
  146. }
  147. public function add_thirdOp()
  148. {
  149. $code = $this->check_third($_GET);
  150. if($code !== true) {
  151. return self::outerr($code,$this->merchant_available);
  152. }
  153. $amount = refill\util::ThirdRefillAmount;
  154. $mch_order = $_GET['ord'];
  155. $notify_url = $_GET['notifyurl'];
  156. //三方充值没有质量
  157. $quality = 1;
  158. $card_type = mtopcard\ThirdRefillCard;
  159. $product_code = $_GET['product_code'];
  160. $card_no = $_GET['mob'];
  161. $quantity = $_GET['quantity'];
  162. $third_card_type = $_GET['card_type'];
  163. //此处判断是对的
  164. if($this->member_available <= 0) {
  165. return self::outerr(4,$this->merchant_available);
  166. }
  167. if(!$this->check_mchorder($this->mchid(),$mch_order)) {
  168. return self::outerr(11,$this->merchant_available);
  169. }
  170. $params = [ 'mchid' => $this->mchid(),
  171. 'buyer_id' => $this->adminid(),
  172. 'amount' => $amount,
  173. 'mch_order' => $mch_order,
  174. 'notify_url' => $notify_url,
  175. 'org_quality' => $quality,
  176. 'card_type' => $card_type,
  177. 'card_no' => $card_no,
  178. 'product_code' => $product_code,
  179. 'quantity' => $quantity,
  180. 'third_card_type' => $third_card_type
  181. ];
  182. $ret = refill\util::push_addthird($params);
  183. if($ret) {
  184. refill\util::push_queue_order($this->mchid(), $mch_order, ORDER_STATE_QUEUE);
  185. return self::outsuccess($this->merchant_available);
  186. }
  187. else {
  188. return self::outerr(-6,$this->merchant_available);
  189. }
  190. }
  191. private function can_refill($cardno)
  192. {
  193. $card_info = refill\util::read_card($cardno);
  194. if(empty($card_info)) return false;
  195. return intval($card_info['black_card']) === 0;
  196. }
  197. private function check_mchorder($mchid,$mch_order)
  198. {
  199. if(empty($mch_order)) {
  200. return false;
  201. }
  202. else {
  203. $refill_order = Model('refill_order');
  204. $ret = $refill_order->getOrderInfo(['mchid' => $mchid,'mch_order' => $mch_order]);
  205. return empty($ret);
  206. }
  207. }
  208. public function balanceOp()
  209. {
  210. $uid = $this->adminid();
  211. $minfo = new member_info($uid);
  212. $available = $minfo->available_predeposit();
  213. $content = "0|".ncPriceFormat($available)."|0.00";
  214. echo $content;
  215. return true;
  216. }
  217. public function queryOp()
  218. {
  219. $mchid = $this->mchid();
  220. $order_sn = $_GET['ord']; //用户方的订单号,对应数据库中的mch_order
  221. if(empty($order_sn)) {
  222. return self::outerr(-9,$this->merchant_available);
  223. }
  224. $order_state = refill\util::query_queue_order($mchid,$order_sn);
  225. if ($order_state == ORDER_STATE_QUEUE || $order_state == ORDER_STATE_SEND) {
  226. Log::record("query_state in queue mchid={$mchid} mch_order={$order_sn} order_state={$order_state}" ,Log::DEBUG);
  227. $state = 0;
  228. $msg = "{$order_sn}-充值中";
  229. $remark = "";
  230. $content = "|{$state}|{$msg}|{$remark}";
  231. echo $content;
  232. $this->query_request($mchid,$order_sn);
  233. return true;
  234. }
  235. else
  236. {
  237. $mod_refill = Model('refill_order');
  238. $refill_info = $mod_refill->getOrderInfo(['mch_order' => $order_sn,'mchid' => $mchid,'inner_status' => 0]);
  239. if(empty($refill_info))
  240. {
  241. Log::record("query_state in db no order mchid={$mchid} mch_order={$order_sn}" ,Log::DEBUG);
  242. $state = 3;
  243. $msg = "{$order_sn}-无此订单";
  244. $remark = "";
  245. $content = "|{$state}|{$msg}|{$remark}";
  246. echo $content;
  247. return true;
  248. }
  249. else
  250. {
  251. $vr_order = Model('vr_order');
  252. $order_info = $vr_order->getOrderInfo(['order_sn' => $refill_info['order_sn']]);
  253. $order_state = $order_info['order_state'];
  254. Log::record("query_state in db mchid={$mchid} mch_order={$order_sn} order_state={$order_state}" ,Log::DEBUG);
  255. if ($order_state == ORDER_STATE_CANCEL) {
  256. $state = 2;
  257. $msg = "{$order_sn}-充值失败";
  258. $remark = "";
  259. }
  260. elseif($order_state == ORDER_STATE_SUCCESS) {
  261. $state = 1;
  262. $msg = "{$order_sn}-充值成功";
  263. $remark = "{$refill_info['official_sn']}";
  264. }
  265. else {
  266. $state = 0;
  267. $msg = "{$order_sn}-充值中";
  268. $remark = "";
  269. }
  270. if($refill_info['card_type'] == mtopcard\ThirdRefillCard) {
  271. $remark = $this->third_remark($refill_info);
  272. }
  273. $content = "|{$state}|{$msg}|{$remark}";
  274. echo $content;
  275. return true;
  276. }
  277. }
  278. }
  279. private function query_request($mchid,$order_sn)
  280. {
  281. $mod_refill = Model('refill_order');
  282. $refill_info = $mod_refill->getOrderInfo(['mch_order' => $order_sn,'mchid' => $mchid,'inner_status' => 0]);
  283. if(!empty($refill_info))
  284. {
  285. $vr_order = Model('vr_order');
  286. $order_info = $vr_order->getOrderInfo(['order_sn' => $refill_info['order_sn']]);
  287. if(!empty($order_info) && $order_info['order_state'] == ORDER_STATE_SEND) {
  288. QueueClient::push("QueryRefillState",['order_id' => $refill_info['order_id']]);
  289. }
  290. }
  291. }
  292. private function third_remark($refill_info)
  293. {
  294. $mchinfo = Model('merchant')->getMerchantInfo(['mchid' => $this->mchid()]);
  295. $mod_third = Model('thrid_refill');
  296. $thrid_info = $mod_third->getThird($refill_info['order_id']);
  297. $secure_key = $mchinfo['secure_key'];
  298. $remark = '';
  299. if (!empty($thrid_info))
  300. {
  301. $card_info = $thrid_info['card_info'];
  302. if (!empty($card_info)) {
  303. $encrypt = openssl_encrypt($card_info,'AES-128-CBC',$secure_key);
  304. if($encrypt != false) {
  305. $remark = $encrypt;
  306. }
  307. }
  308. }
  309. return $remark;
  310. }
  311. }