A simple Laravel package that intercepts and help you customize, remove or modify the meta data on your Eloquent API Resource response, as well as automatically convert resource keys to camel case.
- Complete control over how Eloquent Api Resources are rendered and generated.
- Remove
metaandlinkscompletely from the response if you want. - If you choose to keep
metaandlinks, you also have total control overmeta's [to,from,links,path,total,per_page,last_page,current_page] properties andlink's [first,last,prev,next] properties. - Automatically convert resource keys to camel casing if needed.
php artisan mod:resourceto automatically generate API resources in place ofphp artisan make:resource;
You can install the package via composer:
composer require toneflix-code/laravel-resource-modifierLaravel automatically discovers and publishes service providers but optionally after you have installed Laravel Fileable, open your Laravel config file if you use Laravel below 11, config/app.php and add the following lines.
In the $providers array add the service providers for this package.
ToneflixCode\ResourceModifier\ResourceModifierServiceProvider::classIf you use Laravel >= 11, open your bootstrap/providers.php and the above line to the array.
return [
ToneflixCode\ResourceModifier\ResourceModifierServiceProvider::class,
];By default Laravel Resource Modifier doesn't really do anything different from what Laravel does, but now you can publish the configuration file and modify how Api Resources are presented by running the following artisan command.
Run php artisan vendor:publish --tag="resource-modifier"
To generate a resource class, you may use the mod:resource Artisan command. By default, resources will be placed in the app/Http/Resources directory of your application. Resources extend the ToneflixCode\ResourceModifier\Services\Json\JsonResource class:
artisan mod:resource UserResourceThe configuration file will be copied to config/resource-modifier.php.
To create a resource collection, you should use the --collection flag when creating the resource. Or, including the word Collection in the resource name will indicate to Laravel that it should create a collection resource. Collection resources extend the ToneflixCode\ResourceModifier\Services\Json\ResourceCollection class:
php artisan mod:resource User --collection
php artisan mod:resource UserCollectionIf you want Laravel Resource Modifier to handle your php artisan make:resource command by default, you can create a new command named ResourceMakeCommand with the following signature:
namespace App\Console\Commands;
use Symfony\Component\Console\Attribute\AsCommand;
use ToneflixCode\ResourceModifier\Commands\ResourceMakeCommand as ToneflixCodeResourceMakeCommand;
#[AsCommand(name: 'make:resource')]
class ResourceMakeCommand extends ToneflixCodeResourceMakeCommand
{
protected $name = 'make:resource';
}This will overide the default ResourceMakeCommand as Laravel will prefer user defined commands over built in ones, so the next time you call php artisan make:resource UserCollection, your collection will be created with the Laravel Resource Modifier signature.
composer testPlease see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email code@toneflix.com.ng instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.