XiyueController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. namespace App\Http\Controllers\Wap\Other;
  3. use App\Modules\Subscribe\Services\YearOrderService;
  4. use App\Modules\User\Services\UserService;
  5. use App\Modules\User\Services\UserWealthyOperateRecordService;
  6. use Illuminate\Http\Request;
  7. use App\Http\Controllers\Controller;
  8. use DB;
  9. class XiyueController extends Controller
  10. {
  11. public function xiyuePayNotity(Request $request){
  12. $openid = $request->post('openid');
  13. $sign = $request->post('sign');
  14. $mySign = _sign(compact('openid'),'8T5MJy4FsJoZspq8');
  15. if($sign != $mySign){
  16. return response()->error('PARAM_ERROR');
  17. }
  18. $user = UserService::getUserByUnionAndChannelId($openid,6985);
  19. if(!$user){
  20. $user = UserService::addUser(
  21. ['openid' => $openid,
  22. 'unionid' => $openid,
  23. 'distribution_channel_id' =>6985,
  24. 'send_order_id'=>0,
  25. 'is_new'=>1,
  26. 'register_ip'=>''
  27. ]);
  28. }
  29. YearOrderService::save_year_order([
  30. 'uid'=>$user->id,
  31. 'fee'=>0,
  32. 'send_order_id'=>0,
  33. 'distribution_channel_id'=>6985
  34. ]);
  35. UserWealthyOperateRecordService::create($user->id,365,6985,'yearRecharge',20190828);
  36. return response()->success();
  37. }
  38. public function getUserBalance(Request $request){
  39. $openid = $request->get('openid');
  40. $sign = $request->get('sign');
  41. $mySign = _sign(compact('openid'),'8T5MJy4FsJoZspq8');
  42. if($sign != $mySign){
  43. return response()->error('PARAM_ERROR');
  44. }
  45. $user = UserService::getUserByUnionAndChannelId($openid,6985);
  46. return response()->success($user);
  47. }
  48. public function xiyueConsume(Request $request){
  49. $openid = $request->post('openid');
  50. $sign = $request->post('sign');
  51. $amount = $request->post('amount');
  52. $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
  53. if(!$openid || !$amount || ($sign != $mySign)){
  54. return response()->error('PARAM_ERROR');
  55. }
  56. $user = UserService::getUserByOpenidAndChannelId($openid,6985);
  57. if(!$user) return response()->error('PARAM_ERROR');
  58. if($amount <= 0){
  59. return response()->error('PARAM_ERROR');
  60. }
  61. if($amount > $user->balance){
  62. return response()->error('PARAM_ERROR');
  63. }
  64. $data = [];
  65. $data['uid'] = $user->id;
  66. $data['type'] = 'xiyueconsume';
  67. $data['attach'] = '';
  68. $data['created_at'] = date('Y-m-d H:i:s');
  69. $data['updated_at'] = date('Y-m-d H:i:s');
  70. $data['balance'] = $amount;
  71. if ($user->charge_balance >= $amount) {
  72. $data['charge_balance'] = $amount;
  73. $data['reward_balance'] = 0;
  74. $user->balance -= $amount;
  75. $user->charge_balance -= $amount;
  76. } elseif ($user->charge_balance > 0) {
  77. $data['charge_balance'] = $user->charge_balance;
  78. $data['reward_balance'] = $amount - $user->charge_balance;
  79. $reward = $amount - $user->charge_balance;
  80. $user->balance -= $amount;
  81. $user->charge_balance = 0;
  82. $user->reward_balance -= $reward;
  83. } else {
  84. $data['charge_balance'] = 0;
  85. $data['reward_balance'] = $amount;
  86. $user->balance -= $amount;
  87. $user->reward_balance -= $amount;
  88. }
  89. $user->save();
  90. DB::table('user_other_consume_record')->insert($data);
  91. return response()->success($user);
  92. }
  93. }