PHP Enum Symfony
 
  
  
   
  , (*1)
, (*1)
Symfony support for zlikavac32/php-enum., (*2)
Table of contents
- Installation
- 
Usage
- Form
- Validator
 
- Limitations
Installation
Recommended installation is through Composer., (*3)
composer require zlikavac32/php-enum-symfony
Usage
Assumption is that there exists a valid enum \YesNoEnum., (*4)
Form type for enum is provided as \Zlikavac32\SymfonyEnum\Form\Type\EnumType. There is one required options enum_class which must contain enum class FQN., (*5)
Internally this extends \Symfony\Component\Form\Extension\Core\Type\ChoiceType and populates choices from the defining enum_class., (*6)
If any of the choices and/or choice_loader options is/are passed, an \LogicException will be thrown. Since these fields are overridden internally, passing them from the outside could cloud code's original purpose. Any other option provided by the \Symfony\Component\Form\Extension\Core\Type\ChoiceType can be used., (*7)
use \Zlikavac32\SymfonyEnum\Form\Type\EnumType;
class FormModel
{
    public $answer;
    // ...
}
$formModel = new FormModel();
$form = $this->createFormBuilder($formModel)
    ->add('answer', EnumType::class, [
        'enum_class' => \YesNoEnum::class
    ])
    // ...
    ->getForm();
Validator
Two constraints are provided, \Zlikavac32\SymfonyEnum\Validator\Constraints\ValidEnumElement and \Zlikavac32\SymfonyEnum\Validator\Constraints\ValidEnumElementName. Internally, they use \Symfony\Component\Validator\Constraints\Choice., (*8)
Required constraint argument is enumClass which must contain enum class FQN., (*9)
If any of the choices, callback and/or strict options is/are passed, an \LogicException will be thrown. Since these fields are overridden internally, passing them from the outside could cloud code's original purpose. Any other option provided by the \Symfony\Component\Validator\Constraints\Choice can be used., (*10)
- 
ValidEnumElement- accepted values arenulland any valid enum element from the defined enum class FQN
- 
ValidEnumElementName- accepted values arenulland any valid enum element name from the defined enum class FQN
Example for annotation use:, (*11)
/**
 * @ValidEnumElement(enumClass="\YesNoEnum")
 */
Limitations
Due to doctrine/common issue #794 with checks for aliased namespaces, validation of form enum element within an array will throw exception in following cases:, (*12)
- on Windowsvalidation does not work at all (due to the anonymous classes)
- on Linux- short enum definition (one that useseval()) does not work so the workaround is to manually instantiate elements
- on OSX- have to check but I'd assume same asLinux
For more details on what's wrong and why, feel free to check related issue., (*13)