XiyueController.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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. $amount = $request->post('amount');
  15. $amount = (int)$amount;
  16. $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
  17. if($sign != $mySign){
  18. return response()->error('PARAM_ERROR');
  19. }
  20. $user = UserService::getUserByUnionAndChannelId($openid,6985);
  21. if(!$user){
  22. $user = UserService::addUser(
  23. ['openid' => $openid,
  24. 'unionid' => $openid,
  25. 'distribution_channel_id' =>6985,
  26. 'send_order_id'=>0,
  27. 'is_new'=>1,
  28. 'register_ip'=>''
  29. ]);
  30. }else{
  31. $this->_xiyueConsume($openid,$amount);
  32. }
  33. $result = DB::table('xiyue_zsy_users')->where('uid',$user->id)->select('id')->first();
  34. if(!$result){
  35. DB::table('xiyue_zsy_users')->insert([
  36. 'uid'=>$user->id,
  37. 'xiyue_uid'=>0,
  38. 'openid'=>$openid,
  39. 'created_at'=>date('Y-m-d H:i:s'),
  40. 'updated_at'=>date('Y-m-d H:i:s')
  41. ]);
  42. }
  43. YearOrderService::save_year_order([
  44. 'uid'=>$user->id,
  45. 'fee'=>0,
  46. 'send_order_id'=>0,
  47. 'distribution_channel_id'=>6985
  48. ]);
  49. UserWealthyOperateRecordService::create($user->id,365,6985,'yearRecharge',20190828);
  50. return response()->success();
  51. }
  52. public function getUserBalance(Request $request){
  53. $openid = $request->post('openid');
  54. $sign = $request->post('sign');
  55. $mySign = _sign(compact('openid'),'8T5MJy4FsJoZspq8');
  56. if($sign != $mySign){
  57. return response()->error('PARAM_ERROR');
  58. }
  59. $user = UserService::getUserByUnionAndChannelId($openid,6985);
  60. return response()->success($user);
  61. }
  62. private function _xiyueConsume($openid,$amount){
  63. $user = UserService::getUserByOpenidAndChannelId($openid,6985);
  64. if(!$user) return false;
  65. if($amount <= 0){
  66. return false;
  67. }
  68. if($amount > $user->balance || $amount > $user->charge_balance){
  69. return false;
  70. }
  71. $data = [];
  72. $data['uid'] = $user->id;
  73. $data['type'] = 'xiyueconsume';
  74. $data['attach'] = '';
  75. $data['created_at'] = date('Y-m-d H:i:s');
  76. $data['updated_at'] = date('Y-m-d H:i:s');
  77. $data['balance'] = $amount;
  78. if ($user->charge_balance >= $amount) {
  79. $data['charge_balance'] = $amount;
  80. $data['reward_balance'] = 0;
  81. $user->balance -= $amount;
  82. $user->charge_balance -= $amount;
  83. } elseif ($user->charge_balance > 0) {
  84. $data['charge_balance'] = $user->charge_balance;
  85. $data['reward_balance'] = $amount - $user->charge_balance;
  86. $reward = $amount - $user->charge_balance;
  87. $user->balance -= $amount;
  88. $user->charge_balance = 0;
  89. $user->reward_balance -= $reward;
  90. } else {
  91. $data['charge_balance'] = 0;
  92. $data['reward_balance'] = $amount;
  93. $user->balance -= $amount;
  94. $user->reward_balance -= $amount;
  95. }
  96. $user->save();
  97. DB::table('user_other_consume_record')->insert($data);
  98. return true;
  99. }
  100. public function xiyueConsume(Request $request){
  101. $openid = $request->post('openid');
  102. $sign = $request->post('sign');
  103. $amount = $request->post('amount');
  104. $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
  105. if(!$openid || !$amount || ($sign != $mySign)){
  106. return response()->error('PARAM_ERROR');
  107. }
  108. $user = UserService::getUserByOpenidAndChannelId($openid,6985);
  109. if(!$user) return response()->error('PARAM_ERROR');
  110. if($amount <= 0){
  111. return response()->error('PARAM_ERROR');
  112. }
  113. if($amount > $user->balance || $amount > $user->charge_balance){
  114. return response()->error('WAP_INSUFFICIENT_BALANCE');
  115. }
  116. $data = [];
  117. $data['uid'] = $user->id;
  118. $data['type'] = 'xiyueconsume';
  119. $data['attach'] = '';
  120. $data['created_at'] = date('Y-m-d H:i:s');
  121. $data['updated_at'] = date('Y-m-d H:i:s');
  122. $data['balance'] = $amount;
  123. if ($user->charge_balance >= $amount) {
  124. $data['charge_balance'] = $amount;
  125. $data['reward_balance'] = 0;
  126. $user->balance -= $amount;
  127. $user->charge_balance -= $amount;
  128. } elseif ($user->charge_balance > 0) {
  129. $data['charge_balance'] = $user->charge_balance;
  130. $data['reward_balance'] = $amount - $user->charge_balance;
  131. $reward = $amount - $user->charge_balance;
  132. $user->balance -= $amount;
  133. $user->charge_balance = 0;
  134. $user->reward_balance -= $reward;
  135. } else {
  136. $data['charge_balance'] = 0;
  137. $data['reward_balance'] = $amount;
  138. $user->balance -= $amount;
  139. $user->reward_balance -= $amount;
  140. }
  141. $user->save();
  142. DB::table('user_other_consume_record')->insert($data);
  143. return response()->success($user);
  144. }
  145. }