承接 boulzy/data-transformer 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

boulzy/data-transformer

Composer 安装命令:

composer require boulzy/data-transformer

包简介

Transform objects into other objects

README 文档

README

The boulzy/data-transformer library provides a simple and flexible way to transform objects into other objects.

📋 Table of contents

👋 Introduction

When manipulating data, the need to change the representation of this data sometimes arises, so it can be used by the different components of the application. A common example is the need to transform DTOs to business objects and vice versa.

This transformation often involves a lot of boilerplate code that is not directly related to the business logic of the application. This library aims to reduce the repetition of this code by providing a simple and flexible way to transform an object into an object of another class.

⚙️ Requirements

  • PHP ^8.3
  • symfony/property-access ^7.0
  • symfony/property-info ^7.0
  • phpdocumentor/reflection-docblock ^5.3

ℹ️ This library also provides a bundle to use and extend the DataTransformer in a Symfony application.

📚 Documentation

The documentation is available in the docs/ directory of this repository.

⬇️ Installation

The installation is done using Composer.

composer require boulzy/data-transformer

Don't forget to include vendor/autoload.php file.

🧑‍💻 Usage

First, you must retrieve an instance of \Boulzy\DataTransfomer\DataTransformerInterface.

If you're not in a Symfony application, check the documentation to learn how to get a DataTransformer object.

The DataTransformer exposes one method: transform(object $source, string $targetClass): object. The first argument is the object you currently have, and the second the class in which you want to transform it.

<?php

namespace App\Controller;

use App\DTO\EditUser;
use App\Entity\User;
use Boulzy\DataTransformer\DataTransformerInterface;
use Doctrine\Persistence\ObjectManager;
use Symfony\Component\HttpKernel\Exception\UnprocessableEntityHttpException;
use Symfony\Component\Validator\Validator\ValidatorInterface;

class UserController
{
    public function __construct(
        private ValidatorInterface $validator,
        private DataTransformerInterface $transformer,
        private ObjectManager $manager,
    ) {
    }

    public function __invoke(EditUser $editUser): User
    {
        $errors = $this->validator->validate($editUser);
        if (0 < \count($errors)) {
            throw new UnprocessableEntityHttpException((string) $errors);
        }

        $user = $this->transformer->transform($editUser, User::class);
        $this->manager->flush();

        return $user;
    }
}

Ready for more? Let's get started! 🚀

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-02-24