Laravel Проверка регистрации по электронной почте API - PullRequest
0 голосов
/ 14 апреля 2020

Я пытаюсь внедрить Laravel Проверка электронной почты после проверки в Laravel API

Но я не могу отправить его после регистрации. Но я смог отправить его вручную

В моем маршруте API у меня есть это

Route::get('/email/resend', 'Api\VerificationController@resend')->name('verification.resend');
Route::get('/email/verify/{id}/{hash}', 'Api\VerificationController@verify')->name('verification.verify');

В моем контроллере у меня есть это

<?php

namespace App\Http\Controllers\Api;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Illuminate\Auth\Events\Verified;
use Illuminate\Foundation\Auth\VerifiesEmails;
use Illuminate\Auth\Access\AuthorizationException;

class VerificationController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Email Verification Controller
    |--------------------------------------------------------------------------
    |
    | This controller is responsible for handling email verification for any
    | user that recently registered with the application. Emails may also
    | be re-sent if the user didn't receive the original email message.
    |
    */

    use VerifiesEmails;

    /**
     * Where to redirect users after verification.
     *
     * @var string
     */
    protected $redirectTo = '/home';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('auth:api')->only('resend');
        $this->middleware('signed')->only('verify');
        $this->middleware('throttle:6,1')->only('verify', 'resend');
    }

    /**
     * Resend the email verification notification.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function resend(Request $request)
    {
        if ($request->user()->hasVerifiedEmail()) {

            return response(['message'=>'Already verified']);
        }

        $request->user()->sendEmailVerificationNotification();

        if ($request->wantsJson()) {
            return response(['message' => 'Email Sent']);
        }

        return back()->with('resent', true);
    }


    /**
     * Mark the authenticated user's email address as verified.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     * @throws \Illuminate\Auth\Access\AuthorizationException
     */
    public function verify(Request $request)
    {
        auth()->loginUsingId($request->route('id'));

        if ($request->route('id') != $request->user()->getKey()) {
            throw new AuthorizationException;
        }

        if ($request->user()->hasVerifiedEmail()) {

            return response(['message'=>'Already verified']);

            // return redirect($this->redirectPath());
        }

        if ($request->user()->markEmailAsVerified()) {
            event(new Verified($request->user()));
        }

        return response(['message'=>'Successfully verified']);

    }


}

Я хочу иметь возможность отправлять его автоматически, когда пользователь регистрирует способ его работы в Интернете

1 Ответ

0 голосов
/ 14 апреля 2020

Я исправил это, сделав это

public function register(Request $request)
{
/*     $validatedData = $request->validate([
         'name'=>'required|max:55',
         'email'=>'email|required|unique:users',
         'password'=>'required|confirmed'
     ]);

     $validatedData['password'] = bcrypt($request->password);
     $user = User::create($validatedData);
     $accessToken = $user->createToken('authToken')->accessToken;
     return response(['user'=> $user, 'access_token'=> $accessToken]);
    */
    $request->validate([
        'name' => 'required|max:55',
        'email' => 'required|string|email|unique:users',
        'password' => 'required|string|confirmed',
    //    'phone_number' => 'required|string|min:6',

    ]);
    $user = new User([
        'name' => $request->name,
        'email' => $request->email,
        'password' => bcrypt($request->password),
   //     'phone_number' => $request['phone_number'],
    ]);
    $user->save();
    $accessToken = $user->createToken('authToken')->accessToken;

        Auth::login($user,true);
        $user->sendEmailVerificationNotification();

        $success = 'Please confirm yourself by clicking on verify user button sent to you on your email';

        return response(['user'=> $user, 'access_token'=> $accessToken, 'message' =>  $success,]);

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...