UserMonthService.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: z-yang
  5. * Date: 2019/7/27
  6. * Time: 18:01
  7. */
  8. namespace App\Modules\User\Services;
  9. use App\Modules\User\Models\UserMonthOrder;
  10. use App\Modules\User\Models\UserMonthOrderCallbackv2;
  11. use App\Modules\User\Models\UserMonthOrderRecord;
  12. use App\Modules\User\Models\UserMonthSign;
  13. use App\Modules\User\Models\UserMonthSignOrigin;
  14. use GuzzleHttp\Client;
  15. use EasyWeChat\Support\XML;
  16. class UserMonthService
  17. {
  18. const MONTH_PAY_KEY = 'Manyuedu869815753951852456456852';
  19. const MONTH_PAY_APPID = 'wx34804c803efab065';
  20. const MONTH_PAY_MCH_ID = '1278120701';
  21. public static function createSign(int $uid, int $plan_id, string $change_type,string $openid,string $type)
  22. {
  23. $model = new UserMonthSign();
  24. $info = $model->where('uid', $uid)->where('plan_id', $plan_id)->first();
  25. if ($info) {
  26. $info->change_type = $change_type;
  27. $info->save();
  28. } else {
  29. $model->uid = $uid;
  30. $model->plan_id = $plan_id;
  31. $model->change_type = $change_type;
  32. $model->openid = $openid;
  33. $model->type = $type;
  34. $model->save();
  35. }
  36. return;
  37. }
  38. public static function isSignMonth($openid){
  39. $model = new UserMonthSign();
  40. return $model->where('openid',$openid)->where('change_type','ADD')->select('id')->first();
  41. }
  42. public static function getLastOrder(int $uid){
  43. $model = new UserMonthOrder();
  44. return $model->where('uid',$uid)->orderBy('id','desc')->first();
  45. }
  46. public static function createLOrder(int $uid, int $plan_id, int $total_fee, string $trade_no,string $out_trade_no,string $type)
  47. {
  48. $model = new UserMonthOrder();
  49. $model->uid = $uid;
  50. $model->plan_id = $plan_id;
  51. $model->total_fee = $total_fee;
  52. $model->trade_no = $trade_no;
  53. $model->out_trade_no = $out_trade_no;
  54. $model->type = $type;
  55. $model->save();
  56. return;
  57. }
  58. public static function getOrderByOrder($trade_no,$out_trade_no){
  59. $model = new UserMonthOrder();
  60. $info = $model->where('trade_no',$trade_no)->first();
  61. return $info;
  62. }
  63. public static function getOrderAndSignStatusByUid($uid){
  64. $result = UserMonthOrder::join('user_month_sign','user_month_sign.uid','=','user_month_order.uid')
  65. ->select('user_month_order.type','user_month_sign.change_type')
  66. ->where('user_month_order.uid',$uid)
  67. ->where('user_month_sign.change_type','DELETE')
  68. ->get();
  69. if($result->isEmpty()) return [];
  70. $return_result = [];
  71. foreach ($result as $item){
  72. $return_result[] = $item->type;
  73. }
  74. return $return_result;
  75. }
  76. public static function checkOrderStatus(int $user_id,int $plan_id,string $app_id,string $key,string $app_secret){
  77. $pay_year = date('Y');
  78. $pay_month = date('m');
  79. $sign = strtoupper(_sign(compact('app_id','app_secret','user_id','plan_id','pay_year','pay_month'),$key.$key));
  80. $client = new Client();
  81. $url = 'http://pap.manyuedu.org/checkpay.php?';
  82. $url .= http_build_query(compact('user_id','app_secret','app_id','plan_id','pay_year','pay_month','sign'));
  83. $result = $client->request('post',$url)->getBody()->getContents();
  84. return json_decode($result,true);
  85. }
  86. public static function isMonthOrderUser($uid){
  87. $info = UserMonthOrder::where('uid',$uid)
  88. ->where('type','MONTH')
  89. ->orderBy('id','desc')
  90. ->select('created_at')
  91. ->first();
  92. if($info && strtotime($info->created_at)+365*86400 >time() ){
  93. return true;
  94. }
  95. return false;
  96. }
  97. public static function monthOrderLink($uid,$plan_id){
  98. $key = self::MONTH_PAY_KEY;
  99. $appid = self::MONTH_PAY_APPID;
  100. $mch_id = self::MONTH_PAY_MCH_ID;
  101. $contract_code = $uid;
  102. $request_serial = getMillisecond();
  103. $contract_display_account = $uid;
  104. $notify_url = env('MONTH_PAY_SIGN_NOTIFY_URLV2');
  105. $version = '1.0';
  106. $timestamp = time();
  107. $return_web = 1;
  108. $request_param = compact('appid','mch_id','plan_id','contract_code','request_serial','contract_display_account','notify_url','version','timestamp','return_web');
  109. $sign = _sign($request_param,$key);
  110. $request_param['sign'] = $sign;
  111. $url = 'https://api.mch.weixin.qq.com/papay/entrustweb/?'.http_build_query($request_param);
  112. return $url;
  113. }
  114. public static function monthPayApplypap($uid,$contract_id,$total_fee,$body,$ip,$order_way,$attach=''){
  115. $url = 'https://api.mch.weixin.qq.com/pay/pappayapply';
  116. $data = [
  117. 'appid'=>self::MONTH_PAY_APPID,
  118. 'mch_id'=>self::MONTH_PAY_MCH_ID,
  119. 'nonce_str'=>str_random(32),
  120. 'body'=>$body,
  121. 'attach'=>$attach,
  122. 'out_trade_no'=>date("YmdHis") . str_shuffle(hexdec(uniqid())),
  123. 'total_fee'=>$total_fee,
  124. 'spbill_create_ip'=>$ip,
  125. 'notify_url'=>env('MONTH_PAY_CALLBACK_URLV2'),
  126. 'trade_type'=>'PAP',
  127. 'contract_id'=>$contract_id
  128. ];
  129. $sign = _sign($data,self::MONTH_PAY_KEY);
  130. $data['sign'] = $sign;
  131. $client = new Client();
  132. $result = $client->request('post',$url,[
  133. 'body'=>XML::build($data)
  134. ])->getBody()->getContents();
  135. $result = XML::parse($result);
  136. UserMonthOrderRecord::create([
  137. 'uid'=>$uid,
  138. 'nonce_str'=>$data['nonce_str'],
  139. 'body'=>$data['body'],
  140. 'attach'=>$data['attach'],
  141. 'out_trade_no'=>$data['out_trade_no'],
  142. 'total_fee'=>$data['total_fee'],
  143. 'spbill_create_ip'=>$data['spbill_create_ip'],
  144. 'contract_id'=>$data['contract_id'],
  145. 'order_way'=>$order_way,
  146. 'result_code'=>isset($result['result_code'])?$result['result_code']:'',
  147. 'result_text'=>\GuzzleHttp\json_encode($result)
  148. ]);
  149. return ;
  150. }
  151. public static function monthCallBackRecordV2(array $data)
  152. {
  153. try{
  154. UserMonthOrderCallbackv2::create($data);
  155. }catch (\Exception $e){
  156. \Log::error($e);
  157. }
  158. }
  159. public static function monthOrderSignRecord(array $data){
  160. try{
  161. UserMonthSignOrigin::create($data);
  162. }catch (\Exception $e){
  163. \Log::error($e);
  164. }
  165. }
  166. public static function getLastMonthOrderInfo($uid,$type){
  167. return UserMonthOrder::where('uid',$uid)
  168. ->where('type',$type)
  169. ->orderBy('id','desc')
  170. ->select('id','plan_id','created_at')
  171. ->first();
  172. }
  173. }