mcgo/laravel-barekey
最新稳定版本:v1.0.2
Composer 安装命令:
composer require mcgo/laravel-barekey
包简介
Pure API key auth, nothing more, nothing less.
README 文档
README
Authenticate everything – without users.
A minimal, stateless API key authentication guard for Laravel.
No sessions. No Sanctum. No users. Just pure, verifiable keys.
🚀 Features
- 🧩 Stateless API key guard – powered by
Auth::viaRequest() - 🔐 Secure hashing (SHA-256) and prefix lookup for fast validation
- 🎯 Abilities / Scopes with wildcard support (
invoices:*) - even as route middleware - 🧠 Enum-friendly design for type-safe permission checks
- ⚡ No database overhead beyond a single table for all your api keys
- 🧱 Works with Laravel Gates,
Auth::check(), andauth:apikeymiddleware
⛓️ Compatibility
| Package Version | Laravel Versions |
|---|---|
| 1.x | 10.x, 11.x, 12.x |
📦 Installation
composer require mcgo/laravel-barekey
Then run the migration:
php artisan migrate
⚙️ Setup
Register the guard in your config/auth.php. You can provide your custom Abilities Enum, see packages DefaultAbilities
as example.
'guards' => [ 'barekey' => [ 'driver' => 'apikey', 'provider' => null, // 'abilities' => YourAbilitiesEnum::class ], ],
Barekey automatically registers its guard in your AuthServiceProvider
via Auth::viaRequest('barekey', ...).
🔐 Keys
To generate new keys:
php artisan barekey:make "My Service api key" --abilities=invoices:read,reports:read
Output example:
API Key generated, please use it as the following header:
Authorization: Bearer 593acec5-d9c2-43dd-9155-d93bad8c49e4:CJalcoa3ukYpkHa2ZfTWnRi0s4q8JPslSiqKbWXkls1suHMkJ8Ya6ggOKEBoEFje
Or as custom header:
X-Barekey-Token: 593acec5-d9c2-43dd-9155-d93bad8c49e4:CJalcoa3ukYpkHa2ZfTWnRi0s4q8JPslSiqKbWXkls1suHMkJ8Ya6ggOKEBoEFje
🔑 Usage
Protect routes using the built-in middleware:
Route::middleware('auth:barekey')->group(function () { Route::get('/status', fn() => ['ok' => true]); });
You can also layer can: for ability-based checks:
Route::middleware(['auth:barekey', 'can:invoices:read']) ->get('/invoices', [InvoiceController::class, 'index']);
Inside your controller, you can access the authenticated key:
$key = request()->user(); // GenericUser with ->id, ->name, ->abilities
🧠 Abilities & Gates
Define abilities as strings or Enums – both work:
Gate::before(function ($user, string $ability) { $abilities = (array) $user->abilities; return in_array('*', $abilities, true) || in_array($ability, $abilities, true) || str($abilities)->contains(fn($a) => str($ability)->isMatch($a)); });
Or use the included Enum helper:
use App\Enums\Ability; Gate::before(fn($user, $ability) => Ability::granted($user->abilities, $ability));
🧮 Example Enum
namespace App\Enums; use McGo\Barekey\Contracts\AbilitiesEnumContract; enum Ability: string implements AbilitiesEnumContract { case InvoicesRead = 'invoices:read'; case InvoicesWrite = 'invoices:write'; case ReportsRead = 'reports:read'; case Admin = 'admin'; // Implement the needed methods. }
🧼 Commands
| Command | Description |
|---|---|
php artisan barekey:make |
Create a new API key |
🔒 Security Notes
- Always use HTTPS
- Never expose API keys in frontend code
- Rotate keys regularly
- Use
revoked_at+expires_atto enforce lifecycle policies
🧪 Testing
php artisan test
Example:
it('authenticates with valid API key', function () { $key = ApiKey::factory()->create([...]); $response = $this->withHeaders([ 'Authorization' => "Bearer {$key->plain}", ])->getJson('/api/status'); $response->assertOk()->assertJson(['ok' => true]); });
📋 Roadmap
- Implement Commands to list and revoke key
- Implement rate limiting per key
- Add some events for created, revoked, used key and a rate limit that had hit
🧡 Credits
- Inspired by Laravel Sanctum,
stripped to the essentials for user-free, machine-to-machine auth. - Crafted by McGo
🪪 License
MIT © Mirko Haaser
统计信息
- 总下载量: 703
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-10-13