The AlpixelUserBundle is an integration of FOSUserBundle + Sonata admin for ALPIXEL projects.
It comes bundled with 2 main entity :
- An abstract BaseUser which should be used to create your main user entity in the project
- An admin entity extending the BaseUser to create administrator
- Fixtures for the admin entity
- Install the package
composer require 'alpixel/userbundle:~2.0'
- Update AppKernel.php
<?php
// app/AppKernel.php
// ...
class AppKernel extends Kernel
{
public function registerBundles()
{
$bundles = array(
// ...
new Alpixel\Bundle\UserBundle\AlpixelUserBundle(),
);
// ...
}
// ...
}
- Update DB Schema
php app/console doctrine:schema:update
- Create a User entity in your AppBundle extending the BaseUser
<?php
namespace AppBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Alpixel\Bundle\UserBundle\Entity\User as BaseUser;
/**
* @ORM\Entity
* @ORM\Table(name="account_user")
*/
class User extends BaseUser
{
/**
* @var integer
*
* @ORM\Column(name="user_id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
}
- Add the routing
admin:
resource: '@AlpixelUserBundle/Resources/config/routing.yml'
- Change security.yml (optionnal)
If you have more than an admin firewall, you should copy the security.yml of the bundle and paste it in your main security.yml to edit it.
- Customize login page
For every firewall you have to specify a template for the login page. The admin login template is always provided. Otherwise, it should be defined using the alpixel_user.firewall_templates parameters :
alpixel_user:
firewall_templates:
admin:
login_template: 'AlpixelUserBundle:admin:pages/back_login.html.twig'
You can also simply change the color and the background image of the admin page by overriding these parameters
alpixel_user:
default_login_background_image: '../../bundles/alpixeluser/img/background.jpg'
default_login_background_color: '#ff656c'