2017 © Pedro Peláez
 

symfony-bundle doctrine-set-type-bundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

image

okapon/doctrine-set-type-bundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  • Sunday, January 29, 2017
  • by okapon
  • Repository
  • 2 Watchers
  • 13 Stars
  • 85,000 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 6 Forks
  • 3 Open issues
  • 9 Versions
  • 4 % Grown

The README.md

DoctrineSetTypeBundle

The DoctrineSetTypeBundle provides support MySQL SET type for Doctrine2 in your Symfony2 or Symfony3 application., (*1)

Latest Stable Version Total Downloads Build Status Scrutinizer Code Quality Code Coverage, (*2)

License, (*3)

Features

  • SET type mapping for mysql
  • SET type validation
  • Doctrine migrations

Requirements

  • PHP ~5.5
  • Symfony ~2.6 or ~3.0
  • Doctrine ~2.3

Supported platforms

  • MySQL

Installation

Step 1: Download the Bundle

Using composer, (*4)

$ composer require okapon/doctrine-set-type-bundle "0.5.0"

Step 2: Enable the Bundle

Then, enable the bundle by adding the following line in the app/AppKernel.php file of your project:, (*5)

<?php
// app/AppKernel.php

// ...
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...

            new Okapon\DoctrineSetTypeBundle\OkaponDoctrineSetTypeBundle(),
        );

        // ...
    }

    // ...
}

Step 3: Enable the mapping_type

In order to use MySQL SET type, Add the following line in the app/config/confing.yml, (*6)

doctrine:
    dbal:
        mapping_types:
            set: string

Usage

Create your SET type class

Sample: UserGroupType class, (*7)

This class is Sample that user has multiple groups which is mysql set type., (*8)

Then, create UserGroupType and extend AbstractSetType., (*9)

<?php

namespace AppBundle\DBAL\Types;

use Okapon\DoctrineSetTypeBundle\DBAL\Types\AbstractSetType;

class UserGroupType extends AbstractSetType
{
    const GROUP1 = 'group1';
    const GROUP2 = 'group2';
    const GROUP3 = 'group3';

    /**
     * {@inheritdoc}
     */
     protected $name = 'UserGroupType'; // This is Optional. Automatically registered shord class name.

    /**
     * define your SET type.
     */
    protected static $choices = [
        self::GROUP1 => 'Group 1',
        self::GROUP2 => 'Group 2',
        self::GROUP3 => 'Group 3',
    ];
}

Or you may define set type definition in entity by overrideing AbstractSetType::getChoices() method., (*10)

class UserGroupType extends AbstractSetType
{
    public static function getChoices()
    {
        return User::getGroupChoices();
    }
}

class User
{
    public static function getGroupChoices()
    {
        return [
            self::GROUP1 => 'Group 1',
            self::GROUP2 => 'Group 2',
            self::GROUP3 => 'Group 3',
        ];
    }
}

Register your type

Register UserGroupType in config.yml, (*11)

doctrine:
    dbal:
        ## ...
        types:
            UserGroupType: AppBundle\DBAL\Types\UserGroupType

Add mapping data to entity

This is annotaion sample., (*12)

<?php

namespace AppBundle\Entity;

use Symfony\Component\Validator\Constraints as Assert;
use Doctrine\ORM\Mapping as ORM;
use Okapon\DoctrineSetTypeBundle\Validator\Constraints as DoctrineAssert;
use AppBundle\DBAL\Types\UserGroupType;

/**
 * User
 *
 * @ORM\Table(name="user")
 * @ORM\Entity
 */
class User
{
    /**
     * @var integer
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string
     *
     * @ORM\Column(name="username", type="string", length=50)
     */
    private $username;

    /**
     * @var array
     *
     * @DoctrineAssert\SetType(class="AppBundle\DBAL\Types\UserGroupType")
     * @ORM\Column(name="groups", type="UserGroupType", nullable=true) // mapping_type
     */
    private $groups;

    // ...

    /**
     * Set groups
     *
     * @param array $groups
     * @return User
     */
    public function setGroups(array $groups)
    {
        $this->groups = $groups;

        return $this;
    }

    /**
     * Get groups
     *
     * @return array
     */
    public function getGroups()
    {
        return $this->groups;
    }
}

You can set Groups with array to User entity, (*13)

$user->setGroups([UserGroupType::GROUP1, UserGroupType::GROUP2]);

And also You can validate your type by adding the following annotation., (*14)

    /**
     * @DoctrineAssert\SetType(class="AppBundle\DBAL\Types\UserGroupType")
     */
    private $groups;

Building the form

Pass null to the Second argument., (*15)

SetTypeGuesser extends ChoiseType and render the field as checkboxes., (*16)

So, you can use choice field type option. (see choice Field Type), (*17)

$builder->add('groups', null, [
    'required' => true,
    'invalid_message' => 'Given values are invalid!!'
]);

Doctrine migrations

Following SQL is executed., (*18)

CREATE TABLE user (
    id INT AUTO_INCREMENT NOT NULL,
    username varchar(50) COLLATE utf8_unicode_ci NOT NULL,
    groups set('group1','group2') DEFAULT NULL COMMENT '(DC2Type:UserGroupType)',
    PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB

The Versions

29/01 2017

dev-master

9999999-dev https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

29/01 2017

v0.5.0

0.5.0.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

13/10 2015

v0.4.0

0.4.0.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

13/10 2015

v0.3.1

0.3.1.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

28/04 2015

v0.3.0

0.3.0.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

26/04 2015

v0.2.0

0.2.0.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

26/04 2015

v0.1.2

0.1.2.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

05/01 2015

v0.1.1

0.1.1.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set

04/01 2015

v0.1.0

0.1.0.0 https://github.com/okapon/DoctrineSetTypeBundle

Provides support of MySQL SET type for Doctrine2 in Symfony2 applications.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Yuichi Okada

bundle doctrine symfony dbal mysql type set