Skip to content

Instantly share code, notes, and snippets.

@abbajbryant
Forked from jgrossi/AttachJwtToken.php
Created August 14, 2021 18:14
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save abbajbryant/21b343164427e1c87fdb5979533dd517 to your computer and use it in GitHub Desktop.
Save abbajbryant/21b343164427e1c87fdb5979533dd517 to your computer and use it in GitHub Desktop.
AttachJwtToken.php
<?php
namespace Tests\Concerns;
use App\Models\User;
use Tymon\JWTAuth\Facades\JWTAuth;
trait AttachJwtToken
{
/**
* @var User
*/
protected $loginUser;
/**
* @param User $user
* @return $this
*/
public function loginAs(User $user)
{
$this->loginUser = $user;
return $this;
}
/**
* @return string
*/
protected function getJwtToken()
{
$user = $this->loginUser ?: factory(User::class)->create([
'company_id' => null,
]);
return JWTAuth::fromUser($user);
}
/**
* @param string $method
* @param string $uri
* @param array $parameters
* @param array $cookies
* @param array $files
* @param array $server
* @param string $content
* @return \Illuminate\Http\Response
*/
public function call($method, $uri, $parameters = [], $cookies = [], $files = [], $server = [], $content = null)
{
if ($this->requestNeedsToken($method, $uri)) {
$server = $this->attachToken($server);
}
return parent::call($method, $uri, $parameters, $cookies, $files, $server, $content);
}
/**
* @param string $method
* @param string $uri
* @return bool
*/
protected function requestNeedsToken($method, $uri)
{
return !('/auth/login' === $uri && 'POST' === $method);
}
/**
* @param array $server
* @return string
*/
protected function attachToken(array $server)
{
return array_merge($server, $this->transformHeadersToServerVars([
'Authorization' => 'Bearer ' . $this->getJwtToken(),
]));
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment