InviteController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <?php
  2. namespace App\Http\Controllers\User;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. use App\Models\User;
  6. use App\Models\Order;
  7. use App\Models\InviteCode;
  8. use App\Utils\Helper;
  9. class InviteController extends Controller
  10. {
  11. public function save(Request $request)
  12. {
  13. if (InviteCode::where('user_id', $request->session()->get('id'))->where('status', 0)->count() >= config('v2board.invite_gen_limit', 5)) {
  14. abort(500, '已达到创建数量上限');
  15. }
  16. $inviteCode = new InviteCode();
  17. $inviteCode->user_id = $request->session()->get('id');
  18. $inviteCode->code = Helper::randomChar(8);
  19. return response([
  20. 'data' => $inviteCode->save()
  21. ]);
  22. }
  23. public function details(Request $request)
  24. {
  25. return response([
  26. 'data' => Order::where('invite_user_id', $request->session()->get('id'))
  27. ->where('commission_balance', '>', 0)
  28. ->where('status', 3)
  29. ->select([
  30. 'id',
  31. 'commission_status',
  32. 'commission_balance',
  33. 'created_at',
  34. 'updated_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. }