RefillCallBack.php 1.6 KB

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