RefillCallBack.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. namespace refill\qiantu;
  3. require_once(BASE_HELPER_RAPI_PATH . '/qiantu/config.php');
  4. use refill;
  5. class RefillCallBack implements refill\IRefillCallBack
  6. {
  7. public function verify($params): bool
  8. {
  9. $sign = $this->sign($params);
  10. if ($params['sign'] == $sign) {
  11. return true;
  12. } else {
  13. return false;
  14. }
  15. }
  16. private function sign($params)
  17. {
  18. $userid = config::USER_ID;
  19. $key = config::KEY;
  20. $content = "userid={$userid}&orderid={$params['orderid']}&sporderid={$params['sporderid']}&merchantsubmittime={$params['merchantsubmittime']}";
  21. $content .= "&resultno={$params['resultno']}&key={$key}";
  22. return strtoupper(md5($content));
  23. }
  24. public function notify($params)
  25. {
  26. $status = intval($params['resultno']);
  27. $order_sn = $params['sporderid'];
  28. $order_info = Model('vr_order')->getOrderInfoForNotify(['order_sn' => $order_sn]);
  29. if (empty($order_info)) {
  30. return [false, false, false, false, ''];
  31. }
  32. $official_sn = '';
  33. $order_id = $order_info['order_id'];
  34. if ($status === 1) {
  35. $official_sn = strtolower($params['remark1']) == 'null' ? '' : $params['remark1'];
  36. $data['official_sn'] = $official_sn;
  37. Model('refill_order')->edit($order_id, $data);
  38. return [$order_id, true, false, true, $official_sn];
  39. } elseif ($status === 9) {
  40. return [$order_id, false, true, true, $official_sn];
  41. } else {
  42. return [$order_id, false, false, false, $official_sn];
  43. }
  44. }
  45. }