Entity hydration with change tracking, bidirectional field mapping, and identity generation (UUID v4/v5/v7, NanoID)

Maintainers

Package info

github.com/jardisSupport/data

pkg:composer/jardissupport/data

Statistics

Installs: 83

Dependents: 1

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.0 2026-03-31 07:29 UTC

This package is auto-updated.

Last update: 2026-03-31 07:30:54 UTC


README

Build Status License: PolyForm Shield PHP Version PHPStan Level PSR-12

Part of the Jardis Business Platform — Enterprise-grade PHP components for Domain-Driven Design

Three focused services for entity data operations: Hydration transforms raw database rows into typed PHP objects with automatic change tracking. FieldMapper provides bidirectional array-key mapping between domain and database names. Identity generates unique identifiers (UUID v4/v5/v7, NanoID).

Features

  • Two-Stage Hydrationhydrate() for flat entities, hydrateAggregate() for nested aggregates with recursive object graphs
  • Programmatic Applyapply() sets properties like hydrate() but preserves the snapshot — changes are detected by getChanges()
  • Automatic Snapshots — a snapshot is taken on every hydration call to establish the baseline for change detection. Snapshot keys are the original DB column names — used as source of truth for toArray(), aggregateToArray(), and diff()
  • Value-Based DetectiontoArray() and diff() automatically distinguish DB columns from relations by value type — no attributes required
  • Change Tracking — field-level diff between current property values and the snapshot via getChanges()
  • Entity Cloningclone() for flat entity clone (DB columns), cloneAggregate() for deep clone including nested objects
  • Batch LoadingloadMultiple() hydrates an array of database rows into an array of entities efficiently
  • Field MappingtoColumns() and fromColumns() rename array keys between domain and database names using an explicit map; fromAggregate() maps hierarchical arrays with per-entity mappings and filters unmapped keys
  • Identity Generation — UUID v4 (random), v5 (deterministic), v7 (time-ordered with monotonic counter), and NanoID (compact, URL-safe)
  • PHP Attributes#[Table], #[Column], #[PrimaryKey], #[Aggregate] for entity metadata
  • TypeCaster — automatic DB-to-PHP type conversion (int, bool, float, DateTime, DateTimeImmutable, BackedEnum)

Installation

composer require jardissupport/data

Quick Start

use JardisSupport\Data\Hydration;
use JardisSupport\Data\Identity;
use JardisSupport\Data\FieldMapper;

// --- Hydration ---
$hydration = new Hydration();

// Hydrate an entity from a database row
$user = new User();
$hydration->hydrate($user, [
    'id'         => 42,
    'first_name' => 'Jane',
    'last_name'  => 'Doe',
    'created_at' => '2024-06-01 10:00:00',
]);

// Apply programmatic changes (snapshot stays untouched)
$hydration->apply($user, ['first_name' => 'John']);

// Detect exactly what changed since hydration
$changes = $hydration->getChanges($user);
// ['first_name' => 'John']

// --- Identity ---
$identity = new Identity();

$id = $identity->generateUuid7();   // time-ordered, sortable
$id = $identity->generateUuid4();   // random
$id = $identity->generateUuid5($namespace, 'customer:12345');  // deterministic
$id = $identity->generateNanoId();  // compact, URL-safe (21 chars)

// --- FieldMapper ---
$mapper = new FieldMapper();

$map = ['customerName' => 'name', 'orderNumber' => 'order_number'];
$columns = $mapper->toColumns(['customerName' => 'Müller'], $map);
// ['name' => 'Müller']
$fields = $mapper->fromColumns(['name' => 'Müller'], $map);
// ['customerName' => 'Müller']

Interfaces

All three services implement port interfaces from jardissupport/contract:

Service Interface Purpose
Hydration JardisSupport\Contract\Data\HydrationInterface Entity hydration, snapshots, change tracking
Identity JardisSupport\Contract\Data\IdentityInterface UUID v4/v5/v7, NanoID generation
FieldMapper JardisSupport\Contract\Data\FieldMapperInterface Bidirectional array-key mapping

Documentation

Full documentation, guides, and API reference:

docs.jardis.io/support/data

License

This package is licensed under the PolyForm Shield License 1.0.0. Free for all use except building competing frameworks or developer tooling.

Jardis · Documentation · Headgent