PHPackages                             roke22/array-to-object-factory - 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. roke22/array-to-object-factory

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

roke22/array-to-object-factory
==============================

Array to object that automatically maps array index to object constructor parameters

v1.0.0(1y ago)12MITPHPPHP ^7.4||^8.0CI failing

Since Aug 29Pushed 1y ago1 watchersCompare

[ Source](https://github.com/roke22/array-to-object-factory)[ Packagist](https://packagist.org/packages/roke22/array-to-object-factory)[ RSS](/packages/roke22-array-to-object-factory/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (2)Dependencies (1)Versions (3)Used By (0)

PHP Hydrator - Array to Object Factory
======================================

[](#php-hydrator---array-to-object-factory)

How to install?
---------------

[](#how-to-install)

composer require roke22/array-to-object-factory

What is array to object factory?
--------------------------------

[](#what-is-array-to-object-factory)

This is a utility that help you to create a class and all dependencies of the class without mapping the values.

All objects are create using the construct methods so the data have to acomplish the validations you have.

Unique requisite is that the index of the values of the array have to be organize in the same level of hierarchy.

It have declare strict types so value 1 is not the same as '1'. PHP is not going to try to convert the int 1 to string '1'. In that case you will get a TypeError exception.

Example
-------

[](#example)

```
class SimpleClass
{
    protected string $name;
    protected bool $isActive;

    public function __construct(string $name, bool $isActive)
    {
        $this->name = $name;
        $this->isActive = $isActive;
    }
}
```

You can create this class doing this:

```
$data = [
    'name' => 'John Doe',
    'is_active' => false
];

$object = ArrayToObject::make($data, SimpleClass::class);
```

Array index are transformed to snake, camel and studly case to find the match between the array data and construct params of the object.

You can limit the conversion parssing a third parameter like this:

```
$object = ArrayToObject::make($data, SimpleClass::class, ArrayToObject::SNAKE);
```

Or even don't convert any data:

```
$object = ArrayToObject::make($data, SimpleClass::class, ArrayToObject::NONE);
```

Possible values are:

```
ArrayToObject::ALL // By default
ArrayToObject::SNAKE
ArrayToObject::CAMEL
ArrayToObject::STUDLY
ArrayToObject::NONE
```

Getting the original $data array as example:

```
$data = [
    'name' => 'John Doe',
    'is_active' => false
];
```

Array to object factory transform in the next array:

```
$data = [
    'name' => 'John Doe',
    'is_active' => false,
    'isActive' => false,
    'IsActive' => false,
];
```

If some of the index conversion exists in the original array the data will be override and the object can be construct with wrong data, to solve this you can force the conversion type to NONE or only the annotation you need

Example Complex class
---------------------

[](#example-complex-class)

```
class Classroom
{
    protected int $number;
    protected Course $course;

    public function __construct(int $number, Course $course)
    {
        $this->number = $number;
        $this->course = $course;
    }
}

class Course
{
    protected string $name;

    public function __construct(string $name)
    {
        $this->name = $name;
    }
}

$data = [
    'number' => 1,
    'course' => [
        'Maths'
    ]
];

$result = ArrayToObject::make($data, Classroom::class);
```

More examples
-------------

[](#more-examples)

You can view the test folders to view some examples of collections and more complex class.

Feel free to report any issue and do any pull request to improve the package.

Thank you.

###  Health Score

29

—

LowBetter than 60% of packages

Maintenance45

Moderate activity, may be stable

Popularity4

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity53

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

Unknown

Total

1

Last Release

428d ago

### Community

Maintainers

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

---

Top Contributors

[![roke22](https://avatars.githubusercontent.com/u/5707837?v=4)](https://github.com/roke22 "roke22 (5 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/roke22-array-to-object-factory/health.svg)

```
[![Health](https://phpackages.com/badges/roke22-array-to-object-factory/health.svg)](https://phpackages.com/packages/roke22-array-to-object-factory)
```

PHPackages © 2026

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