定制 mphamid/service-repository 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mphamid/service-repository

最新稳定版本:1.0.2

Composer 安装命令:

composer require mphamid/service-repository

包简介

Service Repository Design Pattern In Laravel

README 文档

README

This package is designed to implement the service structure on Laravel projects.

Installation

composer require mphamid/service-repository

Requirement

  • Laravel 9.*

Generator Commands

php artisan make:dto
php artisan make:service-exception {service-name}
php artisan make:service-exception-language {service-name} --language=fa
php artisan make:service-repository {service-name} --grpc
php artisan make:service-transformer {service-name}
php artisan make:service {service-name} --grpc --language=fa --transformer

Service Structure

Each service contains 5 files that are located in a folder with the same name as the service in the services folder, listed below

  1. Exception: To collect the service exception with the following specific structure

exception class must be extends from ServiceException class and each class contains several errors that contain a constant variable and the definition of this variable. In defining the parameters, the exception error code, the machine-readable code and the error message must be defined please attention to below example

class TestException extends ServiceException
{
    public const NEW_ERROR = 'new_error';

    public function configureExceptions()
    {
        $this->addException(self::NEW_ERROR, Response::HTTP_BAD_REQUEST, 'this is a test exception');
    }
}
  1. Exception Language: This file is the translation of the exceptions in the service, which sends the text related to the exception error to the user according to the language specified in the request of the error handling section.
  2. Repository: Service interface for implement service repository structure
  3. Transformer: It is the class between service methods and other microservices, which can be provided in different versions and include calling several methods from several service.
  4. Service: A class that extends from the repository and all the logic of the service is placed in this class

Register Services

There are two ways to connect the repository to the services, which you can do in the service providers.

$this->app->bind(UserRepository::class, UserService::class);

or

$this->app->singleton(UserRepository::class, UserService::class);

The difference between bind and singleton

The difference between these two methods is that they persist in memory. If you use the singleton method, your instance of the service class will persist in memory and one instance will be used for all requests. Therefore, use Singleton for high-visit services and make sure that this feature does not interfere with the performance of your service.

Handel Service Exception

Please put the following code sample in the report method of the exception handler file (app/Exceptions/Handler.php) To integrate and standardize the outputs issued from the service.

    if ($e instanceof ServiceException && ($request->wantsJson() || $request->is('api/*'))) {
        return response()->json(['code' => $e->getAppCode(), 'message' => $e->getMessage()], $e->getCode());
    }

统计信息

  • 总下载量: 23
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-11-20