masterkey / repository
Laravel 5 的仓库模式
10.0.1
2021-01-17 18:10 UTC
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
- dev-master
- 10.0.1
- 10.0.0
- 9.0.x-dev
- 9.0.6
- 9.0.5
- 9.0.4
- 9.0.3
- 9.0.2
- 9.0.1
- 9.0.0
- 8.2.3
- 8.2.2
- 8.2.1
- 8.2.0
- 8.1.3
- 8.1.2
- 8.1.1
- 8.1.0
- 8.0.x-dev
- 8.0.1
- 8.0.0
- 7.15.6
- 7.15.5
- 7.15.4
- 7.15.3
- 7.15.2
- 7.15.1
- 7.15.0
- 7.14.3
- 7.14.2
- 7.14.1
- 7.14.0
- 7.13.0
- 7.12.0
- 7.11.2
- 7.11.1
- 7.11.0
- 7.10.2
- 7.10.1
- 7.10.0
- 7.9.0
- 7.8.1
- 7.8.0
- 7.7.0
- 7.6.3
- 7.6.2
- 7.6.1
- 7.6.0
- 7.5.0
- 7.4.0
- 7.3.2
- 7.3.1
- 7.3.0
- 7.2.2
- 7.2.1
- 7.2.0
- 7.1.0
- 7.0.x-dev
- 7.0.2
- 7.0.1
- 7.0.0
- 6.2.0
- 6.1.0
- 6.0.x-dev
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 5.0.x-dev
- 5.0.2
- 5.0.1
- 5.0.0
- 4.9.0
- 4.8.6
- 4.8.5
- 4.8.4
- 4.8.3
- 4.8.2
- 4.8.1
- 4.8
- 4.7.0
- 4.6.0
- 4.5.0
- 4.4.1
- 4.4.0
- 4.3.1
- 4.3.0
- 4.2.0
- 4.1.1
- 4.1.0
- 4.0.x-dev
- 4.0
- 3.0.x-dev
- 3.0.1
- 3.0.0
- 2.2.0
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.x-dev
- 2.0.0
- 1.5.1
- 1.5
- 1.4.0
- 1.3.0
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.x-dev
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-dependabot/composer/illuminate/database-8.40.0
- dev-cache-feature
This package is auto-updated.
Last update: 2024-08-29 04:31:14 UTC
README
本项目旨在提供一个Laravel模型的抽象层,解耦Controller的逻辑。
使用Laravel时,请使用composer
$ composer require masterkey/repository
注意:在Laravel 5.5中,不需要在config/app.php
文件中指定Service Provider
对于Laravel 5.4的使用,请查看分支 2.0
完成此操作后,发布仓库配置文件
$ php artisan vendor:publish
在配置文件中,您可以定义创建repository和criterias的位置。
创建仓库
您可以使用artisan创建一个仓库
php artisan make:repository UsersRepository --model=Users
# ou ainda
php artisan make:repository Users/Users --model=Models/Users
用于
<?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']); } }
使用Criterias
Criterias可用于在搜索中添加特定的查询,从而提高与SQL的复用性。为了创建一个新的Criteria
php artisan make:criteria MoviesNotRated --model=Movie
重要:不需要传递完整的模型命名空间。传递模型名称是为了让package创建一个目录,以便将此模型的Criterias分组
创建新的Criteria后,您需要定义要执行的SQL片段
<?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); } }
在Controller中使用
为了在Controller中使用,只需实例化新的类并将其传递给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(); } }