Search code examples
symfonypropel

Can't save Propel model to object in Symfony2 form


I'm trying to edit a user's roles with Propel in Symfony2. The form renders fine, the roles that the user currently has are checked correctly. But saving new roles doesn't work. I get an error: Property role_id does not exist in class Acme\SecurityBundle\Model\User.

[1] PropelException: Unable to execute DELETE statement [DELETE FROM `user_role` WHERE (user_role.user_id=:p1 AND user_role.role_id=:p2)] [wrapped: Notice: Array to string conversion in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php line 102]
    at n/a
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/util/BasePeer.php line 150

    at BasePeer::doDelete(object(UserRoleQuery), object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUserRolePeer.php line 1305

    at Acme\SecurityBundle\Model\om\BaseUserRolePeer::doDelete(object(UserRoleQuery), object(DebugPDO))
        in  line 

    at call_user_func(array('Acme\SecurityBundle\Model\UserRolePeer', 'doDelete'), object(UserRoleQuery), object(DebugPDO))
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/query/ModelCriteria.php line 1677

    at ModelCriteria->doDelete(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/query/ModelCriteria.php line 1655

    at ModelCriteria->delete(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUser.php line 1239

    at Acme\SecurityBundle\Model\om\BaseUser->doSave(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUser.php line 1170

    at Acme\SecurityBundle\Model\om\BaseUser->save()
        in /Users/Stan/Websites/MyProject/src/Acme/AdminBundle/Controller/UserManagementController.php line 20

    at Acme\AdminBundle\Controller\UserManagementController->indexAction(object(Request))
        in  line 

    at call_user_func_array(array(object(UserManagementController), 'indexAction'), array(object(Request)))
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2974

    at Symfony\Component\HttpKernel\HttpKernel->handleRaw(object(Request), '1')
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2936

    at Symfony\Component\HttpKernel\HttpKernel->handle(object(Request), '1', true)
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 3085

    at Symfony\Component\HttpKernel\DependencyInjection\ContainerAwareHttpKernel->handle(object(Request), '1', true)
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2335

    at Symfony\Component\HttpKernel\Kernel->handle(object(Request))
        in /Users/Stan/Websites/MyProject/app_dev.php line 17

    at include('/Users/Stan/Websites/MyProject/app_dev.php')
        in /Users/Stan/Websites/MyProject/web/app_dev.php line 5

[2] Symfony\Component\Debug\Exception\ContextErrorException: Notice: Array to string conversion in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php line 102
    at n/a
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php line 102

    at Symfony\Component\Debug\ErrorHandler->handle('8', 'Array to string conversion', '/Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php', '102', array('input_parameters' => null, 'debug' => array('microtime' => '1412844116.1', 'memory_get_usage' => '18895912', 'memory_get_peak_usage' => '19058688')))
        in  line 

    at PDOStatement->execute(null)
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php line 102

    at DebugPDOStatement->execute()
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/util/BasePeer.php line 146

    at BasePeer::doDelete(object(UserRoleQuery), object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUserRolePeer.php line 1305

    at Acme\SecurityBundle\Model\om\BaseUserRolePeer::doDelete(object(UserRoleQuery), object(DebugPDO))
        in  line 

    at call_user_func(array('Acme\SecurityBundle\Model\UserRolePeer', 'doDelete'), object(UserRoleQuery), object(DebugPDO))
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/query/ModelCriteria.php line 1677

    at ModelCriteria->doDelete(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/vendor/propel/propel1/runtime/lib/query/ModelCriteria.php line 1655

    at ModelCriteria->delete(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUser.php line 1239

    at Acme\SecurityBundle\Model\om\BaseUser->doSave(object(DebugPDO))
        in /Users/Stan/Websites/MyProject/src/Acme/SecurityBundle/Model/om/BaseUser.php line 1170

    at Acme\SecurityBundle\Model\om\BaseUser->save()
        in /Users/Stan/Websites/MyProject/src/Acme/AdminBundle/Controller/UserManagementController.php line 20

    at Acme\AdminBundle\Controller\UserManagementController->indexAction(object(Request))
        in  line 

    at call_user_func_array(array(object(UserManagementController), 'indexAction'), array(object(Request)))
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2974

    at Symfony\Component\HttpKernel\HttpKernel->handleRaw(object(Request), '1')
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2936

    at Symfony\Component\HttpKernel\HttpKernel->handle(object(Request), '1', true)
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 3085

    at Symfony\Component\HttpKernel\DependencyInjection\ContainerAwareHttpKernel->handle(object(Request), '1', true)
        in /Users/Stan/Websites/MyProject/app/bootstrap.php.cache line 2335

    at Symfony\Component\HttpKernel\Kernel->handle(object(Request))
        in /Users/Stan/Websites/MyProject/app_dev.php line 17

    at include('/Users/Stan/Websites/MyProject/app_dev.php')
        in /Users/Stan/Websites/MyProject/web/app_dev.php line 5

This is my schema:

<?xml version="1.0" encoding="UTF-8"?>
<database name="system" namespace="Acme\SecurityBundle\Model" defaultIdMethod="native">
    <table name="user">
        <column name="id" type="integer" required="true" primaryKey="true" autoIncrement="true" />
        <column name="username" required="true" type="varchar" primaryKey="true" size="50" />
    </table>

    <table name="role">
        <column name="id" type="integer" required="true" primaryKey="true" autoIncrement="true" />
        <column name="role" required="true" type="varchar" size="20" primaryString="true" />
        <column name="name" required="true" type="varchar" size="50" />

        <unique>
            <unique-column name="role" />
            <unique-column name="name" />
        </unique>
    </table>

    <table name="user_role" isCrossRef="true">
        <column name="user_id" type="integer" primaryKey="true"/>
        <column name="role_id" type="integer" primaryKey="true"/>
        <foreign-key foreignTable="user">
            <reference local="user_id" foreign="id"/>
        </foreign-key>
        <foreign-key foreignTable="role">
            <reference local="role_id" foreign="id"/>
        </foreign-key>
    </table>
</database>

This is how I render the form in the controller:

class UserManagementController extends Controller
{
    public function indexAction(Request $request)
    {
        $user = UserQuery::create()->filterById(2)->findOne();
        $form = $this->createForm(new UserType($user), $user);
        $form->handleRequest($request);

        if ($form->isValid())
        {
            $user->save();
        }

        return $this->render('AcmeAdminBundle:UserManagement:index.html.twig', array(
            'form' => $form->createView()
        ));
    }
}

And this is the UserType:

class UserType extends AbstractType
{
    private $user;

    public function __construct($user)
    {
        $this->user = $user;
    }

    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('roles', 'model', array(
                    'class' => 'Acme\SecurityBundle\Model\Role',
                    'multiple' => true,
                    'expanded' => true,
                    'property' => 'name',
                    'label' => $this->user->getUsername(),

                )
            )
            ->add('save', 'submit');
    }

    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
        $resolver->setDefaults(array(
                'data_class' => 'Acme\SecurityBundle\Model\User',
            ));
    }


    public function getName()
    {
        return 'user';
    }
}

Where does this error message come from and how can I solve it?


Solution

  • Thanks to the PropelBundle community I've finally figured it out: The two primary keys triggered this error. Now that I have only one primary key, it works flawlessly.