swindon / filament-hashids
A Laravel Filament package that automatically encodes and decodes model IDs using vinkla/hashids for improved security and aesthetics.
Requires
- php: ^8.0
- illuminate/support: ^9.0|^10.0|^11.0|^12.0
- vinkla/hashids: ^10.0|^11.0|^12.0|^13.0
README
Filament Hashids is a Laravel package that automatically encodes and decodes model IDs using vinkla/hashids. By replacing numerical IDs with obfuscated Hashids, this package not only improves the aesthetics of your URLs but also provides an extra layer of security.
Table of Contents
Features
- Automatic Hashid Encoding: Transform model IDs in your URLs (e.g.
/admin/users/1/edit
becomes/admin/users/0l8q7xpnm4k63jo9/edit
). - Automatic Hashid Decoding: Middleware decodes Hashids back to real IDs when processing requests.
- Model Trait (
HasHashid
): Easily apply Hashids to any Filament model. - Filament Plugin (
HashidsPlugin.php
): Seamlessly integrate with Filament, overriding resource routes and actions. - Customisable Hashid Config: Configure custom salts, minimum length, and alphabet via
filament-hashids.php
. - Blade Directive (
@hashid($model)
): Helper directive for generating Hashids in your Blade templates. - Artisan Command (
install:hashids
): Simplifies setup by publishing configuration files and verifying dependencies.
Installation
Install the package via Composer:
composer require swindon/filament-hashids
If you wish to customise the configuration, run the install command:
php artisan install:filament-hashids
This command will publish the configuration file (config/filament-hashids.php
) to your Laravel application.
Configuration
After installation, you can adjust your settings in the config/filament-hashids.php
file. You may set:
- salt: A custom salt value (defaults to your
APP_KEY
). - min_length: The minimum length for the generated Hashid.
- alphabet: The alphabet used to generate the Hashid.
Usage
Using the Model Trait
Simply include the HasHashid
trait in your model to enable Hashid functionality:
use Swindon\FilamentHashids\Traits\HasHashid; class User extends Authenticatable { use HasHashid; // ... }
You can then retrieve the Hashid for a model instance:
$user = User::find(1); echo $user->getHashid();
You can query by Hashid for a model:
$user = User::findHashId($hashId); $users = User::whereHashId($hashId)->get();
Blade Directive
In your Blade templates, generate a Hashid easily with the provided directive:
@hashid($user)
This will output the encoded ID of the model.
Setup the Middleware
Middleware ensures that incoming requests with Hashids are automatically decoded into their corresponding numerical IDs. You can set it up in two ways:
Via Panels
To apply the middleware globally to a Filament panel, include it in the panel's middleware stack:
use Filament\Panel; use Filament\PanelProvider; use Swindon\FilamentHashids\Middleware\FilamentHashidsMiddleware; class AdminPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel ->middleware([ FilamentHashidsMiddleware::class, // Decodes Hashids for all routes in this panel // ...existing code... ]); } }
Via Specific Resources
If you want to apply the middleware to specific resources only, you can define it in the resource's $routeMiddleware
property:
use Filament\Resources\Resource; class UserResource extends Resource { public static array|string $routeMiddleware = [ 'filament-hashids', // Ensures Hashids are decoded for this resource's routes ]; }
Testing
The package includes a suite of tests to cover its key functionality:
- Feature Tests: Validate that URLs are correctly rewritten and that routes work as expected.
- Unit Tests: Ensure that the
HashidsManager
, middleware, and helper functions behave correctly.
To run the tests, simply execute:
vendor/bin/phpunit
Contributing
Contributions are welcome! Feel free to open issues or submit pull requests if you have suggestions or improvements.
Licence
This package is open-sourced software licensed under the MIT licence.
Enjoy building secure and aesthetically pleasing URLs with Filament Hashids!