garethnic / repo
Scaffold repository pattern in Laravel
Requires
- php: ~5.5|~7.0
- illuminate/support: ~5.1
Requires (Dev)
- phpunit/phpunit: 4.*
- scrutinizer/ocular: ~1.1
- squizlabs/php_codesniffer: ~2.3
This package is not auto-updated.
Last update: 2025-01-04 20:25:53 UTC
README
This package creates scaffolding to implement the Repository pattern.
Install
composer require io-digital/repo
Add the ServiceProvider to your config/app.php providers array:
IoDigital\Repo\RepoServiceProvider::class,
Then run the following artisan command:
$ php artisan vendor:publish --provider="IoDigital\Repo\RepoServiceProvider"
This will create the following folder structure in your app/
folder:
- Models
- Concrete
- Eloquent
- AbstractEloquentRepository.php
- Contracts
- Repositories
- RepositoryInterface.php
- Objects
- Concrete
Usage
After installing the package the artisan command repo:create
should be available.
To create the repository structure for your object run the command:
$ php artisan repo:create Post
This will create the following files:
- Models/Objects/Post.php
- Models/Contracts/Repositories/PostRepository.php
- Models/Concrete/Eloquent/EloquentPostRepository.php
It will also add the bindings in your AppServiceProvider.php
file:
$this->app->bind( 'App\Models\Contracts\Repositories\PostRepository', // Repository (Interface) 'App\Models\Concrete\Eloquent\EloquentPostRepository' // Eloquent (Class) );
Then in your Controller it's simply:
... use App\Models\Contracts\Repositories\PostRepository; ... protected $model; public function __construct(PostRepository $repo) { $this->model = $repo; }
Options
-m
or--m
Use the the -m
option to create a migration file for your object:
$ php artisan repo:create Post -m
The repository interface provides the following methods:
public function all($with = [], $orderBy = [], $columns = ['*']); public function find($id, $relations = []); public function findBy($attribute, $value, $columns = ['*']); public function findAllBy($attribute, $value, $columns = ['*']); public function findWhere($where, $columns = ['*'], $or = false); public function findWhereIn($field, array $values, $columns = ['*']); public function paginate($perPage = 25, $columns = ['*']); public function simplePaginate($limit = null, $columns = ['*']); public function create($attributes = []); public function edit($id, $attributes = []); public function delete($id);
The implementations can found in Models/Concrete/AbstractEloquentRepository.php
Example usage for the find functions:
//returns with ->first() $data = $this->model->findBy('title', $title); //returns with ->get() $data = $this->model->findAllBy('category', $category); //returns with ->get() $data = $this->model->findWhere([ 'category' => $category, ['year', '>' , $year], ['name', 'like', "%$name%"], ['surname', 'like', '%nes'] ]); $data = $this->model->findWhereIn('id', [1, 2, 3]) ->get(['name', 'email']);
Change log
Please see CHANGELOG for more information what has changed recently.
Testing
$ composer test
Contributing
Please see CONTRIBUTING and CONDUCT for details.
TODO
Clean up code
License
The MIT License (MIT). Please see License File for more information.