AccountController.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use Carbon\Carbon;
  5. use App\Mail\ConfirmEmail;
  6. use Auth, DB, Cache, Mail, Redis;
  7. use App\{EmailVerification, Notification, Profile, User};
  8. class AccountController extends Controller
  9. {
  10. public function __construct()
  11. {
  12. $this->middleware('auth');
  13. }
  14. public function notifications(Request $request)
  15. {
  16. $this->validate($request, [
  17. 'page' => 'nullable|min:1|max:3'
  18. ]);
  19. $profile = Auth::user()->profile;
  20. $timeago = Carbon::now()->subMonths(6);
  21. $notifications = Notification::whereProfileId($profile->id)
  22. ->whereDate('created_at', '>', $timeago)
  23. ->orderBy('id','desc')
  24. ->take(30)
  25. ->simplePaginate();
  26. return view('account.activity', compact('profile', 'notifications'));
  27. }
  28. public function verifyEmail(Request $request)
  29. {
  30. return view('account.verify_email');
  31. }
  32. public function sendVerifyEmail(Request $request)
  33. {
  34. if(EmailVerification::whereUserId(Auth::id())->count() !== 0) {
  35. return redirect()->back()->with('status', 'A verification email has already been sent! Please check your email.');
  36. }
  37. $user = User::whereNull('email_verified_at')->find(Auth::id());
  38. $utoken = hash('sha512', $user->id);
  39. $rtoken = str_random(40);
  40. $verify = new EmailVerification;
  41. $verify->user_id = $user->id;
  42. $verify->email = $user->email;
  43. $verify->user_token = $utoken;
  44. $verify->random_token = $rtoken;
  45. $verify->save();
  46. Mail::to($user->email)->send(new ConfirmEmail($verify));
  47. return redirect()->back()->with('status', 'Email verification email sent!');
  48. }
  49. public function confirmVerifyEmail(Request $request, $userToken, $randomToken)
  50. {
  51. $verify = EmailVerification::where(DB::raw('BINARY user_token'), $userToken)
  52. ->where(DB::raw('BINARY random_token'), $randomToken)
  53. ->firstOrFail();
  54. if(Auth::id() === $verify->user_id) {
  55. $user = User::find(Auth::id());
  56. $user->email_verified_at = Carbon::now();
  57. $user->save();
  58. return redirect('/timeline');
  59. }
  60. }
  61. public function fetchNotifications($id)
  62. {
  63. $key = config('cache.prefix') . ":user.{$id}.notifications";
  64. $redis = Redis::connection();
  65. $notifications = $redis->lrange($key, 0, 30);
  66. if(empty($notifications)) {
  67. $notifications = Notification::whereProfileId($id)
  68. ->orderBy('id','desc')->take(30)->get();
  69. } else {
  70. $notifications = $this->hydrateNotifications($notifications);
  71. }
  72. return $notifications;
  73. }
  74. public function hydrateNotifications($keys)
  75. {
  76. $prefix = 'notification.';
  77. $notifications = collect([]);
  78. foreach($keys as $key) {
  79. $notifications->push(Cache::get("{$prefix}{$key}"));
  80. }
  81. return $notifications;
  82. }
  83. }