waad / laravel-model-metadata
A robust Laravel package for handling metadata with JSON casting, custom relation names, and advanced querying capabilities.
Requires
- php: ^8.0
- ext-json: *
- laravel/framework: ^9.30.1|^10.0|^11.0|^12.0|^13.0
Requires (Dev)
- laravel/pint: ^1.0
- orchestra/testbench: ^7.0|^8.0|^9.0|^10.0|^11.0
- pestphp/pest-plugin-laravel: ^1.4|^2.4|^3.0|^4.0
README
Laravel Model Metadata
Laravel Model Metadata is a package designed to manage metadata with JSON support for multiple data types. It allows you to easily attach, manage, and query metadata on your Laravel models using the HasManyMetadata or HasOneMetadata traits.
๐ Documentation
For detailed documentation, including usage examples and best practices, please refer to the Documentation.
โจ Requirements
- PHP 8.0 or higher
- Laravel framework 9.30.1 or higher
- JSON extension enabled
๐ผ Installation
-
Install the package using Composer:
composer require waad/laravel-model-metadata
-
(Optional) Publish the config file first:
php artisan vendor:publish --tag=metadata-config
-
(Recommended) Clear the configuration cache to ensure new config is loaded:
php artisan config:clear
-
Publish the migration files:
php artisan vendor:publish --tag=metadata-migrations
-
Run the migrations:
php artisan migrate
โ๏ธ Configuration
You can customize the metadata table name, model, and caching behavior by editing the published config file at config/model-metadata.php:
return [ 'table' => 'model_metadata', 'model' => Waad\Metadata\Models\Metadata::class, 'cache' => [ 'enabled' => false, 'ttl' => 3600, // seconds (1 hour) 'store' => null, // null = default cache driver 'prefix' => 'model_metadata', ], ];
๐ Usage
๐ฅ HasOneMetadata Trait
Add the HasOneMetadata trait to your model to enable a single metadata record:
use Waad\Metadata\Traits\HasOneMetadata; class Company extends Model { use HasOneMetadata; // <--- Add this trait to your model }
Some methods:
// Create metadata with array (only works if no metadata exists) $company->createMetadata(['key' => 'value', 'another_key' => 'another_value']); // Create metadata with collection $company->createMetadata(collect(['key' => 'value'])); // Update existing metadata $company->updateMetadata(['new_key' => 'new_value']); // Delete the metadata $company->deleteMetadata(); // Get metadata as array $metadata = $company->getMetadata(); // Get metadata as collection $metadataCollection = $company->getMetadataCollection();
๐ฅ HasManyMetadata Trait
Add the HasManyMetadata trait to your model to enable multiple metadata records:
use Waad\Metadata\Traits\HasManyMetadata; class Post extends Model { use HasManyMetadata; // <--- Add this trait to your model // Enabled Append id with content metadata (default) public $metadataNameIdEnabled = true; // Custom Append key of id with metadata (default) public $metadataNameId = 'id'; }
see Configuration Append Id for more details
Some methods:
// Create metadata with array or collection $post->createMetadata(['key1' => 'value1', 'key2' => 'value2']); $post->createMetadata(collect(['key1' => 'value1', 'key2' => 'value2'])); // Update metadata by ID $post->updateMetadata('{metadata_id}', ['new_key' => 'new_value']); // Delete metadata by ID $post->deleteMetadata('{metadata_id}'); // Get all metadata objects $metadata = $post->metadata; // or $metadata = $post->metadata()->get(); // Get metadata by ID $metadata = $post->getMetadataById('metadata_id'); // Get all metadata column pluck as array $allMetadata = $post->getMetadata(); // Get all metadata column pluck as collection $metadataCollection = $post->getMetadataCollection(); // Search in metadata $searchResults = $post->searchMetadata('search_term');
๐๏ธ Cache
The package includes an optional caching layer to reduce database queries. Cache is disabled by default and can be enabled in the config:
| Key | Type | Default | Description |
|---|---|---|---|
cache.enabled |
bool |
false |
Enable or disable metadata caching |
cache.ttl |
int |
3600 |
Cache time-to-live in seconds |
cache.store |
string|null |
null |
Cache store to use (null = default driver) |
cache.prefix |
string |
model_metadata |
Prefix for all cache keys |
When caching is enabled:
- Read operations (
getMetadata,getMetadataById,getMetadataCollection) are automatically cached. - Write operations (
create,update,delete,forget,sync) automatically invalidate the cache. - You can manually clear the cache for a specific model using
clearMetadataCache():
$company->clearMetadataCache(); $post->clearMetadataCache();
- You can check if caching is active:
$company->metadataCacheIsEnabled(); // bool
๐งช Testing
To run the tests for development, use the following command:
composer test
๐จโ๐ป Contributors
- Waad Mawlood
- Email: waad_mawlood@outlook.com
- Role: Developer
๐ License
This package is open-sourced software licensed under the MIT license.
