CommController.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. <?php
  2. namespace App\Http\Controllers\V1\Passport;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Passport\CommSendEmailVerify;
  5. use App\Jobs\SendEmailJob;
  6. use App\Models\InviteCode;
  7. use App\Models\User;
  8. use App\Utils\CacheKey;
  9. use App\Utils\Dict;
  10. use Illuminate\Http\Exceptions\HttpResponseException;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Support\Facades\Cache;
  13. use Illuminate\Support\Facades\Mail;
  14. use ReCaptcha\ReCaptcha;
  15. class CommController extends Controller
  16. {
  17. private function isEmailVerify()
  18. {
  19. return response([
  20. 'data' => (int)config('v2board.email_verify', 0) ? 1 : 0
  21. ]);
  22. }
  23. public function sendEmailVerify(CommSendEmailVerify $request)
  24. {
  25. if ((int)config('v2board.recaptcha_enable', 0)) {
  26. $recaptcha = new ReCaptcha(config('v2board.recaptcha_key'));
  27. $recaptchaResp = $recaptcha->verify($request->input('recaptcha_data'));
  28. if (!$recaptchaResp->isSuccess()) {
  29. abort(500, __('Invalid code is incorrect'));
  30. }
  31. }
  32. $email = $request->input('email');
  33. if (Cache::get(CacheKey::get('LAST_SEND_EMAIL_VERIFY_TIMESTAMP', $email))) {
  34. abort(500, __('Email verification code has been sent, please request again later'));
  35. }
  36. if (!User::where('email', $email)->first()) {
  37. return [
  38. 'data' => true
  39. ];
  40. }
  41. $code = rand(100000, 999999);
  42. $subject = config('v2board.app_name', 'V2Board') . __('Email verification code');
  43. SendEmailJob::dispatch([
  44. 'email' => $email,
  45. 'subject' => $subject,
  46. 'template_name' => 'verify',
  47. 'template_value' => [
  48. 'name' => config('v2board.app_name', 'V2Board'),
  49. 'code' => $code,
  50. 'url' => config('v2board.app_url')
  51. ]
  52. ]);
  53. Cache::put(CacheKey::get('EMAIL_VERIFY_CODE', $email), $code, 300);
  54. Cache::put(CacheKey::get('LAST_SEND_EMAIL_VERIFY_TIMESTAMP', $email), time(), 60);
  55. return response([
  56. 'data' => true
  57. ]);
  58. }
  59. public function pv(Request $request)
  60. {
  61. $inviteCode = InviteCode::where('code', $request->input('invite_code'))->first();
  62. if ($inviteCode) {
  63. $inviteCode->pv = $inviteCode->pv + 1;
  64. $inviteCode->save();
  65. }
  66. return response([
  67. 'data' => true
  68. ]);
  69. }
  70. private function getEmailSuffix()
  71. {
  72. $suffix = config('v2board.email_whitelist_suffix', Dict::EMAIL_WHITELIST_SUFFIX_DEFAULT);
  73. if (!is_array($suffix)) {
  74. return preg_split('/,/', $suffix);
  75. }
  76. return $suffix;
  77. }
  78. }