Невозможно получить токен и данные пользователя одновременно при использовании Vue. js, laravel / passport и GuzzleHttp. - PullRequest
1 голос
/ 05 апреля 2020

Я не могу получить пользовательские данные и токен на предъявителя одновременно. Использование vue 2.5 и laravel 7.2.2

Я использую GuzzleHttp, чтобы сделать запрос к серверу для получения токена.

Для запроса на go через я запускаю вторую команду php artisan serve --port 8006.

Пользователь существует в базе данных - подтвердил.

Мой AuthController:

use App\User;
use App\Shop;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use \GuzzleHttp\Client;
use DB;

public function login(Request $request)
{

    $user = User::where('email', $request->email)->get();

    $client = new Client([
        'base_uri' => 'http://127.0.0.1:8006',
        'timeout' => 5
    ]);

    try {

        $response = $client->request('POST', 'oauth/token', [
            'form_params' => [
                'grant_type' => 'password',
                'client_id' => 2,
                'client_secret' => DB::table('oauth_clients')->where('id', 2)->first()->secret,
                'username' => $request->email,
                'password' => $request->password,
            ]
        ]);

        $user->token = $response->getBody();

        return $user;
    } catch (\GuzzleHttp\Exception\BadResponseException $e) {
        if ($e->getCode() === 400 || $e->getCode() == 401) {
            return response()->json(['message' => 'Грешно потребителко име или парола'], $e->getCode());
        }

        return response()->json('Something went wrong on the server.', $e->getCode());
    }
}

Ответ:

  [
  {
    "id": 1,
    "name": "Nelly",
    "email": "n@n.com",
    "email_verified_at": null,
    "created_at": "2020-04-05T11:18:30.000000Z",
    "updated_at": "2020-04-05T11:18:30.000000Z"
  }
]

Если я сделаю метод для return $response->getBody(), я получу только токен на предъявителя.

Если я сделаю метод для return $user Я получаю только пользователя

Пробовал с помощью GuzzleHttp \ Promise \ Promise следующим образом:

public function login(Request $request)
{

    $user = User::where('email', $request->email)->get();

    $client = new Client([
        'base_uri' => 'http://127.0.0.1:8006',
        'timeout' => 5
    ]);

    try {
        $promise = $client->requestAsync('POST', 'oauth/token', [
            'form_params' => [
                'grant_type' => 'password',
                'client_id' => 2,
                'client_secret' => DB::table('oauth_clients')->where('id', 2)->first()->secret,
                'username' => $request->email,
                'password' => $request->password,
            ]
        ]);

        $promise->then(
            // $onFulfilled
            function ($value) {
                dd('The promise was fulfilled.');
            },
            // $onRejected
            function ($reason) {
                dd('The promise was rejected.');
            }
        );
        dd('outside of the then');
    }
}

Каждая попытка возвращает "за пределами того"

1 Ответ

1 голос
/ 05 апреля 2020

Таким образом, в основном вы отправляете http-запрос себе, чтобы войти в систему. Почему бы вам просто не сделать обычную проверку и не создать токен доступа вручную
Я знаю, что это не жрать, но я подумал, что это может быть полезно

Источник

if (! Auth::attempt($request->only(['email', 'password']))) {
    throw new \Exception('User not found');
}

/** @var User $user */
$user = Auth::user();

$token = $user->createToken('Token Name')->accessToken;;
dd($token);
...