# Suspend Token
Platform-level suspension
$request->user()->suspendToken();
1
Account-level suspension
$request->user()->suspendToken(true);
1
After the token is suspension, the controller no longer returns AccessToken and RefreshToken when issuing tokens, but returns AuthCode
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Hash;
use Jundayw\Tokenable\Contracts\Token\Token;
use Jundayw\Tokenable\Support\GuardHelper;
class AccountController
{
use GuardHelper;
public function login(Request $request): ?Token
{
$user = User::query()->where([
'email' => $request->get('email'),
'password' => Hash::make($request->get('password')),
])->first();
if(is_null($user)){
return null;
}
return $this->guard('web')
->login($user)
->createToken(name: 'PC Token', platform: 'pc');
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
{
"auth_code": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJqdGkiOiJkMDI2YTViNC1iMGQ2LTRmYmMtOTI0ZC0xZTg1ZjVlYmRhMTAiLCJpc3MiOiJBcHAuTW9kZWxzLlVzZXIiLCJzdWIiOjEsImlhdCI6MTc1OTY3NDk3Mn0.l3KezbE7EST8asqP9LPaovJO589WB_dPwZFakwYforU",
"code_type": "Bearer",
"type": "code"
}
1
2
3
4
5
2
3
4
5
# Create Token
# Route
Route::get('/token', [App\Http\Controllers\AccountController::class, 'token']);
1
# Controller
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Hash;
use Jundayw\Tokenable\Contracts\Token\Token;
use Jundayw\Tokenable\Support\GuardHelper;
class AccountController
{
use GuardHelper;
public function token(Request $request): ?Token
{
return $this->guard('web')
->fromAuthCode()
->createToken(name: 'auth_code', platform: 'pc');
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17