pribolshoy / laravel-repository
Laravel repository pattern implementation
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/pribolshoy/laravel-repository
Requires
- php: >=8.1
- illuminate/cache: ^10.0|^11.0
- illuminate/database: ^10.0|^11.0
- illuminate/redis: ^10.0|^11.0
- illuminate/support: ^10.0|^11.0
- pribolshoy/repository: ^1.0
Requires (Dev)
- mockery/mockery: 2.0.x-dev
- phpunit/phpunit: ^10.0|^11.0
This package is not auto-updated.
Last update: 2026-02-10 11:57:47 UTC
README
Библиотека для реализации паттерна Repository в Laravel приложениях. Адаптация пакета pribolshoy/yii2-repository для работы с Laravel Eloquent.
Установка
composer require pribolshoy/laravel-repository
Требования
- PHP >= 8.1
- Laravel >= 10.0
- Пакет
pribolshoy/repository
Основные компоненты
AbstractEloquentRepository
Абстрактный класс для создания репозиториев, работающих с Eloquent моделями.
Пример использования:
<?php namespace App\Repositories; use pribolshoy\laravelrepository\AbstractEloquentRepository; use App\Models\User; class UserRepository extends AbstractEloquentRepository { protected ?string $model_class = User::class; protected function defaultFilter() { $this->addFilterValueByParams('status', 'active'); $this->addFilterValueByParams('limit', 25); $this->addFilterValueByParams('page', 1); } protected function addQueries() { if ($this->existsFilter('status')) { $this->model->where('status', $this->getFilter('status')); } if ($this->existsFilter('email')) { $this->model->where('email', 'like', '%' . $this->getFilter('email') . '%'); } return $this; } }
AbstractEloquentService
Абстрактный класс для создания сервисов, работающих с репозиториями.
Пример использования:
<?php namespace App\Services; use pribolshoy\laravelrepository\AbstractEloquentService; use App\Repositories\UserRepository; class UserService extends AbstractEloquentService { protected ?string $repository_class = UserRepository::class; protected function init() { // Инициализация сервиса } }
Драйверы кеша
Библиотека поддерживает несколько драйверов кеша:
RedisDriver
Использует Redis для кеширования данных.
protected ?string $driver = 'redis'; protected ?string $driver_path = "\\pribolshoy\\laravelrepository\\drivers\\";
FileDriver
Использует файловый кеш Laravel.
protected ?string $driver = 'file'; protected ?string $driver_path = "\\pribolshoy\\laravelrepository\\drivers\\";
MysqlDriver
Использует MySQL таблицу для кеширования.
protected ?string $driver = 'mysql'; protected ?string $driver_path = "\\pribolshoy\\laravelrepository\\drivers\\";
Использование
Создание репозитория
$repository = new UserRepository([ 'status' => 'active', 'limit' => 10, 'page' => 1 ]); $users = $repository->search();
Работа с сервисом
$service = new UserService(); $items = $service->getItems();
Особенности
- Поддержка пагинации через Laravel Paginator
- Кеширование результатов запросов
- Гибкая система фильтрации
- Поддержка сортировки
- Работа с Eloquent моделями
Лицензия
BSD-3-Clause
Автор
Nikolay Pribolshoy pribolshoy@gmail.com