laulamanapps / doctrine-enum
Create Doctrine Enum Types with ease
dev-master
2019-01-22 11:54 UTC
Requires
- php: >=7.1
- doctrine/dbal: 2.9
- werkspot/enum: ^2.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.7
- mockery/mockery: ^1.0
- phpunit/phpunit: ^6.3
This package is auto-updated.
Last update: 2024-11-23 01:06:29 UTC
README
This package holds helper classes to convert Enums to database values with Doctrine.
Install
# composer require laulamanapps/doctrine-enum
Usage
Create Enum as described here.
# src/Enums/FooEnum.php namespace YourAwesomeOrganisation\Enums; use Werkspot\Enum\AbstractEnum; /** * @method static FooEnum foo() * @method bool isFoo() * @method static FooEnum bar() * @method bool isBar() */ final class FooEnum extends AbstractEnum { const FOO = 'foo'; const BAR = 'bar'; }
Create a specific doctrine type for that enum:
# src/Doctrine/Persistence/Type/FooEnumType.php namespace YourAwesomeOrganisation\Doctrine\Persistence\Type; use YourAwesomeOrganisation\Enums\FooEnum; final class FooEnumType extends AbstractOneOnOneEnumType { protected function getEnumClass() { return FooEnum::class; } public function getName(): string { return 'enum_foo_type'; } }
Add type to doctrine config:
# config/packages/doctrine.yaml doctrine: dbal: types: enum_foo_type: YourAwesomeOrganisation\Doctrine\Persistence\Type\FooEnumType
Now use it in your Entities
# src/Entity/MyData.php use YourAwesomeOrganisation\Enums\FooEnum; use Doctrine\ORM\Mapping as ORM; /** * @ORM\Entity() */ class MyData { /** * @var FooEnum * * @ORM\Column(type="enum_foo_type") */ private $foo; public function setFoo(FooEnum $fooEnum): void { $this->foo = $fooEnum; } public function getFoo(): FooEnum { return $this->foo; } }
Now doctrine will automatically convert ENUM <=====> database value