omnicode / lara-service
Service layer for CRUD
Installs: 4 141
Dependents: 0
Suggesters: 2
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- laravel/framework: 5.7.*
- omnicode/lara-repo: ~4.0
- omnicode/lara-support: ~4.0
Requires (Dev)
- mockery/mockery: ~1.0
- php-mock/php-mock: 1.0.1
- phpunit/phpunit: ~7.0
Suggests
- omnicode/lara-crud: LaraService integrated with LaraCrud
- omnicode/lara-model: LaraService integrated with LaraModel
- omnicode/lara-repo: LaraService integrated with LaraRepo
README
Lara-Service
Generalized Service layer
Installation
Run the following command from you terminal:
composer require "omnicode/lara-service: 2.0.*"
or add this to require section in your composer.json file:
"omnicode/lara-service": "2.0.*"
then run composer update
Usage
First, create your Service class like shown below with example AcccountService
<?php namespace App\Services; use App\Repositories\Contracts\AccountRepositoryInterface as AccountRepository; use App\Validators\AccountValidator; use LaraService\Services\LaraService; class AccountService extends LaraService { public function __construct(AccountRepository $accountRepository, AccountValidator $accountValidator) { $this->baseRepository = $accountRepository; $this->baseValidator = $accountValidator; } }
The Repository and Validator classes should have the following methods pushCriteria, saveAssociated, findForShow, findFillable, getKeyName, destroy, getIndexableColumns, paginate, setSortingOptions
and isValid, getErrors
respectively. Those are already implemented in Lara Validation and Lara Repository packages.
And finally, use the service in the controller:
<?php namespace App\Http\Controllers; use App\Services\AccountService; class AccountsController extends Controller { public function __construct(AccountService $accountService) { parent::__construct(); $this->baseService = $accountService; } }
Available Methods
The following methods are available in LaraService:
LaraRepo\Contracts\RepositoryInterface
public function setBaseRepository(RepositoryInterface $repository) public function getBaseRepository() public function setBaseValidator($validator) public function getBaseValidator () public function setValidationErrors($errors) public function getValidationErrors() public function paginate($sort = [], $group = self::GROUP) public function create($data) public function createWithRelations($data, $relations = null) public function findForShow($id, $columns = null) public function find($id) public function update($id, $data) public function updateWithRelations($id, $data, $relations = null) public function destroy($id) public function validate($validator, $data, $options = []) public function paginateRepositoryWhere($repository, $group = self::GROUP, $column = null, $val = null) public function paginateRepository($repository, $group = self::GROUP) public function setSortingOptions($repository, $options = [], $group = self::GROUP) }
Example - create a new account repository:
// for index page use // returns item list and columns with their columns information $this->accountService->paginate() // if you want to sort your index page use $this->accountService->setSortingOptions($repository) // to create new record $this->accountService->create($request->all()); // returns validation errors of last operation $this->accountService->getValidationErrors(); // to save items with relations $this->accountService->createWithRelations($data, $relations) // to find based on $showable attributes $this->accountService->findForShow($id) // usual find with fillable columns $this->accountService->find($id) // to update based on primary key $this->accountService->update($id, $data) // to update and item with relations $this->accountService->updateWithRelations($id, $data, $relations) // to delelte $this->accountService->destroy($id) // to validate the data (internally uses the injected Validator) $this->accountService->validate($validator, $data, $options = [])