Tag Archives: Symfony2

Symfony2 – “id” returned as member variable from __sleep() but does not exist

When storing entity objects in the http session, you might run into following exception :

ErrorException: Notice: serialize() [function.serialize]: “id” returned as member variable from __sleep() but does not exist in…

Now, apparently php has some problems serializing an object which subclasses an object with private properties. As Doctrine always creates subclasses of your entity classes (which are called Proxy classes), this means you should never use private properties (e.g. $id or any other property) on your entity (or associated entities) ! Use protected instead.

Custom validation messages for standard validators in Symfony2

Symfony2 contains a lot of validators out of the box, but it is not very clearly documented how to use custom messages when validation fails for these standard validators. After some investigation, I found the validation messages in Symfony/vendor/symfony/src/Symfony/Bundle/FrameworkBundle/Resources/translations/. It is very easy to override a message. Just look up the message you wish to modify (e.g. ‘This value should not be blank’), create your own validators.[language].yml file (or .xliff if you prefer) in your bundle, and add this message as a key with your custom message as value :

# validators.en.yml

This value should not be blank: This is a required field

That’s all :)

Using Zend with Symfony2

I recently needed to use the Zend GData component in my Symfony2 project. It is very easy to setup, but there is one mistake that I suspect some other people might make as well.

First, add the Zend library to your vendor folder (e.g. vendor/Zend/library/Zend). As Zend does not use namespaces, you need to register the ‘Zend’ prefix instead. This can be done in the autoload.php file located in your app folder. Apparently Zend has some problems this way with ‘require_once’ statements, hence the modification of the include path (last line) :

// autoload.php

use Symfony\Component\ClassLoader\UniversalClassLoader;

// ... existing code

$loader->registerPrefixes(array(
    'Twig_Extensions_' => __DIR__.'/../vendor/twig-extensions/lib',
    'Twig_'            => __DIR__.'/../vendor/twig/lib',
    'Swift_'           => __DIR__.'/../vendor/swiftmailer/lib/classes',
    'Zend_'           => __DIR__.'/../vendor/Zend/library',
));

$loader->register();
$loader->registerPrefixFallback(array(
    __DIR__.'/../vendor/symfony/src/Symfony/Component/Locale/Resources/stubs',
));
set_include_path(__DIR__.'/../vendor/Zend/library'.PATH_SEPARATOR.get_include_path());

Now you are ready to use the Zend components. One mistake I made, I used the classes without a leading backslash, which does not work because the classes are in de default namespace. So, instead of using e.g.

$gdataCal = new Zend_Gdata_Calendar($client); // class not found error will be thrown

you need to add a backslash as such :

$gdataCal = new \Zend_Gdata_Calendar($client); // class is located in default namespace

Symfony2 validation using annotations

The Symfony2 book says that validation using annotations should be done as follows :

// Acme/BlogBundle/Author.php
use Symfony\Component\Validator\Constraints as Assert;

class Author
{
    /**
     * @Assert\NotBlank()
     */
    public $name;
}

I tried this on my installation, but this doesn’t work. I had to change ‘@Assert\’ into ‘@assert:’ to make it work :

// Acme/BlogBundle/Author.php

class Author
{
    /**
     * @assert:NotBlank()
     */
    public $name;
}

Read more »

Symfony2 and required fields

I just came across my first HTML5 ‘issue’. I was testing the Symfony2 forms, and for required fields I always got the message ‘Please fill out this field.’ which was shown in a tooltip. I started looking in the Symfony2 code where this message came from, but I couldn’t find it anywhere. So I started inspecting the generated html, and I saw the ‘required’ attribute on the input fields. Apparently this is a new attribute in HTML5, and most browers already support it. I now realise that HTML5 really is something I should learn more about…

While looking for some more info, I came across an online book that seems very interesting : http://diveintohtml5.org. Definitly on my todo list now :)

My first experience with Symfony2

After trying the Symfony2 framework for some days, setting up a little project with security, ORM and routing, I have found some things in the manual that were not entirely clear (or sometimes just wrong, I think). Of course it is still in beta, so I’m not blaming anyone but myself… And don’t get me wrong, I will continue using Symfony2 as it is very easy and clear to use.

Translations

Translations don’t seem to work outside bundles. I tried creating a translation file in the app/Resources/translations folder, but Symfony2 doesn’t seem to pick it up. It does work inside bundles, so this is not really a problem for me. Don’t know of it is intended behavior either.
Read more »

Installing the INTL extension on MAMP

I just started developing in Symfony2, and the installation told me I should install the Intl extension (intl.so) for internationalization. Although Symfony2 works without the extension, I suspect I will run into problems sooner or later, e.g. when using the translation service. So after trying some different ways to compile and install the extension, I finally found that it is fairly easy using Macports.
Read more »