RefillCallBack.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. namespace refill\suning;
  3. require_once(BASE_HELPER_RAPI_PATH . '/suning/config.php');
  4. use refill;
  5. use Log;
  6. class RefillCallBack implements refill\IRefillCallBack
  7. {
  8. public function verify($params): bool
  9. {
  10. return true;
  11. }
  12. public function notify($params)
  13. {
  14. //苏宁接口提交成功即订单成功,只需处理成功
  15. $order_sn = $params['order_sn'];
  16. $order_info = Model('vr_order')->getOrderInfo(['order_sn' => $order_sn]);
  17. if (empty($order_info)) {
  18. return [false, false, false,false];
  19. }
  20. $order_id = $order_info['order_id'];
  21. $fDirect = $params['isDirect'];
  22. $card_info = $params['card_info'];
  23. if($fDirect)
  24. {
  25. if(!empty($card_info))
  26. {
  27. $result = $this->rsa_decode($card_info['password']);
  28. if (empty($result)) {
  29. $data['ret_state'] = 2;
  30. $data['card_info'] = '回调解密,解密失败';
  31. } else {
  32. $data['ret_state'] = 1;
  33. $card_info['password'] = $result;
  34. $result = json_encode($card_info);
  35. $data['card_info'] = $result;
  36. }
  37. Model('thrid_refill')->edit_third($order_id, $data);
  38. }
  39. }
  40. else {
  41. $data['official_sn'] = $card_info['cardNo'];
  42. Model('refill_order')->edit($order_id, $data);
  43. }
  44. return [$order_id, true, false,true];
  45. }
  46. private function rsa_decode($encrypted)
  47. {
  48. $ret = openssl_private_decrypt(base64_decode($encrypted), $decrypted, config::PRIVATE_KEY);
  49. if ($ret) {
  50. $result = json_decode($decrypted, true);
  51. return $result;
  52. } else {
  53. $err = openssl_error_string();
  54. Log::record("suning callback openssl_private_decrypt error={$err}",Log::ERR);
  55. return false;
  56. }
  57. }
  58. }