# Laravel Meta-Articles [![Build Status][ico-build]][link-travis] [![Quality Score][ico-scrutinizer]][link-scrutinizer] [![Latest Unstable Version][ico-unstable]][link-packagist] [![License][ico-license]][link-license] [![Total Downloads][ico-downloads]][link-packagist] [![Latest Stable Version][ico-stable]][link-packagist] The Framework for Meta enabled Laravel models. ## Install Via Composer ``` bash $ composer require glmdev/meta ``` ### Update the Laravel Framework Add the following provider to config/app.php ``` php 'providers' => [ Glmdev\Meta\MetaServiceProvider::class ] ``` ## Usage When declaring a new model, extend the Meta model: ``` php *Important*: do not extend the Model class, Meta does this for you Then, include the 'meta' and 'uuid' columns in your database table: In your migration, ``` php hasUuid(); // returns true or false $post->getUuid(); // returns the UUID ``` The other big feature of the Meta model is saving meta information. This information is stored in the database in one column: 'meta' To save meta information, use the 'write' method. ``` php $post->write('author', 'Bob Saget'); ``` And to retrieve meta information, use the 'read' method. ``` php $post->read('author'); //returns 'Bob Saget' ``` ### Query Builder Let's say you need to retrieve the post that has a certain UUID (maybe you gave it out in a url or something) It's super easy to search for it: ``` php Post::withUuid($uuid)->first(); ``` It is completely integrated into the query builder, so you can still do stuff like: ``` php Post::withUuid($uuid)->pluck('username'); Post::withUuid($uuid)->firstOrFail(); ``` ## Credits - [Garrett Mills][link-author] - [All Contributors][link-contributors] ## License and Copyright Copyright (C) 2016 Garrett Mills This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . Please see [License File][link-license] for more details. [ico-stable]: https://poser.pugx.org/glmdev/meta/v/stable [ico-unstable]: https://poser.pugx.org/glmdev/meta/v/unstable [ico-downloads]: https://poser.pugx.org/glmdev/meta/downloads [ico-license]: https://poser.pugx.org/glmdev/meta/license [ico-scrutinizer]: https://scrutinizer-ci.com/g/glmdev/meta/badges/quality-score.png?b=master [ico-build]: https://travis-ci.org/glmdev/meta.svg [link-travis]: https://travis-ci.org/glmdev/meta [link-packagist]: https://packagist.org/packages/glmdev/meta [link-scrutinizer]: https://scrutinizer-ci.com/g/glmdev/meta [link-license]: ./LICENSE [link-author]: https://github.com/glmdev [link-contributors]: ../../contributors