Looking to hire Laravel developers? Try LaraJobs

laravel-easyapi maintained by rdcstarr

Description
A simple settings package for Laravel.
Author
Last update
2025/11/25 15:57 (dev-main)
License
Downloads
15

Comments
comments powered by Disqus

Laravel EasyAPI

Latest Version on Packagist Tests Code Style Downloads

Lightweight package for managing API keys in Laravel — with middleware protection, logging and simple CLI tools.


✨ Features

  • 🔑 API key management — generate, list, reveal and delete API keys via an artisan command or programmatically.
  • 🛡 Middleware protection — a lightweight middleware validates Bearer tokens on incoming requests.
  • 📈 Usage metrics — each key tracks an access count and API access is logged to api_logs.
  • 🔒 Secure keys — keys are generated using SHA-256 with unique identifiers to avoid collisions.
  • ⚙️ Facade & manager — programmatic API via the EasyApi facade or the EasyApiManager service.
  • 🧪 Test-friendly — models and factories included to make testing straightforward.
  • 📦 Migrations included — package ships migrations for api and api_logs tables and can be published.

📦 Installation

composer require rdcstarr/laravel-easyapi

Automatic Installation (Recommended)

Run the install command to publish and run the migrations:

php artisan easyapi:install

Manual Installation

Alternatively, you can install manually:

  1. Publish the migrations:
php artisan vendor:publish --tag=easyapi-migrations
  1. Run the migrations:
php artisan migrate

The package registers a singleton manager and console commands. It will also register route groups if you provide routes/api.php or routes/web.php.

🔑 Usage

Facade examples (programmatic):

use Rdcstarr\EasyApi\Facades\EasyApi;

// Generate a new API key (returns the Api model)
$api = EasyApi::createKey();
$fullKey = $api->key; // show and store this securely

// Validate a key (returns bool)
$isValid = EasyApi::validateKey($fullKey);

// Delete a key
EasyApi::deleteKey($fullKey);

Middleware usage:

  • The package provides Rdcstarr\EasyApi\Middleware\EasyApiMiddleware which checks for a Bearer token and validates it against the api table. If valid, it logs the request and increments the access count.

Apply it to a route or route group:

Route::middleware([\Rdcstarr\EasyApi\Middleware\EasyApiMiddleware::class])->group(function () {
    Route::get('/protected', function () {
        return ['ok' => true];
    });
});

Database schema:

  • api table: id, key (unique), access_count, timestamps
  • api_logs table: id, api_id, endpoint, ip_address, user_agent, timestamps

Artisan CLI:

The package exposes a single console command: php artisan easyapi with the following actions:

  • generate — create a new API key
  • delete --key=KEY — delete an API key (confirmation required)
  • list — display stored API keys (masked) with access counts
  • reveal --id=ID — reveal the full API key for a given id

Examples:

php artisan easyapi generate
php artisan easyapi list
php artisan easyapi delete --key="qwerty_..."
php artisan easyapi reveal --id=1

Notes:

  • Generated keys must be stored securely when created — the generate command shows the full key once.
  • The command output masks keys in listings for safety; use reveal to show the full value when necessary.

🧪 Testing

Run the package tests:

composer test

The package provides models (Api, ApiLog) and factories to make writing tests simpler.

📖 Resources

  • Changelog for more information on what has changed recently.

👥 Credits

📜 License