PHPackages                             dxi/doctrine-extension - 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. [Database &amp; ORM](/categories/database)
4. /
5. dxi/doctrine-extension

ActiveLibrary[Database &amp; ORM](/categories/database)

dxi/doctrine-extension
======================

DXI Doctrine Extensions

1.0.0(10y ago)31.9k3[1 PRs](https://github.com/DXI-Ltd/doctrine-extension/pulls)PHPPHP &gt;=5.3.3CI failing

Since Jan 25Pushed 6y ago5 watchersCompare

[ Source](https://github.com/DXI-Ltd/doctrine-extension)[ Packagist](https://packagist.org/packages/dxi/doctrine-extension)[ RSS](/packages/dxi-doctrine-extension/feed)WikiDiscussions master Synced 1mo ago

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

DXI Doctrine Extension
======================

[](#dxi-doctrine-extension)

Doctrine 2 extensions

Installation
------------

[](#installation)

Add the **dxi/doctrine-extension** into **composer.json**

```
{
    "require": {
        "php":              ">=5.3.2",
        "dxi/doctrine-extension": "~1.0"
    }
}
```

Enum Extension
--------------

[](#enum-extension)

This Extension provides convenient way to create Doctrine Mapping Types from your Enum Types. For now, only ***marc-mabe/php-enum*** is supported (see ).

- Create your Enum Type

```
class MyEnum extends \MabeEnum\Enum
{
    const ONE = 'one';
    const TWO = 'two';
}
```

- Define your Entity or Document

```
class MyEntity
{
    private $id;

    /**
     * @var MyEnum
     */
    private $myEnum;

    /**
     * @return MyEnum
     */
    public function getMyEnum()
    {
        return $this->myEnum;
    }

    /**
     * @param MyEnum $myEnum
     */
    public function setMyEnum(MyEnum $myEnum)
    {
        $this->myEnum = $myEnum;
    }

    public function getId()
    {
        return $this->id;
    }
}
```

- Register your type with DBAL

```
use Dxi\DoctrineExtension\Enum\DBAL\DBALTypeRegistrar;
use Dxi\DoctrineExtension\Enum\DBAL\DBALTypeClassGenerator;

$targetDir = './enum-db-types';
$typeNamespace = 'My\Enum\DBALTypes';

$registrar = new DBALTypeRegistrar(new DBALTypeClassGenerator($targetDir, $typeNamespace));
$registrar->registerType('my_enum_type', '\MyEnum');
```

Now you can use ***my\_enum\_type*** with for Doctrine ORM mappings and with DBAL bindings. (see [http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/cookbook/custom-mapping-types.html](http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/cookbook/custom-mapping-types.html "DoctrineORM Custom Mapping Type")) Notice: Field mapped as ***my\_enum\_type*** creates column type "VARCHAR" (32 length by default, however you can use other "string" type properties)

- Register your type with MongoDB

```
use Dxi\DoctrineExtension\Enum\DBAL\DBALTypeRegistrar;
use Dxi\DoctrineExtension\Enum\DBAL\DBALTypeClassGenerator;

$targetDir = './enum-mongo-types';
$typeNamespace = 'My\Enum\MongoDbTypes';

$registrar = new MongoDbTypeRegistrar(new MongoDbTypeClassRegistrar($targetDir, $typeNamespace));
$registrar->registerType('my_enum_type', '\MyEnum');
```

Now you can use ***my\_enum\_type*** for your Doctrine MongoDB ODM mappings (see [http://docs.doctrine-project.org/projects/doctrine-mongodb-odm/en/latest/reference/basic-mapping.html#custom-mapping-types](http://docs.doctrine-project.org/projects/doctrine-mongodb-odm/en/latest/reference/basic-mapping.html#custom-mapping-types "DoctrineMongoDbODM Custom Mapping Type"))

Reference Extension
-------------------

[](#reference-extension)

It's a fork of the Gedmo/References extension. See [https://github.com/Atlantic18/DoctrineExtensions/blob/master/doc/references.md](https://github.com/Atlantic18/DoctrineExtensions/blob/master/doc/references.md "Gedmo/References extension")It provides multi registry support and XML/YML mapping drivers. Note, this Extension will be removed, when it become part of Gedmo Doctrine Extension project (see [doctrine-extensions/DoctrineExtensions#1320](https://github.com/doctrine-extensions/DoctrineExtensions/pull/1320))

###  Health Score

31

—

LowBetter than 68% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity22

Limited adoption so far

Community16

Small or concentrated contributor base

Maturity58

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 60% 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

3766d ago

### Community

Maintainers

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

![](https://www.gravatar.com/avatar/42b2a335947d064294cc9d52cd90dcfeb92924f4a5642fb398fe0f80614bf708?d=identicon)[DXI-8x8](/maintainers/DXI-8x8)

---

Top Contributors

[![dbojdo8x8](https://avatars.githubusercontent.com/u/76156710?v=4)](https://github.com/dbojdo8x8 "dbojdo8x8 (3 commits)")[![tharangakothalawala](https://avatars.githubusercontent.com/u/4851255?v=4)](https://github.com/tharangakothalawala "tharangakothalawala (1 commits)")[![toooni](https://avatars.githubusercontent.com/u/241080?v=4)](https://github.com/toooni "toooni (1 commits)")

---

Tags

enumormdoctrinemappingodmphp-enum

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/dxi-doctrine-extension/health.svg)

```
[![Health](https://phpackages.com/badges/dxi-doctrine-extension/health.svg)](https://phpackages.com/packages/dxi-doctrine-extension)
```

###  Alternatives

[gedmo/doctrine-extensions

Doctrine behavioral extensions

4.1k118.8M366](/packages/gedmo-doctrine-extensions)[doctrine/persistence

The Doctrine Persistence project is a set of shared interfaces and functionality that the different Doctrine object mappers share.

4.1k286.5M762](/packages/doctrine-persistence)[beberlei/doctrineextensions

A set of extensions to Doctrine 2 that add support for additional query functions available in MySQL, Oracle, PostgreSQL and SQLite.

2.1k75.1M146](/packages/beberlei-doctrineextensions)[doctrine/mongodb-odm

PHP Doctrine MongoDB Object Document Mapper (ODM) provides transparent persistence for PHP objects to MongoDB.

1.1k23.3M302](/packages/doctrine-mongodb-odm)[scienta/doctrine-json-functions

A set of extensions to Doctrine that add support for json query functions.

58723.9M36](/packages/scienta-doctrine-json-functions)[mmucklo/queue-bundle

Symfony2/3/4/5 Queue Bundle (for background jobs) supporting Mongo (Doctrine ODM), Mysql (and any Doctrine ORM), RabbitMQ, Beanstalkd, Redis, and ... {write your own}

120839.8k](/packages/mmucklo-queue-bundle)

PHPackages © 2026

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