AccountController.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. $timeLimit = Carbon::now()->subDays(1)->toDateTimeString();
  35. $recentAttempt = EmailVerification::whereUserId(Auth::id())
  36. ->where('created_at', '>', $timeLimit)->count();
  37. $exists = EmailVerification::whereUserId(Auth::id())->count();
  38. if($recentAttempt == 1 && $exists == 1) {
  39. return redirect()->back()->with('error', 'A verification email has already been sent recently. Please check your email, or try again later.');
  40. } elseif ($recentAttempt == 0 && $exists !== 0) {
  41. // Delete old verification and send new one.
  42. EmailVerification::whereUserId(Auth::id())->delete();
  43. }
  44. $user = User::whereNull('email_verified_at')->find(Auth::id());
  45. $utoken = hash('sha512', $user->id);
  46. $rtoken = str_random(40);
  47. $verify = new EmailVerification;
  48. $verify->user_id = $user->id;
  49. $verify->email = $user->email;
  50. $verify->user_token = $utoken;
  51. $verify->random_token = $rtoken;
  52. $verify->save();
  53. Mail::to($user->email)->send(new ConfirmEmail($verify));
  54. return redirect()->back()->with('status', 'Email verification email sent!');
  55. }
  56. public function confirmVerifyEmail(Request $request, $userToken, $randomToken)
  57. {
  58. $verify = EmailVerification::where('user_token', $userToken)
  59. ->where('random_token', $randomToken)
  60. ->firstOrFail();
  61. if(Auth::id() === $verify->user_id) {
  62. $user = User::find(Auth::id());
  63. $user->email_verified_at = Carbon::now();
  64. $user->save();
  65. return redirect('/');
  66. }
  67. }
  68. public function fetchNotifications($id)
  69. {
  70. $key = config('cache.prefix') . ":user.{$id}.notifications";
  71. $redis = Redis::connection();
  72. $notifications = $redis->lrange($key, 0, 30);
  73. if(empty($notifications)) {
  74. $notifications = Notification::whereProfileId($id)
  75. ->orderBy('id','desc')->take(30)->get();
  76. } else {
  77. $notifications = $this->hydrateNotifications($notifications);
  78. }
  79. return $notifications;
  80. }
  81. public function hydrateNotifications($keys)
  82. {
  83. $prefix = 'notification.';
  84. $notifications = collect([]);
  85. foreach($keys as $key) {
  86. $notifications->push(Cache::get("{$prefix}{$key}"));
  87. }
  88. return $notifications;
  89. }
  90. }