base service to simplify service layer implement

Maintainers

👁 dbwhddn10

Package info

github.com/simplify-service-layer/php

pkg:composer/simplify-service-layer/base

Statistics

Installs: 15

Dependents: 2

Suggesters: 0

Stars: 0

Open Issues: 0

dev-master 2025-03-26 16:30 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT c053276d6e37b1de18d7f5a3ba4f256c8c2a2d21

This package is auto-updated.

Last update: 2026-06-26 19:29:46 UTC


README

helper for declarative backend service layer.

UseCase Example

class UserService extends Service {

 public function __constructor(UserRepository $userRepository)
 {
 $this->userRepository = $userRepository;
 }

 /**
 * names declaration be used in validation error message
 */
 public function getNames()
 {
 return [
 // basic example
 'token' => 'authorized token',
 // dictionary type data key must have '[...]' for subkey naming
 'auth_user' => 'authorized user[...]',
 // nested bound name with '{{keyName}}'
 'user_profile' => 'profile[...] for {{auth_user}}',
 ];
 }

 /**
 * callbacks declaration be run after validation check is passed
 */
 public function getCallbacks()
 {
 return [
 // called after `auth_user` validation check is passed
 'auth_user__session' => function ($authUser) {
 // session
 Session::setData('auth_user', $authUser)
 },
 // called after `auth_user` validation check is passed
 'auth_user__logging' => function ($authUser) {
 // logging
 Log::write('user id:'.$authUser->getId().' logged in');
 },
 ];
 }

 /**
 * loaders declaration be used for loading data
 */
 public function getLoaders()
 {
 return [
 // injected `$userRepository` value take from instance properties
 // injected `$jwe` value take from loaded data
 'auth_user' => function ($jwe, $userRepository) {
 return $userRepository->findById($jwe->sid);
 },
 // injected `$token` value take from init input token parameter
 'jwe' => function ($token) {
 return new JWE($token);
 },

 // result key must be exists
 // result key is output value of $service->run
 'result' => function ($authUser) {
 return $authUser;
 }
 ];
 }

 /**
 * rule lists declaration be used for validation check
 */
 public function getRuleLists()
 {
 return [
 // ...
 ];
 }
}