nathanbarrett / laravel-repositories
Repository service layer for Laravel apps
Fund package maintenance!
Nathan Barrett
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^9.0.0||^8.22.0
- pestphp/pest: ^2.34
- pestphp/pest-plugin-arch: ^2.7
- pestphp/pest-plugin-laravel: ^2.3
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1
- phpstan/phpstan-phpunit: ^1.3
This package is not auto-updated.
Last update: 2024-05-19 21:22:46 UTC
README
Repositories are meant to act as a middle layer between Models and higher level objectives like services. They are meant to abstract the data layer and provide a clean API for data access. Use a repository when the action is mostly or entirely about the related model.
Layers of a Laravel application using Repositories
- Service - Highest level of abstraction. Uses Repositories and Models to perform actions. Example:
StripePaymentService
- Repository - Middle layer of abstraction. Uses Models (not just the related Model) to perform actions. Example:
UserRepository
- Model - Lowest level of abstraction. Represents a single table in the database. Use only for relations and light transforms of the data. Example:
User
Installation
You can install the package via composer:
composer require nathanbarrett/laravel-repositories
Usage
First create a repository class
use NathanBarrett\LaravelRepositories\Repository; use App\Models\User; /** * @extends Repository<User> */ class UserRepository extends Repository { public function modelClass(): string { return User::class; } }
Generics are used to ensure that your IDE can provide code completion and type hinting.
class UserController extends Controller { public function __construct(private UserRepository $userRepository) { // } public function store(Request $request) { // The IDE will understand that $user is an instance of User $user = $this->userRepository->create($request->all()); return response()->json($user); } }
Or you can quickly create one using the command
php artisan make:repository UserRepository
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
License
The MIT License (MIT). Please see License File for more information.