iqbalatma / laravel-service-repo
Project for extend base class on laravel with service repo pattern
Installs: 1 659
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/iqbalatma/laravel-service-repo
Requires
- php: >=8.0
- dev-master
- 5.0.0
- 4.1.4
- 4.1.3
- 4.1.2
- 4.1.1
- 4.1.0
- 4.0.0
- 3.4.2
- 3.4.1
- 3.4.0
- 3.3.15
- 3.3.14
- 3.3.13
- 3.3.12
- 3.3.11
- 3.3.10
- 3.3.9
- 3.3.8
- 3.3.7
- 3.3.6
- 3.3.5
- 3.3.4
- 3.3.3
- 3.3.2
- 3.3.1
- 3.3.0
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.1
- 3.1.0
- 3.0.0
- 2.1.0
- 2.0.0
- 1.0.29
- 1.0.28
- 1.0.27
- 1.0.26
- 1.0.25
- 1.0.24
- 1.0.23
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-revertingback
- dev-upgrade/repository
- dev-feature/service-interfacing
- dev-develop
- dev-feature/custom-config-base-class
- dev-feature/perpage-dynamic
- dev-refactoring/revamp-code
- dev-refactor/documentation
- dev-feature/refactoring-query
- dev-feature/generate-repository-command
- dev-iqbalatma-patch-1
This package is auto-updated.
Last update: 2025-10-13 07:42:40 UTC
README
Laravel Service Repository is laravel package for service repository pattern. Service repository pattern helps you to separate concern and move logic into service class. From service class you can query all of your data from repository, not directly using model. This will help you to avoid redundant query and make it easier to maintain.
Upcomming
- Customize root of filter and order by config
- Publish service stub for customization
- Testing
- Type hint for predefined method on repository extend
How to install
Use composer to install Laravel Service Repository Package
composer require iqbalatma/laravel-service-repo
Concept
Here is concept of service repository, you can see diagram below Controller will handle only http request and http response. This will make your controller thin. All of data from request will be validate on Validation class. All validation rule will be defined here After all data validated, data will be passed to service. In service, all of business logic works. Every business logic that need data or modify data from database will be communicate via repository. This repository already have some predefined query, but you are free to customize predefined query as you need.
Service
Service is use for your business logic. You can call service from controller or from another service. This package have base service and you can extend to this service. You can also generate service via artisan command.
php artisan make:service UserService
This command will generate service for you in App/Services directory.
Repository
Use repository to query your database via model. So you do not need to write same query twice. You can generate repository on directroy App/Repositories via artisan command.
php artisan make:repository UserRepository
This command will generate repository for you in App/Repositories directory Here is example of UserRepository.
<?php namespace App\Repositories; use Iqbalatma\LaravelServiceRepo\BaseRepository; use Illuminate\Database\Eloquent\Builder; use App\Models\User; class UserRepository extends BaseRepository { /** * use to set base query builder * @return Builder */ public function getBaseQuery(): Builder { return User::query(); } /** * use this to add custom query on filterColumn method * @return void */ public function applyAdditionalFilterParams(): void { } }
How to call repository from service
You can call method on repository via static or non-static method.
Note
Here is example call repository via static method
<?php namespace App\Services\Management; use Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; use Illuminate\Pagination\LengthAwarePaginator; class UserService extends BaseService { public function getAllDataPaginated():LengthAwarePaginator { return UserRepository::getAllDataPaginated(); } }
Note
Here is example call repository via non-static method
<?php namespace App\Services\Management; use Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; use Illuminate\Pagination\LengthAwarePaginator; class UserService extends BaseService { public function getAllDataPaginated():LengthAwarePaginator { return (new UserRepository())->getAllDataPaginated(); } }
Predefined Method Query
You can call predefied method from service. Here is list of predefined method query and it's use case.
<?php function getAllDataPaginated(array $whereClause = [], array $columns = ["*"]); function getAllData(array $whereClause = [], array $columns = ["*"]); function getDataById(string|int|array $id, array $columns = ["*"]); function getSingleData(array $whereClause = [], array $columns = ["*"]); function addNewData(array $requestedData); function updateDataById(string|int $id, array $requestedData, array $columns = ["*"], bool $isReturnObject = true); function updateDataByWhereClause(array $whereClause, array $requestedData, array $columns = ["*"], bool $isReturnObject = false); function deleteDataById(string|int $id); function deleteDataByWhereClause(array $whereClause);
You can also chaining method before predefined method query.
<?php function with(array|string $relations); function without(array|string $relations); function withAvg(array|string $relation, string $column); function withCount(mixed $relations); function withMin(array|string $relation, string $column); function withMax(array|string $relation, string $column) function withSum(array|string $relation, string $column); function has(Relation|string $relation, string $operator = '>=', int $count = 1, string $boolean = 'and', Closure|null $callback = null); function whereHas(string $relation, Closure|null $callback = null, string $operator = '>=', int $count = 1); and other method ....
Note
Here is how to use predefined method with chaining method for additional query
<?php namespace App\Services\Management; use Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; use Illuminate\Pagination\LengthAwarePaginator; class UserService extends BaseService { public function getAllDataPaginated():LengthAwarePaginator { return UserRepository::with('profile')->getAllDataPaginated(); } }
How to add predefined method
You can also create your own method on repository. For example you want to create query that will be execute in many place and want to avoid redundant code.
Important
Create predefined method query with query prefix. So you can call statically without query prefix. Example : UserRepository::getAllActiveUser()
<?php namespace App\Repositories; use Iqbalatma\LaravelServiceRepo\BaseRepository; use Illuminate\Database\Eloquent\Builder; use App\Models\User; class UserRepository extends BaseRepository { /** * use to set base query builder * @return Builder */ public function getBaseQuery(): Builder { return User::query(); } /** * use this to add custom query on filterColumn method * @return void */ public function applyAdditionalFilterParams(): void { } public function queryGetAllActiveUser(){ return $this->builder->where('status', 'active')->get(); } }
How to call model scope on repository
Sometimes you want to create model local scope and still want to use repository to call it.
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Builder; class Tag extends Model { use HasFactory; protected $fillable = [ "name" ]; public function scopeActive(Builder $query){ $query->where('status', '=', 'active'); } }
you can call this scope TagRepository::active()->getAllDataPaginated();
How to use orderColumn method
Order column is predefined method that will use query param from http request for order requested data. Before use order column you need to defined column that allowed to order. You can define that orderable column inside the model.
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; class User extends Model { use HasFactory; public array $orderableColumns = [ "name" => "users.name", "address" => "users.address", ]; }
As you can see, property $orderableColumns is array that has key and value. Key of this property is use to key from http request. You can customize this key into whatever you want The value of this property is mapping to column name of database table
To use this order you just need to call orderColumn method when calling repository
<?php namespace App\Services\Management; Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; class UserService extends BaseService { public function getAllDataPaginated(){ return UserRepository::orderColumn()->getAllDataPaginated(); } }
In other condition you can also pass parameter into orderColumn method to override orderable column
<?php namespace App\Services\Management; Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; class UserService extends BaseService { public function getAllDataPaginated(){ return UserRepository::orderColumn([ "name" => "users.name", "address" => "users.address", ])->getAllDataPaginated(); } }
How to use filterColumn method
Filter column is predefined method to filter data via query param from http request Before use filterColumn method, you need to define list of column that allowed to filter
Important
All of filter query using operator '=', but you can define custom operator based on your needs
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; class User extends Model { use HasFactory; public array $filterableColumns = [ "name" => "users.name", "address" => "users.address", ]; }
To use filter column you just need to call and chain this method. You can also chain with other method like orderColumn
<?php namespace App\Services\Management; Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; class UserService extends BaseService { public function getAllDataPaginated(){ return UserRepository::orderColumn()->filterColumn()->getAllDataPaginated(); } }
In other condition you can also pass parameter into filterColumn method to override filterable column
<?php namespace App\Services\Management; Iqbalatma\LaravelServiceRepo\BaseService; use App\Repositories\UserRepository; class UserService extends BaseService { public function getAllDataPaginated(){ return UserRepository::orderColumn()->filterColumn([ "name" => "users.name", "address" => "users.address", ])->getAllDataPaginated(); } }
Note
You can also filter column on relation. But you need to define relation and filterable column on model
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use App\Models\Profile; class User extends Model { use HasFactory; public array $filterableColumns = [ "name" => "users.name", "address" => "users.address", ]; public array $relationFilterableColumns = [ "profile" => [ "phone" => "profiles.pone" ] ]; public function profile(){ return $this->belongsTo(Profile::class); } }
You when you want to filter relation of model, you need to make sure the relation is already defined. And then you need to create $relationFilterableColumns property. The key of this property is relation name and the value is filterable column just like $filterableColumns property.
Note
You can also override relation filterable column just pass array filterable column on second argumen of filterColumn. Example : filterColumn([], [ "profile" => [ "phone" => "profiles.pone" ] ])
How to custom operator on filterColumn
You just need to define array for column and operator
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; class User extends Model { use HasFactory; public array $filterableColumns = [ "name" => [ "column" => "users.name" "operator" => "like" ], "address" => "users.address", ]; }