UserWealthController.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: admin
  5. * Date: 2018/9/20
  6. * Time: 14:22
  7. */
  8. namespace App\Http\Controllers\Manage\User;
  9. use App\Http\Controllers\Manage\BaseController;
  10. use App\Modules\Subscribe\Models\YearOrder;
  11. use App\Modules\Subscribe\Services\YearOrderService;
  12. use App\Modules\User\Models\User;
  13. use App\Modules\User\Services\UserService;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Routing\Controller;
  16. use DB;
  17. class UserWealthController extends BaseController
  18. {
  19. public function addBookCoin(Request $request)
  20. {
  21. $uid = $request->input('uid', '');
  22. $coinNum = $request->input('coinNum', 0);
  23. if (!$uid) {
  24. return response()->error('PARAM_EMPTY');
  25. }
  26. $userInfo = User::where('id', $uid)->first();
  27. if (!$userInfo) {
  28. return response()->error('PARAM_ERROR');
  29. }
  30. //加币
  31. if ($coinNum >= 0) {
  32. $userInfo->balance += $coinNum;
  33. $userInfo->reward_balance += $coinNum;
  34. $userInfo->save();
  35. //减币
  36. } else {
  37. if ($userInfo->balance + $coinNum >= 0) {
  38. //reword 够减除
  39. if ($userInfo->reward_balance + $coinNum >= 0) {
  40. $userInfo->reward_balance += $coinNum;
  41. //reword 不够减除
  42. } else {
  43. //先把reword减完
  44. $rewordCoin = $userInfo->reward_balance;
  45. $userInfo->reward_balance = 0;
  46. $userInfo->charge_balance = $userInfo->charge_balance + $coinNum + $rewordCoin;
  47. }
  48. $userInfo->balance += $coinNum;
  49. $userInfo->save();
  50. //余额不够
  51. } else {
  52. return response()->error('BALANCE_NOT_ENOUGH');
  53. }
  54. }
  55. $record = array(
  56. 'uid' => $uid,
  57. 'operator' => $request->session()->get('manage_auth'),
  58. 'coin_num' => $coinNum,
  59. 'type' => 'addCoin',
  60. 'created_at' => date('Y-m-d H:i:s'),
  61. 'updated_at' => date('Y-m-d H:i:s')
  62. );
  63. DB::table('user_wealthy_operate_record')->insert($record);
  64. return response()->success();
  65. }
  66. /**
  67. * 用户间转移书币
  68. * @param Request $request
  69. * @param from_uid
  70. * @param to_uid
  71. * @return mixed
  72. */
  73. function transBalanceByUser(Request $request)
  74. {
  75. $to_uid = $request->has('to_uid') ? $request->input('to_uid') : '';
  76. $from_uid = $request->has('from_uid') ? $request->input('from_uid') : '';
  77. if (empty($to_uid) || empty($from_uid)) {
  78. return response()->error('PARAM_EMPTY');
  79. }
  80. if ($from_uid == $to_uid) {
  81. return response()->error('SAME_ACCOUNT_ERROR');
  82. }
  83. $result = UserService::transfromBalanceByUser($from_uid, $to_uid);
  84. if ($result) {
  85. return response()->success();
  86. } else {
  87. return response()->error('HANDLE_FAILED');
  88. }
  89. }
  90. public function updateUserYearOrders(Request $request)
  91. {
  92. $uid = $request->input('uid', '');
  93. $distribution = $request->input('channelId', '');
  94. if (!$uid || !$distribution) {
  95. return response()->error('PARAM_EMPTY');
  96. }
  97. //$start_time = $request->input('start_time','');
  98. $end_time = $request->input('end_time', '');
  99. if (!$end_time) {
  100. return response()->error('PARAM_EMPTY');
  101. }
  102. if (!strtotime($end_time)) {
  103. return response()->error('PARAM_ERROR');
  104. }
  105. $data = [
  106. 'uid' => $uid,
  107. 'begin_time' => date('Y-m-d H:i:s'),
  108. 'end_time' => $end_time . ' ' . date('H:i:s'),
  109. 'u' => 0,
  110. 'send_order_id' => 0,
  111. 'fee' => 0,
  112. 'distribution_channel_id' => $distribution
  113. ];
  114. $yearOrder = YearOrderService::getRecord($uid);
  115. if ($yearOrder) {
  116. $yearOrderEndTime = $yearOrder->end_time;
  117. //更新的时间 小于 现在包年的到期时间
  118. if (strtotime($end_time) < strtotime($yearOrderEndTime)) {
  119. return ['code' => 304, 'msg' => '用户在该渠道已存在包年!'];
  120. } else {
  121. //延长到期时间
  122. $updateEndTime = $end_time . ' ' . date('H:i:s');
  123. $res = YearOrder::updateEndtime($yearOrder->id, $updateEndTime);
  124. if (!$res) {
  125. return response()->error("HANDLE_FAILED");
  126. }
  127. }
  128. } else {
  129. YearOrder::create($data);
  130. }
  131. $record = array(
  132. 'operator' => $request->session()->get('manage_auth'),
  133. 'uid' => $uid,
  134. 'endtime' => $data['end_time'],
  135. 'channel_id' => $distribution,
  136. 'type' => 'yearRecharge',
  137. 'created_at' => date('Y-m-d H:i:s'),
  138. 'updated_at' => date('Y-m-d H:i:s')
  139. );
  140. DB::table('user_wealthy_operate_record')->insert($record);
  141. return response()->success();
  142. }
  143. }