mcgo/laravel-barekey

Pure API key auth, nothing more, nothing less.

Installs: 594

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/mcgo/laravel-barekey

v1.0.2 2025-10-21 18:55 UTC

This package is auto-updated.

Last update: 2025-11-21 19:09:39 UTC


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