-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
3 changed files
with
124 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
<?php | ||
|
||
use Laravel\Sanctum\Sanctum; | ||
|
||
return [ | ||
|
||
/* | ||
|-------------------------------------------------------------------------- | ||
| Stateful Domains | ||
|-------------------------------------------------------------------------- | ||
| | ||
| Requests from the following domains / hosts will receive stateful API | ||
| authentication cookies. Typically, these should include your local | ||
| and production domains which access your API via a frontend SPA. | ||
| | ||
*/ | ||
|
||
'stateful' => explode(',', env('SANCTUM_STATEFUL_DOMAINS', sprintf( | ||
'%s%s', | ||
'localhost,localhost:3000,127.0.0.1,127.0.0.1:8000,::1', | ||
Sanctum::currentApplicationUrlWithPort() | ||
))), | ||
|
||
/* | ||
|-------------------------------------------------------------------------- | ||
| Sanctum Guards | ||
|-------------------------------------------------------------------------- | ||
| | ||
| This array contains the authentication guards that will be checked when | ||
| Sanctum is trying to authenticate a request. If none of these guards | ||
| are able to authenticate the request, Sanctum will use the bearer | ||
| token that's present on an incoming request for authentication. | ||
| | ||
*/ | ||
|
||
'guard' => ['web'], | ||
|
||
/* | ||
|-------------------------------------------------------------------------- | ||
| Expiration Minutes | ||
|-------------------------------------------------------------------------- | ||
| | ||
| This value controls the number of minutes until an issued token will be | ||
| considered expired. This will override any values set in the token's | ||
| "expires_at" attribute, but first-party sessions are not affected. | ||
| | ||
*/ | ||
|
||
'expiration' => null, | ||
|
||
/* | ||
|-------------------------------------------------------------------------- | ||
| Token Prefix | ||
|-------------------------------------------------------------------------- | ||
| | ||
| Sanctum can prefix new tokens in order to take advantage of numerous | ||
| security scanning initiatives maintained by open source platforms | ||
| that notify developers if they commit tokens into repositories. | ||
| | ||
| See: https://docs.github.com/en/code-security/secret-scanning/about-secret-scanning | ||
| | ||
*/ | ||
|
||
'token_prefix' => env('SANCTUM_TOKEN_PREFIX', ''), | ||
|
||
/* | ||
|-------------------------------------------------------------------------- | ||
| Sanctum Middleware | ||
|-------------------------------------------------------------------------- | ||
| | ||
| When authenticating your first-party SPA with Sanctum you may need to | ||
| customize some of the middleware Sanctum uses while processing the | ||
| request. You may change the middleware listed below as required. | ||
| | ||
*/ | ||
|
||
'middleware' => [ | ||
'authenticate_session' => Laravel\Sanctum\Http\Middleware\AuthenticateSession::class, | ||
'encrypt_cookies' => Illuminate\Cookie\Middleware\EncryptCookies::class, | ||
'validate_csrf_token' => Illuminate\Foundation\Http\Middleware\ValidateCsrfToken::class, | ||
], | ||
|
||
]; |
33 changes: 33 additions & 0 deletions
33
database/migrations/2024_10_18_070245_create_personal_access_tokens_table.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
<?php | ||
|
||
use Illuminate\Database\Migrations\Migration; | ||
use Illuminate\Database\Schema\Blueprint; | ||
use Illuminate\Support\Facades\Schema; | ||
|
||
return new class extends Migration | ||
{ | ||
/** | ||
* Run the migrations. | ||
*/ | ||
public function up(): void | ||
{ | ||
Schema::create('personal_access_tokens', function (Blueprint $table) { | ||
$table->id(); | ||
$table->morphs('tokenable'); | ||
$table->string('name'); | ||
$table->string('token', 64)->unique(); | ||
$table->text('abilities')->nullable(); | ||
$table->timestamp('last_used_at')->nullable(); | ||
$table->timestamp('expires_at')->nullable(); | ||
$table->timestamps(); | ||
}); | ||
} | ||
|
||
/** | ||
* Reverse the migrations. | ||
*/ | ||
public function down(): void | ||
{ | ||
Schema::dropIfExists('personal_access_tokens'); | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
<?php | ||
|
||
use Illuminate\Http\Request; | ||
use Illuminate\Support\Facades\Route; | ||
|
||
Route::get('/user', function (Request $request) { | ||
return $request->user(); | ||
})->middleware('auth:sanctum'); |