CommController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. namespace App\Http\Controllers\Passport;
  3. use App\Http\Requests\Passport\CommSendEmailVerify;
  4. use Illuminate\Http\Request;
  5. use App\Http\Controllers\Controller;
  6. use Illuminate\Http\Exceptions\HttpResponseException;
  7. use Illuminate\Support\Facades\Mail;
  8. use App\Utils\Helper;
  9. use Illuminate\Support\Facades\Cache;
  10. use App\Jobs\SendEmailJob;
  11. use App\Models\InviteCode;
  12. use App\Utils\Dict;
  13. use App\Utils\CacheKey;
  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. $code = rand(100000, 999999);
  37. $subject = config('v2board.app_name', 'V2Board') . __('Email verification code');
  38. SendEmailJob::dispatch([
  39. 'email' => $email,
  40. 'subject' => $subject,
  41. 'template_name' => 'verify',
  42. 'template_value' => [
  43. 'name' => config('v2board.app_name', 'V2Board'),
  44. 'code' => $code,
  45. 'url' => config('v2board.app_url')
  46. ]
  47. ]);
  48. Cache::put(CacheKey::get('EMAIL_VERIFY_CODE', $email), $code, 300);
  49. Cache::put(CacheKey::get('LAST_SEND_EMAIL_VERIFY_TIMESTAMP', $email), time(), 60);
  50. return response([
  51. 'data' => true
  52. ]);
  53. }
  54. public function pv(Request $request)
  55. {
  56. $inviteCode = InviteCode::where('code', $request->input('invite_code'))->first();
  57. if ($inviteCode) {
  58. $inviteCode->pv = $inviteCode->pv + 1;
  59. $inviteCode->save();
  60. }
  61. return response([
  62. 'data' => true
  63. ]);
  64. }
  65. private function getEmailSuffix()
  66. {
  67. $suffix = config('v2board.email_whitelist_suffix', Dict::EMAIL_WHITELIST_SUFFIX_DEFAULT);
  68. if (!is_array($suffix)) {
  69. return preg_split('/,/', $suffix);
  70. }
  71. return $suffix;
  72. }
  73. }