asokol1981/abstract-mold 问题修复 & 功能扩展

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

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

asokol1981/abstract-mold

最新稳定版本:2.0.3

Composer 安装命令:

composer require asokol1981/abstract-mold

包简介

A base abstract class for centralizing all changes to an entity using user-provided data (mold pattern).

README 文档

README

tests codecov downloads

💎 AbstractMold is a set of abstract classes and shared utilities for centralized management of entity data changes, with strict control and single-point validation.

✨ Main idea

A Mold acts as a single entry point for handling any incoming user data (creation, updates, or partial patches). All changes go through the mold to ensure:

  • Whitelisted allowed fields only.
  • Centralized validation and normalization logic.
  • Predictable and consistent data preparation.

🧩 Two mold types

🟢 AbstractMutableMold

Allows step-by-step incremental data changes and gradual accumulation of modifications.

  • Perfect for form scenarios or multi-step wizards.
  • You can modify fields one by one or in batches.
  • Tracks which fields were explicitly changed.

🔵 AbstractImmutableMold

Accepts base data and a patch all at once in the constructor.

  • Ideal for APIs or services where you receive all data as a single payload.
  • Does not allow further modification after creation (immutable approach).

🚀 Installation

composer require asokol1981/abstract-mold

🚀 Usage examples

🟢 AbstractMutableMold usage

use ASokol1981\AbstractMold\AbstractMutableMold;

final class UserMutableMold extends AbstractMutableMold
{
    protected function publicFields(): array
    {
        return ['name', 'email', 'age'];
    }

    protected function validatedData(): array
    {
        $age = $this->getRawData('age');

        return [
            'name' => (string) $this->getRawData('name', ''),
            'email' => strtolower((string) $this->getRawData('email', '')),
            'age' => $age !== null ? (int) $age : null,
        ];
    }
}

// Usage

$mold = new UserMutableMold(['name' => 'John', 'email' => 'John@EXAMPLE.COM']);
$mold->change('name', 'Johnny');
$mold->changes(['email' => 'Johnny@EXAMPLE.COM', 'age' => '25']);

$data = $mold->validated();
// ['name' => 'Johnny', 'email' => 'johnny@example.com', 'age' => 25]

$changes = $mold->changesValidated();
// ['name' => 'Johnny', 'email' => 'johnny@example.com', 'age' => 25]

🔵 AbstractImmutableMold usage

use ASokol1981\AbstractMold\AbstractImmutableMold;

final class UserImmutableMold extends AbstractImmutableMold
{
    protected function publicFields(): array
    {
        return ['name', 'email', 'age'];
    }

    protected function validatedData(): array
    {
        $age = $this->getRawData('age');

        return [
            'name' => (string) $this->getRawData('name', ''),
            'email' => strtolower((string) $this->getRawData('email', '')),
            'age' => $age !== null ? (int) $age : null,
        ];
    }
}

// Usage

$mold = new UserImmutableMold(
    ['name' => 'John', 'email' => 'John@EXAMPLE.COM'],
    ['name' => 'Johnny', 'age' => '25']
);

$data = $mold->validated();
// ['name' => 'Johnny', 'email' => 'john@example.com', 'age' => 25]

$changes = $mold->changesValidated();
// ['name' => 'Johnny', 'age' => 25]

✅ Key advantages

  • 🚦 Strict allowed fields control.
  • 💾 Centralized validation logic.
  • 🧩 Flexible design for different scenarios (mutable vs immutable).
  • ⚡️ Built-in validated data cache for performance.
  • 🛡 Safe and predictable API.

🤝 License

MIT © Aleksei Sokolov

Created in collaboration with ChatGPT (OpenAI), July 2025.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-07-08