Download the PHP package gregoriohc/laravel-castable without Composer
On this page you can find all versions of the php package gregoriohc/laravel-castable. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download gregoriohc/laravel-castable
More information about gregoriohc/laravel-castable
Files in gregoriohc/laravel-castable
Package laravel-castable
Short Description Laravel package that adds custom casts for models attributes
License MIT
Homepage https://github.com/gregoriohc/laravel-castable
Informations about the package laravel-castable
Laravel Castable
Laravel package that adds custom casts for models attributes.
Install
Via Composer
In Laravel 5.5 the package will autoregister the service provider. In Laravel 5.4 and before you must install this service provider.
Usage
With Castable base model
The fastest way is using \Gregoriohc\Castable\CustomCastableModel
as your base model.
Without Castable base model
Add HasCustomCasts
trait to your the model you want to add custom attribute casting (if you want to use it in all your models, I suggest adding it to your own base model).
Override castAttribute
model method:
Override setAttribute
model method:
Override toArray
model method:
Add custom casted attributes to the model casts array:
A full model example would look like this:
Attribute migration, setting and getting
Depending on the custom caster, the attribute will accept and return different values when setting/getting. Also, the required database migration type will differ. For the included casters, you can see the doc in the caster class file.
For example, for the point caster requires a Point
database migration type, and to set its value you can do the following:
Configuration
You can optionally publish the config file with:
Creating a custom caster
You can create a custom caster extending the \Gregoriohc\Castable\Casters\Caster
class and implementing as
and from
methods. For example:
The as
method must transform the raw attribute value (from the database or internal) to the usable model attribute, and the from
method must do the opposite thing.
After that, add the custom caster to the config file:
Testing
Change log
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CODE_OF_CONDUCT for details.
Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
Socialware
You're free to use this package, but if it makes it to your production environment I highly appreciate you sharing it on any social network.
Credits
- Gregorio Hernández Caso
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-castable with dependencies
illuminate/support Version ~5.0|~6.0|~7.0|~8.0
illuminate/database Version ~5.0|~6.0|~7.0|~8.0
spinen/laravel-geometry Version ~1.0|~2.0