PHPackages                             sopheos/pebble\_dataconverter - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. sopheos/pebble\_dataconverter

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

sopheos/pebble\_dataconverter
=============================

Data Mapper

0.0.2(2y ago)1195MITPHPPHP &gt;=8.1.0

Since Aug 3Pushed 2y ago1 watchersCompare

[ Source](https://github.com/sopheos/pebble_dataconverter)[ Packagist](https://packagist.org/packages/sopheos/pebble_dataconverter)[ RSS](/packages/sopheos-pebble-dataconverter/feed)WikiDiscussions main Synced 1mo ago

READMEChangelogDependencies (1)Versions (3)Used By (0)

Pebble/DataConverter
====================

[](#pebbledataconverter)

Bibliothèque de conversion de données structurés.

Règle de transformation
-----------------------

[](#règle-de-transformation)

Les règles de transformations peuvent être :

- un objet de conversion qui implémente `ConverterInterface`
- une fonction de rappel (`callback`)
- Un tableau associatif qui associe des noms de propriétés d'une donnée à une règle.
- Un objet ou un nom de classe à hydrater à partir du jeu de donnée.

Chaînage
--------

[](#chaînage)

Chaque outil de conversion `ConverterInterface`permet d'ajouter d'autres outils de conversions à executer ensuite.

- La méthode `one(mixed $rule): static` permet d'ajouter une règle qui va agir sur la donnée.
- La méthode `many(mixed $rule): static` permet d'ajouter une règle qui va agir sur chaque élement d'une donnée itérable.

Liste des objets de conversion :
--------------------------------

[](#liste-des-objets-de-conversion-)

- `CallbackConverter` : Transforme une fonction de rappel (callback) en objet de conversion.
- `CollectionConverter` : Applique un objet de conversion a chaque élément d'une donnée itérable
- `DateTimeConverter` : Transforme une date d'un format à un entre
- `HydrateConverter` : Transforme un tableau associatif en un objet hydraté
- `JsonDecodeConverter` : Transforme une chaine en un tableau associatif. Retourne null en cas d'erreur.
- `JsonEncodeConverter` : Transforme un tableau ou un objet en Json.
- `MapConverter` : Associe les propriétés d'un objet ou d'un tableau associatif à une règle.

Exemple :
---------

[](#exemple-)

```
class Car
{
    public $number;
    public $model;
    public $date;
}

class User
{
    public $name;
    public $birthdate;
    public array $cars = [];
}

$input = json_encode([
    'name' => 'Toto',
    'birthdate' => '1980-10-03',
    'cars' => [
        [
            'number' => 1651984,
            'model' => 'renault',
            'date' => '2000-01-01'
        ],
        [
            'number' => 2061161,
            'model' => 'audi',
            'date' => '2021-08-19'
        ],
    ]
]);

$carConverter = MapConverter::create()
    ->map('model', function ($input) {
        return ucfirst($input);
    })
    ->map('date', DatetimeConverter::create('Y-m-d', 'd/m/Y'))
    ->one(Car::class);

$userConverter = JsonDecodeConverter::create()
    ->one([
        'birthdate' => DatetimeConverter::create('Y-m-d', 'd/m/Y'),
        'cars' => Converter::create()->many($carConverter)
    ])
    ->one(new User);

$output = $userConverter($input);
```

Résultat :

```
User Object
(
    [name] => Toto
    [birthdate] => 03/10/1980
    [cars] => Array
        (
            [0] => Car Object
                (
                    [number] => 1651984
                    [model] => Renault
                    [date] => 01/01/2000
                )

            [1] => Car Object
                (
                    [number] => 2061161
                    [model] => Audi
                    [date] => 19/08/2021
                )

        )

)

```

###  Health Score

23

—

LowBetter than 27% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity13

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity43

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

2

Last Release

1011d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/e5a5482c3c1b25e5c39c23177570691f1e625aa5c094dc5dce45284b90409910?d=identicon)[sopheos](/maintainers/sopheos)

---

Top Contributors

[![sugatasei](https://avatars.githubusercontent.com/u/6987162?v=4)](https://github.com/sugatasei "sugatasei (2 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/sopheos-pebble-dataconverter/health.svg)

```
[![Health](https://phpackages.com/badges/sopheos-pebble-dataconverter/health.svg)](https://phpackages.com/packages/sopheos-pebble-dataconverter)
```

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
