yeremi/schema-mapper 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

yeremi/schema-mapper

最新稳定版本:v1.0.1

Composer 安装命令:

composer require yeremi/schema-mapper

包简介

A PHP library for mapping external API data to PHP objects using PHP 8 attributes.

README 文档

README

A PHP library for mapping external API data to PHP objects using PHP 8 attributes. This library helps you easily transform API responses into strongly-typed PHP objects with minimal boilerplate code.

Index

  1. Requirements
  2. Installation
  3. Basic Usage
  4. Features
  5. Error Handling
  6. Examples
  7. License
  8. Support

Requirements

  • PHP 8.0+

Installation

Install the package via Composer:

composer require yeremi/schema-mapper

Basic Usage

  1. Define your data class with attributes:
use Yeremi\SchemaMapper\Attributes\ApiSchema;

class User
{
    #[ApiSchema(key: 'first_name')]
    private string $firstName;

    #[ApiSchema(key: 'last_name')]
    private string $lastName;

    #[ApiSchema(key: 'email')]
    private string $email;

    // Getters
    public function getFirstName(): string
    {
        return $this->firstName;
    }

    public function getLastName(): string
    {
        return $this->lastName;
    }

    public function getEmail(): string
    {
        return $this->email;
    }
}
  1. Use the normalizer to map your data:
use Yeremi\SchemaMapper\Normalizer\NormalizerInterface;

class MyUseCase {
    public function __construct(
        NormalizerInterface $normalizer
    ) {}
    
    public function fetchSomeData(){
        $response = [
            'first_name' => 'John',
            'last_name' => 'Doe',
            'email' => 'john@example.com'
        ];

        $user = $this->normalizer->normalize($response, User::class);
        echo $user->getFirstName(); // Outputs: John
    }
}

Features

  • Map API responses to PHP objects using attributes
  • Support for nested objects
  • Type validation
  • Nullable properties support
  • Dependency injection ready with interfaces

Error Handling

The library throws specific exceptions:

  • TypeMismatchException: When the data type doesn't match the property type
  • ReflectionException: When there are issues with class reflection

Examples

For more examples and advanced use cases, refer to the examples directory in the documentation.

License

This project is open source and licensed under the MIT License - see the LICENSE file for details.

Support

If you encounter any problems or have any questions, please open an issue.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-12-25