lzrefill.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  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. return self::outsuccess($this->merchant_available);
  185. }
  186. else {
  187. return self::outerr(-6,$this->merchant_available);
  188. }
  189. }
  190. private function can_refill($cardno)
  191. {
  192. $card_info = refill\util::read_card($cardno);
  193. if(empty($card_info)) return false;
  194. return intval($card_info['black_card']) === 0;
  195. }
  196. private function check_mchorder($mchid,$mch_order)
  197. {
  198. if(empty($mch_order)) {
  199. return false;
  200. }
  201. else {
  202. $refill_order = Model('refill_order');
  203. $ret = $refill_order->getOrderInfo(['mchid' => $mchid,'mch_order' => $mch_order]);
  204. return empty($ret);
  205. }
  206. }
  207. public function balanceOp()
  208. {
  209. $uid = $this->adminid();
  210. $minfo = new member_info($uid);
  211. $available = $minfo->available_predeposit();
  212. $content = "0|".ncPriceFormat($available)."|0.00";
  213. echo $content;
  214. return true;
  215. }
  216. public function queryOp()
  217. {
  218. $mchid = $this->mchid();
  219. $order_sn = $_GET['ord']; //用户方的订单号,对应数据库中的mch_order
  220. if(empty($order_sn)) {
  221. return self::outerr(-9,$this->merchant_available);
  222. }
  223. $order_state = refill\util::query_queue_order($mchid,$order_sn);
  224. if ($order_state == ORDER_STATE_QUEUE || $order_state == ORDER_STATE_SEND) {
  225. $state = 0;
  226. $msg = "{$order_sn}-充值中";
  227. $remark = "";
  228. $content = "|{$state}|{$msg}|{$remark}";
  229. echo $content;
  230. $this->query_request($mchid,$order_sn);
  231. return true;
  232. }
  233. else
  234. {
  235. $mod_refill = Model('refill_order');
  236. $refill_info = $mod_refill->getOrderInfo(['mch_order' => $order_sn,'mchid' => $mchid,'inner_status' => 0]);
  237. if(empty($refill_info))
  238. {
  239. $state = 3;
  240. $msg = "{$order_sn}-无此订单";
  241. $remark = "";
  242. $content = "|{$state}|{$msg}|{$remark}";
  243. echo $content;
  244. return true;
  245. }
  246. else
  247. {
  248. $vr_order = Model('vr_order');
  249. $order_info = $vr_order->getOrderInfo(['order_sn' => $refill_info['order_sn']]);
  250. $order_state = $order_info['order_state'];
  251. if ($order_state == ORDER_STATE_CANCEL) {
  252. $state = 2;
  253. $msg = "{$order_sn}-充值失败";
  254. $remark = "";
  255. } else {
  256. $state = 1;
  257. $msg = "{$order_sn}-充值成功";
  258. $remark = "{$refill_info['official_sn']}";
  259. }
  260. if($refill_info['card_type'] == mtopcard\ThirdRefillCard) {
  261. $remark = $this->third_remark($refill_info);
  262. }
  263. $content = "|{$state}|{$msg}|{$remark}";
  264. echo $content;
  265. return true;
  266. }
  267. }
  268. }
  269. private function query_request($mchid,$order_sn)
  270. {
  271. $mod_refill = Model('refill_order');
  272. $refill_info = $mod_refill->getOrderInfo(['mch_order' => $order_sn,'mchid' => $mchid,'inner_status' => 0]);
  273. if(!empty($refill_info))
  274. {
  275. $vr_order = Model('vr_order');
  276. $order_info = $vr_order->getOrderInfo(['order_sn' => $refill_info['order_sn']]);
  277. if(!empty($order_info) && $order_info['order_state'] == ORDER_STATE_SEND) {
  278. QueueClient::push("QueryRefillState",['order_id' => $refill_info['order_id']]);
  279. }
  280. }
  281. }
  282. private function third_remark($refill_info)
  283. {
  284. $mchinfo = Model('merchant')->getMerchantInfo(['mchid' => $this->mchid()]);
  285. $mod_third = Model('thrid_refill');
  286. $thrid_info = $mod_third->getThird($refill_info['order_id']);
  287. $secure_key = $mchinfo['secure_key'];
  288. $remark = '';
  289. if (!empty($thrid_info))
  290. {
  291. $card_info = $thrid_info['card_info'];
  292. if (!empty($card_info)) {
  293. $encrypt = openssl_encrypt($card_info,'AES-128-CBC',$secure_key);
  294. if($encrypt != false) {
  295. $remark = $encrypt;
  296. }
  297. }
  298. }
  299. return $remark;
  300. }
  301. }