jarivas/laravel-cast-json-models

A simple and direct way of casting json objects to models

Installs: 82

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 2

pkg:composer/jarivas/laravel-cast-json-models

1.3.0 2025-10-20 08:46 UTC

This package is auto-updated.

Last update: 2025-11-04 09:35:01 UTC


README

  • A easy solution to have decriptions of json objects POCO style
  • The method Object::collection will convert an array of objects to an collection of PHP objects that extends from CastModels\Model
  • The objects that extends from CastModels\Model has the method toArray so can be returned in a response directly
  • self casts from a Json object or array of json objects
<?php

namespace Tests\Models;

use CastModels\Model;
use Illuminate\Support\Collection;
use Tests\Enum\OrderStatus;
use Tests\Enum\TransactionStatus;

class Order extends Model
{
    public int $transaction_id;

    public string $order_id;

    public string $created;

    public string $currency = 'EUR';

    public int $amount;

    public string $description;

    /** @var Collection<\App\Casts\ShoppingCartItem> */
    public Collection $items;

    public int $amount_refunded;

    public string $auth_order_id;

    public OrderStatus $status;

    public TransactionStatus $financial_status;

    public string $reason;

    public string $reason_code;

    public string $fastcheckout;

    public string $modified;

    public Customer $customer;

    public PaymentDetails $payment_details;

    public string $completed_date;

    public Costs $costs;

    /** @var Collection<\App\Casts\Transaction> */
    public Collection $related_transactions;

    /** @var Collection<\App\Casts\PaymentMethod> */
    public Collection $payment_methods;

    public string $var1;

    public string $var2;

    public string $var3;
}
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use App\Casts\Translation;
use Illuminate\Database\Eloquent\Collection;

/**
 * Summary of Example
 *
 * @property string $id
 * @property string $name
 * @property \Illuminate\Support\Collection $name_translations
 * @property \Illuminate\Support\Carbon $created_at
 * @property \Illuminate\Support\Carbon $updated_at
 * @property \Illuminate\Support\Carbon $deleted_at
 */
class Example extends Model
{
    protected $fillable = [
        'name',
        'name_translations',
    ];

    /**
     * Get the attributes that should be cast.
     *
     * @return array<string, string>
     */
    protected function casts(): array
    {
        return [
            // This will be valid for a single object or array of objects
            'name_translations' => Translation::class,
        ];
    }
}

Support union types Models, when built in types use mixed as type, only use union when you can not combine both models in one, like in this case

<?php

namespace Tests\Models;

use App\Casts\NextDate;
use Illuminate\Support\Collection;
use CastModels\Model;

class SearchAvailability extends Model
{
    public string $start;

    public int|null $idResource = null;

    public int|null $idResourceType = null;

    /** @var Collection<\App\Casts\Availability> */
    public Collection|NextDate $availability;
}