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!
- Minimum PHP ^8.2
You can install the package via composer for latest version
$ composer require yaza/laravel-repository-service
Specific Version :
Laravel Version | Package Version |
---|---|
11 | 5.x |
10 | 4.0 |
9 | 3.2 |
# for laravel 10
$ composer require yaza/laravel-repository-service:"^4.0"
# for laravel 9
$ composer require yaza/laravel-repository-service:"^3.2"
Publish the config file with (Important):
php artisan vendor:publish --provider="LaravelEasyRepository\LaravelEasyRepositoryServiceProvider" --tag="easy-repository-config"
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
Add this config to AppServiceProvider :
$this->app->extend(Interface::class, function ($service, $app) {
return new NewImplement($service);
});
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 5.
Go to guide Docs V5
Please see CHANGELOG for more information on what has changed recently.
The MIT License (MIT). Please see License File for more information.