InviteController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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. ->where('get_amount', '>', 0)
  29. ->select([
  30. 'id',
  31. 'trade_no',
  32. 'order_amount',
  33. 'get_amount',
  34. 'created_at'
  35. ])
  36. ->get()
  37. ]);
  38. }
  39. public function fetch(Request $request)
  40. {
  41. $codes = InviteCode::where('user_id', $request->session()->get('id'))
  42. ->where('status', 0)
  43. ->get();
  44. $commission_rate = config('v2board.invite_commission', 10);
  45. $user = User::find($request->session()->get('id'));
  46. if ($user->commission_rate) {
  47. $commission_rate = $user->commission_rate;
  48. }
  49. $stat = [
  50. //已注册用户数
  51. (int)User::where('invite_user_id', $request->session()->get('id'))->count(),
  52. //有效的佣金
  53. (int)Order::where('status', 3)
  54. ->where('commission_status', 2)
  55. ->where('invite_user_id', $request->session()->get('id'))
  56. ->sum('commission_balance'),
  57. //确认中的佣金
  58. (int)Order::where('status', 3)
  59. ->where('commission_status', 0)
  60. ->where('invite_user_id', $request->session()->get('id'))
  61. ->sum('commission_balance'),
  62. //佣金比例
  63. (int)$commission_rate,
  64. //可用佣金
  65. (int)$user->commission_balance
  66. ];
  67. return response([
  68. 'data' => [
  69. 'codes' => $codes,
  70. 'stat' => $stat
  71. ]
  72. ]);
  73. }
  74. }