Package Data | |
---|---|
Maintainer Username: | devLopez |
Maintainer Contact: | fale_com_lopez@hotmail.com (Matheus Lopes Santos) |
Package Create Date: | 2016-12-28 |
Package Last Update: | 2021-04-29 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-02-07 15:01:22 |
Package Statistics | |
---|---|
Total Downloads: | 1,713 |
Monthly Downloads: | 2 |
Daily Downloads: | 0 |
Total Stars: | 0 |
Total Watchers: | 2 |
Total Forks: | 0 |
Total Open Issues: | 1 |
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.
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:
protected $user;
public function __construct(\App\Repositories\UserRepository $user)
{
$this->user = $user;
}
public function index()
{
return $this->user->all(['column_a', 'column_b']);
}
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);
}
}
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();
}
}