yonchando/laravel-cast-attributes

Laravel model cast json columns to class object

v1.0.1 2025-03-23 07:46 UTC

This package is auto-updated.

Last update: 2025-04-23 08:05:05 UTC


README

Latest Version on Packagist Total Downloads

Laravel cast attribute is model custom cast json column to Class entity

IMPORTANT property is not primitive (User-Define Type), The User-Define type need to have default value to property.

Installation

Via Composer

composer require yonchando/laravel-cast-attributes

Usage

Model

class User extends \Illuminate\Database\Eloquent\Model
{
    protected $fillable = ['json'];

    protected $casts = [
        'json' => UserJson::class
    ];
}

UserJson

private property must have setter with camelCase start with set

class UserJson extends \Yonchando\CastAttributes\CastAttributes
{
    private string $firstName;
    
    protected string $lastName;
    
    public string $gender;
    
    public Image $image;
    
    public  function getFirstName(): string
    {
        return $this->firstName;
    }
    
    public  function setFirstName(string $firstName):void 
    {
        $this->firstName = $firstName;
    }
    
    public function getLastName(){
        return $this->lastName;
    }
}

Image

For sub property class use trait CastProperty

class Image
{
    use \Yonchando\CastAttributes\Traits\CastProperty;
    
    public string $filename;
    public int $size;
    public string $path;
    
    public function url()
    {
        return Storage::url($this->path);
    }
}

Controller

use Illuminate\Http\Request;

class UserController extends Controller
{
    public function show($id)
    {
        $user = User::find($id);
        
        $user->json->getFirstName();
        $user->json->getLastName();
        $user->json->gender;
        
        // access function in image class
        $user->json->image->url();
        
        // to array
        $user->json->toArray();
        $user->json->image->toArray();
        
    }
    
    public function store(Request $request)
    {
        // use class
        $user = new User([
            'json' => UserJson::create($request->all()),
        ]);
        
        // use an array
        $user = User::create([
            'json' => [
                'first_name' => $request->get('first_name'),        
                'last_name' => $request->get('last_name'),
                'gender' => $request->get('gender'),
                'image' => $request->get('image'),
            ]
        ])
    }
}

Methods available for CastProperty trait

Name modifier parameters Description
toArray public class property to array
toJson public int $options class property to json_encode string
create public static array|object $data initialize class

Change log

Please see the changelog for more information on what has changed recently.

Contributing

Please see contributing.md for details and a todolist.

Security

If you discover any security related issues, please email von.chando@gmail.com instead of using the issue tracker.

Credits

License

MIT. Please see the license file for more information.