承接 vdhoangson/laravel-repository 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

vdhoangson/laravel-repository

最新稳定版本:v2.0.7

Composer 安装命令:

composer require vdhoangson/laravel-repository

包简介

Repository pattern package for Laravel framework

README 文档

README

Repository pattern package for Laravel framework.

GitHub tag (latest by date) GitHub Packagist PHP from Packagist Tests

Version compatibility

Laravel

Framework Package Note
10.x.x ^2.x.x PHP ^8.2 Supported.
11.x.x ^2.x.x PHP ^8.2 Supported.
12.x.x ^2.x.x PHP ^8.2 Supported.

Requirements

  • PHP 8.3 or higher
  • Laravel 10.x or higher

Installation

You can install this package by composer:

composer require vdhoangson/laravel-repository

For more configuration, you can publish configuration file:

php artisan vendor:publish --tag=laravel-repository-config

Or using the provider:

php artisan vendor:publish --provider "Vdhoangson\LaravelRepository\Providers\LaravelRepositoryServiceProvider"

Implementation

To use Repositories, create repository class that:

  • Extend BaseRepository class
  • Implements interface that extend BaseInterface

For example, this is implementation of repository for Example entity:

ExampleRepositoryInterface:

interface ExampleRepositoryInterface extends BaseInterface
{}

ExampleRepository class. This class has to implement entity() method, that return namespace of entity that will be used by repository.

class ExampleRepository extends BaseRepository implements ExampleRepositoryInterface
{
    /**
     * Model entity class that will be use in repository
     *
     * @return BaseInterface
     */
    public function entity(): string
    {
        return Example::class;
    }

}

Using repositories

To use Repository in controller or other class you can use dependency injection or Container. Below is sample code of using service in controller.

class ExampleController extends Controller {

    /**
     * @var ExampleRepositoryInterface $exampleRepository
     */
    protected $exampleRepository;

    public function __construct(ExampleRepositorynterface $exampleRepository){
        $this->exampleRepository = $exampleRepository;
    }

    ....
}

Available methods

  • makeEntity() - make new entity instance
  • getEntity() - return previously set entity instance
  • setEntity() - set entity instance
  • pushCriteria() - push new criteria to use in query (passed class must be implementation of BaseCriteria)
  • popCriteria() - delete given criteria from use (if exist)
  • getCriteria() - return collection of actualy set criteria
  • applyCriteria() - apply criteria to use in query
  • skipCriteria() - skip criteria in query
  • clearCriteria() - clear criteria colleciton - delete all pushed criterias
  • all(array $columns) - get all records
  • get(array $columns) - get records (with criteria)
  • first(array $columns) - get first record (with criteria)
  • create(array $parameters) - create new entity record
  • updateOrCreate(array $where, array $values) - update existing record, or create new
  • update(int $id, array $parameters) - update entity by ID
  • delete(int $id) - delete entity record by ID
  • firstOrNew(array $where) - return first entity record if found, otherwise return new entity
  • orderBy(string $column, string $direction) - order records by column
  • with($relations) - add relations sub-query
  • transactionBegin() - begin database transaction
  • transactionCommit() - commit transaction
  • transactionRollback() - rollback transaction
  • findWhere(array $where, array $columns) - return all records that match where array
  • findWhereIn(string $column, array $where, array $columns)
  • findWhereNotIn(string $column, array $where, array $columns)
  • findByField($field, $value = null, $columns = ['*'])
  • chunk(int $limit, callable $callback, array $columns) - chunk query results
  • count(array $columns) - count results
  • paginate($perPage, $columns, $pageName, $page) - paginate results
  • simplePaginate($perPage, $columns, $pageName, $page) - paginate results
  • has($relation, $operator, $count, $bolean, $callback) - where has relation
  • orHas($relation, $operator, $count) - or where has relation
  • whereHas($relation, $callback, $operator, $count)
  • orWhereHas($relation, $callback, $operator, $count)
  • whereDoesntHave($relation, $callback)
  • orWhereDoesntHave($relation, $callback)
  • withCount($relations)
  • doesntHave($relation, $boolean, $callback)
  • orDoesntHave($relation)
  • hasMorph($relation, $types, $operator, $count, $boolean, $callback)
  • orHasMorph($relation, $types, $operator, $count)
  • doesntHaveMorph($relation, $types, $boolean, $callback)
  • orDoesntHaveMorph($relation, $types)
  • whereHasMorph($relation, $types, $callback, $operator, $count)
  • orWhereHasMorph($relation, $types, $callback, $operator, $count)
  • whereDoesntHaveMorph($relation, $types, $callback)
  • orWhereDoesntHaveMorph($relation, $types, $callback)
  • sum($column)

Caching

Information: In order to use Caching feature in repository, you must use cache driver that support tags. Actually "file" and "database" drivers are not supported.

More information in in laravel documentation.

You can user criteria with this functions, and results will be cached.

Repository automatically flush cache, when method create(), updateOrCreate(), update(), delete() is call.

Skipping cache

To force fetch data from database, skipping cached data, use skipCache() method. Example:

$this->repository->skipCache()->findWhere(...)
Disable cache

To quick disable cache i.ex for debugging, set REPOSITORY_CACHE variable to false in .env

REPOSITORY_CACHE=false

Use scopeQuery

$data = $this->repository->scopeQuery(function($query){
    return $query->orderBy('sort_order','asc');
})->all();

Changelog

Go to the Changelog for a full change history of the package.

License

This package is open-source software licensed under the MIT license.

统计信息

  • 总下载量: 284
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 6
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 6
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-11-03