yaza / laravel-repository-service
Simple repository, service pattern for laravel
Installs: 30 378
Dependents: 2
Suggesters: 0
Security: 0
Stars: 140
Watchers: 2
Forks: 33
Open Issues: 0
pkg:composer/yaza/laravel-repository-service
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0.0||^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
- spatie/laravel-ray: ^1.35
- dev-master
- V6.0.1
- V6.0.0
- V5.1.0
- V5.0.1
- V5.0.0
- V4.0.0
- V3.2.7
- V3.2.6
- V3.2.5
- V3.2.4
- V3.2.3
- V3.2.2
- V3.2.1
- V2.1.2
- V2.1.1
- V2.1.0
- V2.0.0
- V1.5.15
- V1.4.13
- V1.3.14
- V1.3.13
- V1.3.12
- V1.3.11
- V1.3.10
- V1.3.9
- V1.3.8
- V1.2.8
- V1.2.7
- V1.2.6
- V1.2.5
- V1.2.4
- V1.2.3
- V1.2.2
- V1.2.1
- V1.1.4
- V1.1.3
- V1.1.2
- dev-feature/support-laravel-11
This package is auto-updated.
Last update: 2025-10-17 02:21:19 UTC
README
With easy repository, you can have the power of the repository pattern, without having to write too much code altogether. The package automatically binds the interfaces to the implementations, all you have to do is change in the configuration which implementation is being used at the moment!
Requirement
- Minimum PHP ^8.2
Installation
You can install the package via composer for latest version
$ composer require yaza/laravel-repository-service
Specific Version :
| Laravel Version | Package Version | 
|---|---|
| 12 | 6.x | 
| 11 | 5.x | 
| 10 | 4.0 | 
| 9 | 3.2 | 
# for laravel 11 $ composer require yaza/laravel-repository-service:"^5.0"
Publish the config file with (Important):
php artisan vendor:publish --provider="LaravelEasyRepository\LaravelEasyRepositoryServiceProvider" --tag="easy-repository-config"
Quick usage
You can also create only the repository, or service, or both with artisan:
php artisan make:repository User // or php artisan make:repository UserRepository // or create together with a service php artisan make:repository User --service // or php artisan make:repository UserRepository --service // or create a service separately php artisan make:service User // or php artisan make:service UserService // or php artisan make:service UserService --repository // create service with blank template php artisan make:service UserService --blank
How to change bind interface to new class implementation
Add this config to AppServiceProvider :
$this->app->extend(Interface::class, function ($service, $app) { return new NewImplement($service); });
Documentation
Note : When you create service the default used api template,in api template use setter getter data inside service for how to use you can look in src/Traits/ResultService.php, if you need blank template when create service, you need add argument --blank, ex : php artisan make:service User --blank.
example setter getter service with api template
// getter (on service called) $serviceName->getData() $serviceName->getCode() $serviceName->getMessage() $serviceName->getError() // setter (in service) $this->setCode() $this->setData() $this->setError() $this->setMessage()
More details will be explained in docs version 6.
Go to guide Docs V6
Changelog
Please see CHANGELOG for more information on what has changed recently.
License
The MIT License (MIT). Please see License File for more information.