CommController.php 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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. public function config()
  18. {
  19. return response([
  20. 'data' => [
  21. 'isEmailVerify' => (int)config('v2board.email_verify', 0) ? 1 : 0,
  22. 'isInviteForce' => (int)config('v2board.invite_force', 0) ? 1 : 0,
  23. 'emailWhitelistSuffix' => (int)config('v2board.email_whitelist_enable', 0)
  24. ? $this->getEmailSuffix()
  25. : 0,
  26. 'isRecaptcha' => (int)config('v2board.recaptcha_enable', 0) ? 1 : 0,
  27. 'recaptchaSiteKey' => config('v2board.recaptcha_site_key'),
  28. 'appDescription' => config('v2board.app_description')
  29. ]
  30. ]);
  31. }
  32. private function isEmailVerify()
  33. {
  34. return response([
  35. 'data' => (int)config('v2board.email_verify', 0) ? 1 : 0
  36. ]);
  37. }
  38. public function sendEmailVerify(CommSendEmailVerify $request)
  39. {
  40. if ((int)config('v2board.recaptcha_enable', 0)) {
  41. $recaptcha = new ReCaptcha(config('v2board.recaptcha_key'));
  42. $recaptchaResp = $recaptcha->verify($request->input('recaptcha_data'));
  43. if (!$recaptchaResp->isSuccess()) {
  44. abort(500, '验证码有误');
  45. }
  46. }
  47. $email = $request->input('email');
  48. if (Cache::get(CacheKey::get('LAST_SEND_EMAIL_VERIFY_TIMESTAMP', $email))) {
  49. abort(500, '验证码已发送,请过一会再请求');
  50. }
  51. $code = rand(100000, 999999);
  52. $subject = config('v2board.app_name', 'V2Board') . '邮箱验证码';
  53. SendEmailJob::dispatch([
  54. 'email' => $email,
  55. 'subject' => $subject,
  56. 'template_name' => 'verify',
  57. 'template_value' => [
  58. 'name' => config('v2board.app_name', 'V2Board'),
  59. 'code' => $code,
  60. 'url' => config('v2board.app_url')
  61. ]
  62. ]);
  63. Cache::put(CacheKey::get('EMAIL_VERIFY_CODE', $email), $code, 300);
  64. Cache::put(CacheKey::get('LAST_SEND_EMAIL_VERIFY_TIMESTAMP', $email), time(), 60);
  65. return response([
  66. 'data' => true
  67. ]);
  68. }
  69. public function pv(Request $request)
  70. {
  71. $inviteCode = InviteCode::where('code', $request->input('invite_code'))->first();
  72. if ($inviteCode) {
  73. $inviteCode->pv = $inviteCode->pv + 1;
  74. $inviteCode->save();
  75. }
  76. return response([
  77. 'data' => true
  78. ]);
  79. }
  80. private function getEmailSuffix()
  81. {
  82. $suffix = config('v2board.email_whitelist_suffix', Dict::EMAIL_WHITELIST_SUFFIX_DEFAULT);
  83. if (!is_array($suffix)) {
  84. return preg_split('/,/', $suffix);
  85. }
  86. return $suffix;
  87. }
  88. }