MonthOrderController.php 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: z-yang
  5. * Date: 2019/7/25
  6. * Time: 10:29
  7. */
  8. namespace App\Http\Controllers\Wap\Pay;
  9. use App\Modules\SendOrder\Services\SendOrderService;
  10. use App\Modules\Subscribe\Models\Order;
  11. use App\Modules\Subscribe\Services\OrderService;
  12. use App\Modules\Subscribe\Services\YearOrderService;
  13. use App\Modules\User\Services\UserMonthService;
  14. use App\Modules\User\Services\UserService;
  15. use GuzzleHttp\Client;
  16. use Illuminate\Routing\Controller;
  17. use Illuminate\Http\Request;
  18. use Log;
  19. use Redis;
  20. class MonthOrderController extends Controller
  21. {
  22. public function getH5RedirectUrl(Request $request){
  23. $app_id = 'Aekgrv87yo5wxnl715';
  24. $app_secret = '57gwsnd158ib2sn7wluq5716brp8fzm';
  25. $key = 'sn7wluq5716brp8fzm';
  26. //$plan_id = 124768;
  27. $plan_id = 39603;
  28. $user_id = 10008;
  29. $ip = _getIp();
  30. $sign = _sign(compact('app_id','app_secret','plan_id','user_id','ip'),$key.$key);
  31. $sign = strtoupper($sign);
  32. $client = new Client();
  33. Log::info(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  34. $url = 'http://pap.manyuedu.org/h5.php?'.http_build_query(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  35. //$url = 'http://pap.manyuedu.org/?'.http_build_query(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  36. return $client->get($url)->getBody()->getContents();
  37. }
  38. public function getWechatRedirectUrl(Request $request){
  39. $app_id = 'Aekgrv87yo5wxnl715';
  40. $app_secret = '57gwsnd158ib2sn7wluq5716brp8fzm';
  41. $key = 'sn7wluq5716brp8fzm';
  42. //$plan_id = 124768;
  43. $plan_id = 39603;
  44. $user_id = 10008;
  45. $ip = _getIp();
  46. $sign = _sign(compact('app_id','app_secret','plan_id','user_id','ip'),$key.$key);
  47. $sign = strtoupper($sign);
  48. $client = new Client();
  49. Log::info(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  50. //$url = 'http://pap.manyuedu.org/h5.php?'.http_build_query(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  51. $url = 'http://pap.manyuedu.org/?'.http_build_query(compact('app_id','app_secret','plan_id','user_id','ip','sign'));
  52. return $client->get($url)->getBody()->getContents();
  53. }
  54. public function signCallBack(Request $request){
  55. Log::info('signCallBack------------------------------------------signCallBack');
  56. Log::info($request->all());
  57. Log::info($request->getMethod());
  58. //$key = 'sn7wluq5716brp8fzm';
  59. $key = env('MONTH_ORDER_KEY');
  60. $app_id = $request->post('app_id');
  61. $plan_id = $request->post('plan_id');
  62. $user_id = $request->post('user_id');
  63. $change_type = $request->post('change_type');
  64. if($check = checkParam($request->except('_url'),['app_id','plan_id','user_id','change_type'])){
  65. return response()->error('PARAM_EMPTY',['msg'=>$check]);
  66. }
  67. $sign = _sign(compact('app_id','plan_id','user_id','change_type'),$key.$key);
  68. $sign = strtoupper($sign);
  69. $user_info = UserService::getById($user_id);
  70. if($sign == $request->post('sign')){
  71. UserMonthService::createSign($user_id,$plan_id,$change_type,$user_info->openid);
  72. }
  73. Log::info('signCallBack-------------------end-----------------------signCallBack');
  74. return response('success');
  75. }
  76. public function orderCallBackV2(Request $request){
  77. Log::info('orderCallBack------------------------------------------orderCallBack');
  78. Log::info($request->all());
  79. Log::info($request->getMethod());
  80. $key = env('MONTH_ORDER_KEY');//'sn7wluq5716brp8fzm';
  81. $app_id = $request->post('app_id');
  82. $plan_id = $request->post('plan_id',0);
  83. $user_id = $request->post('user_id');
  84. $total_fee = $request->post('total_fee');
  85. $trade_no = $request->post('trade_no');
  86. $out_trade_no = $request->post('out_trade_no');
  87. if($check = checkParam($request->except('_url'),['app_id','user_id','total_fee','trade_no','out_trade_no'])){
  88. return response()->error('PARAM_EMPTY',['msg'=>$check]);
  89. }
  90. $sign = _sign(compact('app_id','user_id','total_fee','trade_no','out_trade_no'),$key.$key);
  91. $sign = strtoupper($sign);
  92. Log::info('self sign is: '.$sign);
  93. $order_info = Order::find($user_id);
  94. if(!$order_info){
  95. Log::error('month order not exist !!!order is :'.$trade_no);
  96. return response('fail');
  97. }
  98. if($order_info->status == 'PAID'){
  99. Log::error('month order had deal !!!, order is :'.$trade_no);
  100. return response('fail');
  101. }
  102. //if($sign == $request->post('sign')){
  103. if(!UserMonthService::getOrderByOrder($trade_no,$out_trade_no)){
  104. UserMonthService::createLOrder($order_info->uid,$plan_id,$total_fee,$trade_no,$out_trade_no);
  105. $order_info->transaction_id = $trade_no;
  106. $order_info->status = 'PAID';
  107. self::addOrderAndVipV2($order_info->uid,$total_fee);
  108. }
  109. //}
  110. Log::info('orderCallBack--------------------endend----------------------orderCallBack');
  111. return response('success');
  112. }
  113. public function orderCallBack(Request $request){
  114. Log::info('orderCallBack------------------------------------------orderCallBack');
  115. Log::info($request->all());
  116. Log::info($request->getMethod());
  117. $key = env('MONTH_ORDER_KEY');//'sn7wluq5716brp8fzm';
  118. $app_id = $request->post('app_id');
  119. $plan_id = $request->post('plan_id',0);
  120. $user_id = $request->post('user_id');
  121. $total_fee = $request->post('total_fee');
  122. $trade_no = $request->post('trade_no');
  123. $out_trade_no = $request->post('out_trade_no');
  124. if($check = checkParam($request->except('_url'),['app_id','user_id','total_fee','trade_no','out_trade_no'])){
  125. return response()->error('PARAM_EMPTY',['msg'=>$check]);
  126. }
  127. $sign = _sign(compact('app_id','user_id','total_fee','trade_no','out_trade_no'),$key.$key);
  128. $sign = strtoupper($sign);
  129. //if($sign == $request->post('sign')){
  130. if(!UserMonthService::getOrderByOrder($trade_no,$out_trade_no)){
  131. UserMonthService::createLOrder($user_id,$plan_id,$total_fee,$trade_no,$out_trade_no);
  132. self::addOrderAndVip($user_id,$out_trade_no,$trade_no,$total_fee);
  133. }
  134. //}
  135. Log::info('orderCallBack--------------------endend----------------------orderCallBack');
  136. return response('success');
  137. }
  138. private function addOrderAndVip($uid,$out_trade_no,$trade_no,$price){
  139. $order_info = OrderService::getByTradeNo($out_trade_no);
  140. //订单已经存在
  141. if($order_info){
  142. return ;
  143. }
  144. $user_info = UserService::getById($uid);
  145. if(!$user_info) return ;
  146. $this->createOrder($uid,$user_info->distribution_channel_id,0,$price,$out_trade_no,$trade_no);
  147. YearOrderService::save_month_order([
  148. 'uid'=>$uid,
  149. 'distribution_channel_id'=>$user_info->distribution_channel_id,
  150. 'fee'=>$price / 100,
  151. 'send_order_id'=>0
  152. ]);
  153. }
  154. private function addOrderAndVipV2($uid,$price){
  155. $user_info = UserService::getById($uid);
  156. if(!$user_info) return ;
  157. YearOrderService::save_month_order([
  158. 'uid'=>$uid,
  159. 'distribution_channel_id'=>$user_info->distribution_channel_id,
  160. 'fee'=>$price / 100,
  161. 'send_order_id'=>0
  162. ]);
  163. }
  164. private function createOrder($uid,$distribution_channel_id,$product_id,$price,$trade_no,$transaction_id){
  165. $count = OrderService::getUserChargeTimes($uid);
  166. $count = $count + 1;
  167. $send_order_id = 0;
  168. try {
  169. $send_order_id = (int)Redis::hget('book_read:' . $uid, 'send_order_id');
  170. } catch (\Exception $e) {
  171. }
  172. $send_order_name = '';
  173. if ($send_order_id) {
  174. $send_order_info = SendOrderService::getById($send_order_id);
  175. if ($send_order_info && isset($send_order_info->name) && !empty($send_order_info->name)) {
  176. $send_order_name = $send_order_info->name;
  177. }
  178. }
  179. $init_order = [
  180. 'distribution_channel_id' => $distribution_channel_id,
  181. 'uid' => $uid,
  182. 'product_id' => 6826,
  183. 'price' => $price / 100,
  184. 'pay_type' => $count,
  185. 'trade_no' => $trade_no,
  186. 'pay_merchant_source' => 'MONTH',
  187. 'pay_merchant_id' => 99,
  188. 'create_ip' => '',
  189. 'send_order_id' => $send_order_id,
  190. 'send_order_name' => $send_order_name,
  191. 'order_type' => 'RECHARGE',
  192. 'from_bid' => '0',
  193. 'from_type' => 'auto_month',
  194. 'activity_id' => 0,
  195. 'inner_send_order_id' => '',
  196. 'status'=>'PAID',
  197. 'transaction_id'=>$transaction_id,
  198. 'pay_end_at'=>date('Y-m-d H:i:s')
  199. ];
  200. OrderService::save_order($init_order);
  201. }
  202. public function wait(Request $request){
  203. //$user_cookie = \Cookie::get(env('COOKIE_AUTH_WEB_WECHAT'));
  204. //$uid = $user_cookie ? decrypt($user_cookie) : null;
  205. $r = $request->get('r');
  206. $r = urldecode($r);
  207. return view('pay.order.monthpaywait',['url'=>$r]);
  208. }
  209. public function issuccess(Request $request){
  210. $uid = \Cookie::get(env('COOKIE_AUTH_WEB_WECHAT'));
  211. //$uid = $user_cookie ? decrypt($user_cookie) : null;
  212. if(!$uid){
  213. return response()->success();
  214. }
  215. $last = UserMonthService::getLastOrder($uid);
  216. if(!$last){
  217. return response()->error('WAP_SYS_ERROR');
  218. }
  219. if(time()-strtotime($last->created_at) <20){
  220. return response()->success();
  221. }
  222. return response()->error('WAP_SYS_ERROR');
  223. }
  224. }