RefillCallBack.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace refill\yingdian_hf;
  3. require_once(BASE_HELPER_RAPI_PATH . '/yingdian_hf/config.php');
  4. use refill;
  5. class RefillCallBack implements refill\IRefillCallBack
  6. {
  7. public function verify($params): bool
  8. {
  9. $input = $params;
  10. unset($input['sign']);
  11. $sign = $this->sign($input);
  12. if ($params['sign'] == $sign) {
  13. return true;
  14. } else {
  15. return false;
  16. }
  17. }
  18. private function sign($params)
  19. {
  20. unset($params['proof']);
  21. $content = '';
  22. ksort($params);
  23. foreach ($params as $key => $val){
  24. $content .= "{$key}=". urlencode($val) ."&";
  25. }
  26. $content .= "key=".config::KEY;
  27. return md5($content);
  28. }
  29. public function notify($params)
  30. {
  31. $status = $params['state'];
  32. $order_sn = $params['outTradeNo'];
  33. $order_info = Model('vr_order')->getOrderInfoForNotify(['order_sn' => $order_sn]);
  34. if (empty($order_info)) {
  35. return [false, false, false,false];
  36. }
  37. $order_id = $order_info['order_id'];
  38. if ($status === 'SUCCESS') {
  39. Model('refill_order')->edit($order_id, ['official_sn' => $params['proof'], 'ch_trade_no' => $params['orderNo']]);
  40. return [$order_id, true, false, true];
  41. } elseif ($status === 'FAIL') {
  42. Model('refill_order')->edit($order_id, ['ch_trade_no' => $params['orderNo']]);
  43. return [$order_id, false, true, true];
  44. } else {
  45. return [$order_id, false, false, false];
  46. }
  47. }
  48. }