XiyueController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <?php
  2. namespace App\Http\Controllers\Wap\Other;
  3. use App\Modules\Subscribe\Services\YearOrderService;
  4. use App\Modules\User\Services\ReadRecordService;
  5. use App\Modules\User\Services\UserService;
  6. use App\Modules\User\Services\UserWealthyOperateRecordService;
  7. use Illuminate\Http\Request;
  8. use App\Http\Controllers\Controller;
  9. use DB;
  10. class XiyueController extends Controller
  11. {
  12. public function xiyuePayNotity(Request $request){
  13. $openid = $request->post('openid');
  14. $sign = $request->post('sign');
  15. $amount = $request->post('amount');
  16. $amount = (int)$amount;
  17. $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
  18. if($sign != $mySign){
  19. return response()->error('PARAM_ERROR');
  20. }
  21. $user = UserService::getUserByUnionAndChannelId($openid,6985);
  22. if(!$user){
  23. $user = UserService::addUser(
  24. ['openid' => $openid,
  25. 'unionid' => $openid,
  26. 'distribution_channel_id' =>6985,
  27. 'send_order_id'=>0,
  28. 'is_new'=>1,
  29. 'register_ip'=>''
  30. ]);
  31. }
  32. $this->_xiyueConsume($openid,$amount);
  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. $user = $this->selectXiyueUser($openid);
  61. return response()->success($user);
  62. }
  63. private function _xiyueConsume($openid,$amount){
  64. if($amount <= 0){
  65. return false;
  66. }
  67. //$user = UserService::getUserByOpenidAndChannelId($openid,6985);
  68. $user = $this->selectXiyueUser($openid);
  69. if(!$user) return false;
  70. /*if($amount > $user->balance || $amount > $user->charge_balance){
  71. return false;
  72. }*/
  73. $consume_amount = $amount;
  74. if($amount > $user->charge_balance){
  75. $consume_amount = $user->charge_balance;
  76. }
  77. if(!$consume_amount)return false;
  78. $data = [];
  79. $data['uid'] = $user->id;
  80. $data['type'] = 'xiyueconsume';
  81. $data['attach'] = '';
  82. $data['created_at'] = date('Y-m-d H:i:s');
  83. $data['updated_at'] = date('Y-m-d H:i:s');
  84. $data['balance'] = $amount;
  85. if ($user->charge_balance >= $consume_amount) {
  86. $data['charge_balance'] = $consume_amount;
  87. $data['reward_balance'] = 0;
  88. $user->balance -= $consume_amount;
  89. $user->charge_balance -= $consume_amount;
  90. } elseif ($user->charge_balance > 0) {
  91. $data['charge_balance'] = $user->charge_balance;
  92. $data['reward_balance'] = $consume_amount - $user->charge_balance;
  93. $reward = $consume_amount - $user->charge_balance;
  94. $user->balance -= $consume_amount;
  95. $user->charge_balance = 0;
  96. $user->reward_balance -= $reward;
  97. } else {
  98. $data['charge_balance'] = 0;
  99. $data['reward_balance'] = $consume_amount;
  100. $user->balance -= $consume_amount;
  101. $user->reward_balance -= $consume_amount;
  102. }
  103. $user->save();
  104. DB::table('user_other_consume_record')->insert($data);
  105. return true;
  106. }
  107. private function selectXiyueUser($openid){
  108. $user = UserService::getUserByOpenidAndChannelId($openid,6985);
  109. if($user->charge_balance >0) return $user;
  110. $all_user = UserService::getUserByOpenid($openid);
  111. $select_user = null;
  112. $temp_time = 0;
  113. foreach ($all_user as $user_item){
  114. if($user_item->distribution_channel_id == 6985) continue;
  115. if($user_item->charge_balance >0){
  116. $last_read_info = ReadRecordService::getByField($user_item->id,'last_read');
  117. if(!$last_read_info) continue;
  118. list($bid,$cid,$time) = explode('_',$last_read_info);
  119. if($time >$temp_time) $select_user = $user_item;
  120. }
  121. }
  122. if(!$select_user) return $user;
  123. return $select_user;
  124. }
  125. public function xiyueConsume(Request $request){
  126. $openid = $request->post('openid');
  127. $sign = $request->post('sign');
  128. $amount = $request->post('amount');
  129. $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
  130. if(!$openid || !$amount || ($sign != $mySign)){
  131. return response()->error('PARAM_ERROR');
  132. }
  133. $user = UserService::getUserByOpenidAndChannelId($openid,6985);
  134. if(!$user) return response()->error('PARAM_ERROR');
  135. if($amount <= 0){
  136. return response()->error('PARAM_ERROR');
  137. }
  138. if($amount > $user->balance || $amount > $user->charge_balance){
  139. return response()->error('WAP_INSUFFICIENT_BALANCE');
  140. }
  141. $data = [];
  142. $data['uid'] = $user->id;
  143. $data['type'] = 'xiyueconsume';
  144. $data['attach'] = '';
  145. $data['created_at'] = date('Y-m-d H:i:s');
  146. $data['updated_at'] = date('Y-m-d H:i:s');
  147. $data['balance'] = $amount;
  148. if ($user->charge_balance >= $amount) {
  149. $data['charge_balance'] = $amount;
  150. $data['reward_balance'] = 0;
  151. $user->balance -= $amount;
  152. $user->charge_balance -= $amount;
  153. } elseif ($user->charge_balance > 0) {
  154. $data['charge_balance'] = $user->charge_balance;
  155. $data['reward_balance'] = $amount - $user->charge_balance;
  156. $reward = $amount - $user->charge_balance;
  157. $user->balance -= $amount;
  158. $user->charge_balance = 0;
  159. $user->reward_balance -= $reward;
  160. } else {
  161. $data['charge_balance'] = 0;
  162. $data['reward_balance'] = $amount;
  163. $user->balance -= $amount;
  164. $user->reward_balance -= $amount;
  165. }
  166. $user->save();
  167. DB::table('user_other_consume_record')->insert($data);
  168. return response()->success($user);
  169. }
  170. }