RefillPhone.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. <?php
  2. namespace refill\xingzy;
  3. require_once(BASE_HELPER_RAPI_PATH . '/xingzy/config.php');
  4. use refill;
  5. use Log;
  6. class RefillPhone extends refill\IRefillPhone
  7. {
  8. public function __construct($cfgs)
  9. {
  10. parent::__construct($cfgs);
  11. }
  12. private function req_params(int $phone, int $card_type, int $amount, string $order_sn)
  13. {
  14. $params['phone'] = $phone;
  15. $params['access_key'] = config::ACCESS_KEY;
  16. $params['par_value'] = $amount;
  17. $params['code'] = config::product_code[$card_type][$amount];
  18. $params['producttype'] = 0;
  19. $params['out_trade_no'] = $order_sn;
  20. $params['timestamp'] = time();
  21. return $params;
  22. }
  23. public function add($card_no, $card_type, $amount, $params,&$net_errno = 0)
  24. {
  25. $params = $this->req_params($card_no, $card_type, $amount, $params['order_sn']);
  26. $sign = $this->sign($params);
  27. $params['sign'] = $sign;
  28. $params['notify_url'] = config::NOTIFY_URL;
  29. $params = json_encode($params);
  30. $resp = http_post_data(config::ORDER_URL, $params , config::ExtHeaders, $net_errno);
  31. if (empty($resp)) {
  32. return [false, '系统错误', true];
  33. }
  34. else
  35. {
  36. Log::record($resp, Log::DEBUG);
  37. $resp = json_decode($resp, true);
  38. if (empty($resp)) {
  39. return [false, '系统错误', true];
  40. } elseif ($resp['code'] == 1) {
  41. return [true, $resp['data']['orderid'], false];
  42. } elseif ($resp['code'] == 3) {
  43. return [false, $resp['msg'], false];
  44. } elseif (in_array($resp['code'], [0,2])) {
  45. $net_errno = "HTTP-{$resp['code']}";
  46. return [false, $resp['msg'], true];
  47. } else {
  48. $err = 998;
  49. $net_errno = "HTTP-{$err}";
  50. return [false, $resp['msg'], true];
  51. }
  52. }
  53. }
  54. public function query($refill_info)
  55. {
  56. $params['access_key'] = config::ACCESS_KEY;
  57. $params['orderid'] = $refill_info['ch_trade_no'];
  58. $params['out_trade_no'] = $refill_info['order_sn'];
  59. $params['timestamp'] = time();
  60. $params['sign'] = $this->sign($params);
  61. $params = json_encode($params);
  62. $resp = http_post_data(config::QUERY_URL, $params , config::ExtHeaders);
  63. if (empty($resp)) {
  64. return [false, '系统错误'];
  65. }
  66. else
  67. {
  68. Log::record($resp, Log::DEBUG);
  69. $resp = json_decode($resp, true);
  70. if (empty($resp)) {
  71. return [false, '系统错误'];
  72. }
  73. else
  74. {
  75. $status = intval($resp['code']);
  76. if ($status === 2) {
  77. Model('refill_order')->edit($refill_info['order_id'], ['official_sn' => $resp['data']['official_id']]);
  78. $order_state = ORDER_STATE_SUCCESS;
  79. } elseif ($status === 3) {
  80. $order_state = ORDER_STATE_CANCEL;
  81. } elseif ($status === 1) {
  82. $order_state = ORDER_STATE_SEND;
  83. } elseif ($status === 5 && (time() - $refill_info['commit_time'] > 600)) {
  84. $order_state = ORDER_STATE_NOEXIST;
  85. } else {
  86. return [false, $resp['msg']];
  87. }
  88. return [true, $order_state];
  89. }
  90. }
  91. }
  92. public function balance()
  93. {
  94. $params['access_key'] = config::ACCESS_KEY;
  95. $params['timestamp'] = time();
  96. $params['sign'] = $this->sign($params);
  97. $params = json_encode($params);
  98. $resp = http_post_data(config::BALANCE_URL, $params , config::ExtHeaders);
  99. if (empty($resp)) {
  100. return [false, '系统错误'];
  101. }
  102. else
  103. {
  104. Log::record($resp, Log::DEBUG);
  105. $resp = json_decode($resp, true);
  106. if (empty($resp)) {
  107. return [false, '系统错误'];
  108. } elseif ($resp['code'] == 1) {
  109. return [true, $resp['balance']];
  110. } else {
  111. return [false, $resp['msg']];
  112. }
  113. }
  114. }
  115. private function sign($params)
  116. {
  117. ksort($params);
  118. $body = "";
  119. foreach ($params as $k => $v) {
  120. $body .= "{$k}{$v}";
  121. }
  122. return base64_encode(hash_hmac("sha1", $body, config::ACCESS_SECRET, true));
  123. }
  124. }