InviteController.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php
  2. namespace App\Http\Controllers\User;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\CommissionLog;
  5. use Illuminate\Http\Request;
  6. use App\Models\User;
  7. use App\Models\Order;
  8. use App\Models\InviteCode;
  9. use App\Utils\Helper;
  10. class InviteController extends Controller
  11. {
  12. public function save(Request $request)
  13. {
  14. if (InviteCode::where('user_id', $request->session()->get('id'))->where('status', 0)->count() >= config('v2board.invite_gen_limit', 5)) {
  15. abort(500, __('The maximum number of creations has been reached'));
  16. }
  17. $inviteCode = new InviteCode();
  18. $inviteCode->user_id = $request->session()->get('id');
  19. $inviteCode->code = Helper::randomChar(8);
  20. return response([
  21. 'data' => $inviteCode->save()
  22. ]);
  23. }
  24. public function details(Request $request)
  25. {
  26. return response([
  27. 'data' => CommissionLog::where('invite_user_id', $request->session()->get('id'))
  28. ->select([
  29. 'id',
  30. 'trade_no',
  31. 'order_amount',
  32. 'get_amount',
  33. 'created_at'
  34. ])
  35. ->get()
  36. ]);
  37. }
  38. public function fetch(Request $request)
  39. {
  40. $codes = InviteCode::where('user_id', $request->session()->get('id'))
  41. ->where('status', 0)
  42. ->get();
  43. $commission_rate = config('v2board.invite_commission', 10);
  44. $user = User::find($request->session()->get('id'));
  45. if ($user->commission_rate) {
  46. $commission_rate = $user->commission_rate;
  47. }
  48. $stat = [
  49. //已注册用户数
  50. (int)User::where('invite_user_id', $request->session()->get('id'))->count(),
  51. //有效的佣金
  52. (int)Order::where('status', 3)
  53. ->where('commission_status', 2)
  54. ->where('invite_user_id', $request->session()->get('id'))
  55. ->sum('commission_balance'),
  56. //确认中的佣金
  57. (int)Order::where('status', 3)
  58. ->where('commission_status', 0)
  59. ->where('invite_user_id', $request->session()->get('id'))
  60. ->sum('commission_balance'),
  61. //佣金比例
  62. (int)$commission_rate,
  63. //可用佣金
  64. (int)$user->commission_balance
  65. ];
  66. return response([
  67. 'data' => [
  68. 'codes' => $codes,
  69. 'stat' => $stat
  70. ]
  71. ]);
  72. }
  73. }