定制 mcgo/laravel-barekey 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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(), and auth:apikey middleware

⛓️‍ 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_at to 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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-10-13