masterkey / repository
Repository Pattern for Laravel 5
Requires
- php: ^7.4|^8.0
- ext-json: *
- ext-pdo: *
- illuminate/cache: ^8.0
- illuminate/config: ^8.0
- illuminate/container: ^8.0
- illuminate/database: ^8.0
- illuminate/events: ^8.0
- illuminate/filesystem: ^8.0
- illuminate/http: ^8.0
- illuminate/pagination: ^8.0
- illuminate/support: ^8.0
- illuminate/validation: ^8.0
Requires (Dev)
- phpunit/phpunit: ^9.3.3
This package is auto-updated.
Last update: 2026-05-29 00:54:23 UTC
README
Este projeto foi desenvolvido para que pudessemos ter uma camada de abstração dos Models do Laravel, desacoplando a lógica dos Controllers.
Para utilização com o Laravel, utilize o composer:
$ composer require masterkey/repository
Lembre-se que, com o Laravel 5.5, não é necessario informar o Service Provider
no arquivo config/app.php
Para utilização com o Laravel 5.4, verifique o branch 2.0
Feito isso, publique o arquivo de configuração do repositório:
$ php artisan vendor:publish
No arquivo de configuração você pode definir o local onde os repositories e criterias serão criados.
Criando Repositories
Você pode Criar um repositório utilizando o artisan:
php artisan make:repository UsersRepository --model=Users
# ou ainda
php artisan make:repository Users/Users --model=Models/Users
para utilização:
<?php class MyController { protected $user; public function __construct(\App\Repositories\UserRepository $user) { $this->user = $user; } public function index() { return $this->user->all(['column_a', 'column_b']); } }
Utilizando Criterias
Criterias podem ser utilizadas para adicionar uma query específica em uma busca, permitindo uma melhor reusabilidade com o sql. Para criar uma nova Criteria:
php artisan make:criteria MoviesNotRated --model=Movie
Importante: Nao é necessário passar o namespace completo do model. O nome do model é passado para que o package possa criar um diretório para que as Criterias dequele model possam ser agrupadas
Após criar a nova Criteria, você definir o trecho sql que deseja ser executado:
<?php namespace App\Repositories\Criteria\Movies; use Masterkey\Repository\Criteria; use Masterkey\Repository\Contracts\RepositoryContract as Repository; /** * MoviesNotRated * * @package App\Repositories\Criteria\Movies */ class MoviesNotRated extends Criteria { /** * @param $model * @param Repository $repository * @return mixed */ public function apply($model, Repository $repository) { return $model->where('was_rated', false); } }
Usando no Controller
Para utilização no controller, basta instanciar a nova classe e passá-la para o repository
<?php use App\Repositories\Criteria\Movies\MoviesNotRated; use App\Repositories\FilmRepository as Film; class FilmsController extends Controller { /** * @var Film */ private $film; public function __construct(Film $film) { $this->film = $film; } public function index() { $this->film->pushCriteria(new MoviesNotRated()); return \Response::json($this->film->all()); } /* * Você também pode utilizar o método getByCriteria */ public function notRated() { $criteria = new MoviesNotRated(); return $this->film ->getByCriteria($criteria) ->all(); } }