RefillCallBack.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. <?php
  2. namespace refill\dingchi;
  3. require_once(BASE_HELPER_RAPI_PATH . '/dingchi/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. $key = config::KEY;
  19. $user_id = config::USER_ID;
  20. $content = "{$params['bizId']}{$params['downstreamSerialno']}{$params['id']}{$params['status']}{$user_id}{$key}";
  21. return md5($content);
  22. }
  23. public function notify($params)
  24. {
  25. $status = intval($params['status']);
  26. $order_sn = $params['downstreamSerialno'];
  27. $order_info = Model('vr_order')->getOrderInfoForNotify(['order_sn' => $order_sn]);
  28. if (empty($order_info)) {
  29. return [false, false, false,false];
  30. }
  31. $order_id = $order_info['order_id'];
  32. if ($status === 2) {
  33. $data['official_sn'] = strtolower($params['extend']) == 'null' ? '' : $params['extend'];
  34. Model('refill_order')->edit($order_id, $data);
  35. return [$order_id, true, false, true];
  36. } elseif ($status === 3) {
  37. return [$order_id, false, true, true];
  38. } else {
  39. return [$order_id, false, false, false];
  40. }
  41. }
  42. }