aboutcoders/enum-serializer-bundle
最新稳定版本:0.4.0
Composer 安装命令:
composer require aboutcoders/enum-serializer-bundle
包简介
A symfony bundle to serialize/deserialize enumerations of type myclabs/php-enum with jms/serializer
README 文档
README
A symfony bundle to serialize/deserialize enumerations of type myclabs/php-enum with jms/serializer.
Note: At this point json is the only supported format.
Installation
Add the AbcEnumSerializerBundle to your composer.json file:
php composer.phar require aboutcoders/enum-serializer-bundle
Include the bundle in the AppKernel.php class:
# app/AppKernel.php public function registerBundles() { $bundles = array( ... new Abc\Bundle\EnumSerializerBundle\AbcEnumSerializerBundle(), ); }
Usage
Define the enum as defined by myclabs/php-enum:
namespace Acme; use MyCLabs\Enum\Enum; class MyEnum { const VALUE_1; const VALUE_2; }
In order to serialize/deserialize the enumeration you can register the type in app/config.yml
# app/config/config.yml abc_enum_serializer: serializer: types: - Acme\MyEnum
or you can register the enum within the service container and tag it with with the tag abc.enum
services: my_enum: class: Acme\MyEnum tags: - { name: abc.enum }
Note, this service should be declared private and should never be instantiated, since this would lead to an exception. The only purpose of this service is to provide the fully qualified name of the class that needs to be registered as enum type.
Finally you can configure the type in case you use it as a member variable
use JMS\Serializer\Annotation\Type; class MyExample { /** * @Type("Acme\MyEnum") */ private $myEnum; }
or serialize/deserialize it directly referencing the type:
$serializer = $container->get('jms_serializer'); $data = $serializer->serialize($subject, 'json'); $enum = $this->serializer->deserialize($data, MyExample::class, 'json');
ToDo
- Add support for the formats XML and YAML
统计信息
- 总下载量: 26.61k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 4
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2016-05-15