lzrefill.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  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. refill\util::push_queue($this->mchid(),$mch_order,time());
  84. $ret = refill\util::push_add($params);
  85. if($ret) {
  86. return self::outsuccess($this->merchant_available);
  87. }
  88. else {
  89. return self::outerr(-6,$this->merchant_available);
  90. }
  91. }
  92. private function check_third($params)
  93. {
  94. if(empty($params['product_code'])) {
  95. Log::record("check_third product_code",Log::ERR);
  96. return -9;
  97. }
  98. $pcode = $params['product_code'];
  99. if($this->check_pcode($pcode) == false) {
  100. Log::record("check_third check_pcode",Log::ERR);
  101. return -10;
  102. }
  103. if(empty($params['quantity']) || intval($params['quantity']) < 1) {
  104. Log::record("check_third quantity",Log::ERR);
  105. return -9;
  106. }
  107. $card_no = $params['mob'];
  108. if(empty($card_no)) {
  109. Log::record("check_third mob",Log::ERR);
  110. return -9;
  111. }
  112. $third_card_type = $params['card_type'];
  113. if(empty($third_card_type)) {
  114. Log::record("check_third card_type",Log::ERR);
  115. return -9;
  116. }
  117. if(empty($params['notifyurl'])) {
  118. Log::record("check_third notifyurl",Log::ERR);
  119. return -9;
  120. }
  121. if(empty($params['ord'])) {
  122. Log::record("check_third ord",Log::ERR);
  123. return -9;
  124. }
  125. if(empty($params['tim'])) {
  126. Log::record("check_third tim",Log::ERR);
  127. return -9;
  128. }
  129. $tim = strtotime($params['tim']);
  130. if($tim === false) {
  131. Log::record("check_third strtotime tim",Log::ERR);
  132. return -9;
  133. }
  134. $cur = time();
  135. $start = strtotime(date('Y-m-d',$cur - 1800));
  136. if($tim < $start || $tim > $cur + 1800) {
  137. Log::record("check_third check tim",Log::ERR);
  138. return -9;
  139. }
  140. return true;
  141. }
  142. private function check_pcode($pcode)
  143. {
  144. $mod_third = Model('thrid_refill');
  145. $product = $mod_third->getProduct(['system_code' => $pcode]);
  146. return !empty($product);
  147. }
  148. public function add_thirdOp()
  149. {
  150. $code = $this->check_third($_GET);
  151. if($code !== true) {
  152. return self::outerr($code,$this->merchant_available);
  153. }
  154. $amount = refill\util::ThirdRefillAmount;
  155. $mch_order = $_GET['ord'];
  156. $notify_url = $_GET['notifyurl'];
  157. //三方充值没有质量
  158. $quality = 1;
  159. $card_type = mtopcard\ThirdRefillCard;
  160. $product_code = $_GET['product_code'];
  161. $card_no = $_GET['mob'];
  162. $quantity = $_GET['quantity'];
  163. $third_card_type = $_GET['card_type'];
  164. //此处判断是对的
  165. if($this->member_available <= 0) {
  166. return self::outerr(4,$this->merchant_available);
  167. }
  168. if(!$this->check_mchorder($this->mchid(),$mch_order)) {
  169. return self::outerr(11,$this->merchant_available);
  170. }
  171. $params = [ 'mchid' => $this->mchid(),
  172. 'buyer_id' => $this->adminid(),
  173. 'amount' => $amount,
  174. 'mch_order' => $mch_order,
  175. 'notify_url' => $notify_url,
  176. 'org_quality' => $quality,
  177. 'card_type' => $card_type,
  178. 'card_no' => $card_no,
  179. 'product_code' => $product_code,
  180. 'quantity' => $quantity,
  181. 'third_card_type' => $third_card_type
  182. ];
  183. $ret = refill\util::push_addthird($params);
  184. if($ret) {
  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. $mod_refill = Model('refill_order');
  225. $refill_info = $mod_refill->getOrderInfo(['mch_order' => $order_sn,'mchid' => $mchid,'inner_status' => 0]);
  226. if(empty($refill_info))
  227. {
  228. $state = 3;
  229. $msg = "{$order_sn}-无此订单";
  230. $remark = "";
  231. $content = "|{$state}|{$msg}|{$remark}";
  232. echo $content;
  233. return true;
  234. }
  235. if(empty($refill_info))
  236. {
  237. $ret = refill\util::query_queue($mchid,$order_sn);
  238. if ($ret > 0) {
  239. $state = 0;
  240. $msg = "{$order_sn}-充值中";
  241. $remark = "";
  242. $content = "|{$state}|{$msg}|{$remark}";
  243. echo $content;
  244. return true;
  245. } else {
  246. $state = 3;
  247. $msg = "{$order_sn}-无此订单";
  248. $remark = "";
  249. $content = "|{$state}|{$msg}|{$remark}";
  250. echo $content;
  251. return true;
  252. }
  253. }
  254. $vr_order = Model('vr_order');
  255. $order_info = $vr_order->getOrderInfo(['order_sn' => $refill_info['order_sn']]);
  256. if($refill_info['is_retrying'])
  257. {
  258. QueueClient::push("QueryRefillState",['order_id' => $refill_info['order_id']]);
  259. $state = 0;
  260. $msg = "{$order_sn}-充值中";
  261. $remark = "";
  262. }
  263. else
  264. {
  265. $order_state = $order_info['order_state'];
  266. if($order_state == ORDER_STATE_SEND || $order_state == ORDER_STATE_PAY || $order_state == ORDER_STATE_NEW) {
  267. QueueClient::push("QueryRefillState",['order_id' => $refill_info['order_id']]);
  268. $state = 0;
  269. $msg = "{$order_sn}-充值中";
  270. $remark = "";
  271. }
  272. elseif($order_state == ORDER_STATE_CANCEL) {
  273. $state = 2;
  274. $msg = "{$order_sn}-充值失败";
  275. $remark = "";
  276. }
  277. else {
  278. $state = 1;
  279. $msg = "{$order_sn}-充值成功";
  280. $remark = "{$refill_info['official_sn']}";
  281. }
  282. }
  283. if($refill_info['card_type'] == mtopcard\ThirdRefillCard) {
  284. $remark = $this->third_remark($refill_info);
  285. }
  286. $content = "|{$state}|{$msg}|{$remark}";
  287. echo $content;
  288. return true;
  289. }
  290. private function third_remark($refill_info)
  291. {
  292. $mchinfo = Model('merchant')->getMerchantInfo(['mchid' => $this->mchid()]);
  293. $mod_third = Model('thrid_refill');
  294. $thrid_info = $mod_third->getThird($refill_info['order_id']);
  295. $secure_key = $mchinfo['secure_key'];
  296. $remark = '';
  297. if (!empty($thrid_info))
  298. {
  299. $card_info = $thrid_info['card_info'];
  300. if (!empty($card_info)) {
  301. $encrypt = openssl_encrypt($card_info,'AES-128-CBC',$secure_key);
  302. if($encrypt != false) {
  303. $remark = $encrypt;
  304. }
  305. }
  306. }
  307. return $remark;
  308. }
  309. }