Download the PHP package dominiquevienne/laravel-magic without Composer
On this page you can find all versions of the php package dominiquevienne/laravel-magic. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download dominiquevienne/laravel-magic
More information about dominiquevienne/laravel-magic
Files in dominiquevienne/laravel-magic
Package laravel-magic
Short Description Laravel helpers classes such as Controllers / Models / Requests
License MIT
Homepage https://github.com/dominiquevienne/laravel-magic
Informations about the package laravel-magic
Laravel Magic
Laravel Magic provides Abstract Controller, Model, generic Request, Traits, Exceptions and various middlewares in order to generate very easily and quickly API resources from scratch.
Support us
Laravel Magic is a free open source project. If you use the project, please star us on Github... it costs nothing but a click! 😉
Installation
You can install the package via composer:
This package does not provide
- any migration
- any configuration file
- any view
ENV variables to be set
Usage
Models
Extending your models from AbstractModel
will give you the opportunity to get the autocompletion that comes with PHPDoc in your IDE and will make it possible to check if a relationship exist for the given model.
It will also make it possible for AbstractController
to make the magic happen. (see Controllers).
Controllers
Extending your controllers from AbstractController
will give you the opportunity to get a fully automated way to generate index, show, destroy, update, store methods without writing a single controller line. This will fill 90% of the API Resource needs.
Since default methods are already available in AbstractController
, you can directly configure your routes to target the usual methods and magic will happen.
Relationships
When calling an index or show endpoint, you can add the with
GET parameter in order to retrieve direct relationships of a given model.
The API will not throw an error / warning if relationship is not available.
If the property is not provided or if value is empty after sanitization, the query will result in a normal query without any relationship retrieval.
Fields
When calling an index or show endpoint, you can add the fields
GET parameter in order to only retrieve the listed fields.
The API will not throw an error / warning if field is not available.
If the property is not provided or if value is empty after sanitization, the query will throw every available fields.
Filtering
When calling an index endpoint, you can add the filter
GET parameter in order to filter the list so you only retrieve the row you targeted.
The API will not throw an error / warning if the fields you use for filtering are not available.
If the property is not provided or if value is empty after sanitization, the query will result in a normal query retrieving all the rows.
Ordering
When calling an index endpoint, you can add the filter
GET parameter in order to order the provided result is ordered the way you need.
The API will throw an error if you provide a non-compliant string.
If the property is not provided, the query will result in a normal query retrieving all the rows without any specific sorting.
Pagination
The standard Laravel pagination is integrated. Please refer to the official paginate
documentation.
Query Caching
By default Laravel Magic will cache queries used for Index and Show methods. It will use their fingerprint to ensure that the cache value is the one corresponding to a unique query. This caching method takes in consideration the in-app filtering, user-filtering, fields, ordering, relationships and pagination.
The default behaviour is to store the query result in cache for 8 hours but the value can be overridden in your .env
file through the LARAVEL_MAGIC_CACHE_DEFAULT_DURATION
variable. The value of this variable is TTL for cache in seconds. Use LARAVEL_MAGIC_CACHE_DEFAULT_DURATION=0
if you want to avoid totally query caching.
Requests
Laravel Magic provides a BootstrapRequest
file which will be call on any AbstractConctroller.create
and AbstractConctroller.update
methods. If a request which name is ModelnameRequest
is available in your Requests
folder, it will be used to generate the validation rules.
Filtering queries
In your development, if you create a src/Http/Filters/ModelNameFilter.php
class extending the GenericFilter
class, Laravel Magic will automatically filter the way it retrieves data in your CRUD methods.
If this class has not been created, by default, no filtering is done. However, if you set LARAVEL_MAGIC_FILTERING_MODE=paranoid
in your .env
file, LaravelMagic will make it impossible to get any data.
Middlewares
Laravel Magic provides ForceJson
and VerifyJwtToken
middlewares. Those can be set up in Laravel Kernel
.
Traits
We also provide the HasPublicationStatus
, TimeStampsBy
and SoftDeletesBy
traits.
HasPublicationStatus trait
This trait will add a publication status to any of your model and store it in database.
To use the trait, add it to your models and migrate your schema so it has the publication_status_id
field. Value of this field is handled by $publicationStatusAvailable
property.
TimeStampsBy trait
This trait will add creator
and an updater
relationships and will automatically store the user id in the created_by
and updated_by
table properties. Those properties have to be added through migration.
SoftDeletesBy trait
This trait will add deleter
relationship and will automatically store the user id in the deleted_by
table property. Those properties have to be added through migration.
Exceptions
Laravel Magic provides those Exceptions:
- ControllerAutomationException
- EnvException
- PublicationStatusException
- StatusUnknownException
These are used internally but you can of course use them as you want.
Testing
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- Dominique Vienne
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-magic with dependencies
doctrine/dbal Version ^3.3
firebase/php-jwt Version ^6.1
laravel/framework Version ^10.0
spatie/laravel-package-tools Version ^1.11