This plugin offer tools to adapt your plugins to Sylius Plus RBAC system.
Sylius Version | PHP Version |
---|---|
1.12 | 8.1 - 8.2 - 8.3 |
1.13 | 8.1 - 8.2 - 8.3 |
1.14 | 8.1 - 8.2 - 8.3 |
composer config --no-plugins --json extra.symfony.endpoint '["https://api.github.com/repos/monsieurbiz/symfony-recipes/contents/index.json?ref=flex/master","flex://defaults"]'
composer require monsieurbiz/sylius-plus-adapter-plugin
To illustrate the following examples, we will use a Foo
plugin with a MyResource
resource.
Your resource entity
namespace Foo\SyliusBarPlugin\Entity;
use Sylius\Component\Channel\Model\ChannelsAwareInterface;
use Sylius\Component\Resource\Model\ResourceInterface;
class MyResource implements ResourceInterface, ChannelsAwareInterface
{
// ...
}
Your resource config
sylius_resource:
resources:
foo_bar.my_resource:
classes:
model: Foo\SyliusBarPlugin\Entity\MyResource
It's a Sylius native feature, you don't have to install this plugin!
You just have to add permission: true
on your route definition.
If you do this, your route will become available on the permission tree.
foo_bar_my_resource_admin:
resource: |
alias: foo_bar.my_resource
section: admin
permission: true
templates: "@SyliusAdmin\\Crud"
redirect: update
grid: foo_bar_my_resource
type: sylius.resource
If you want to add channel restrictions on your channel related resources, you have to following theses 2 steps:
- Your resource (entity) need to implement
\Sylius\Component\Channel\Model\ChannelAwareInterface
or\Sylius\Component\Channel\Model\ChannelsAwareInterface
. - You need to include the
\MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait
trait in your bundle extension class and call theprependRestrictedResources
method in theprepend
method.
Your plugin extension file
namespace Foo\SyliusBarPlugin\DependencyInjection;
use MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Extension\Extension;
use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface;
class FooSyliusBarPluginExtension extends Extension implements PrependExtensionInterface
{
use SyliusPlusCompatibilityTrait;
public function prepend(ContainerBuilder $container): void
{
$this->prependRestrictedResources($container, ['my_resource']);
}
}
To filter the resource grid with channel restriction, you need to include the \MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait
trait in your bundle extension class and call the replaceInGridOriginalQueryBuilderWithChannelRestrictedQueryBuilder
method in the prepend
method.
The goal of this is to replace the original query builder of the grid with a new one that call the original one but will filter the resources with the current channel if needed.
Configuring this is tricky so follow the example below.
Your current resource grid config
sylius_grid:
grids:
foo_bar_my_resource:
driver:
name: doctrine/orm
options:
class: '%foo.model.my_resource.class%'
repository:
method: createListQueryBuilder
arguments: ["%locale%"]
# ...
Your plugin extension file
namespace Foo\SyliusBarPlugin\DependencyInjection;
use MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Extension\Extension;
use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface;
class FooSyliusBarPluginExtension extends Extension implements PrependExtensionInterface
{
use SyliusPlusCompatibilityTrait;
public function prepend(ContainerBuilder $container): void
{
$this->replaceInGridOriginalQueryBuilderWithChannelRestrictedQueryBuilder(
$container,
'foo_bar_my_resource', // This is the grid name
'%foo_bar.model.my_resource.class%', // This is the resource class as in your original grid
"expr:service('foo_bar.repository.my_resource').createListQueryBuilder('%locale%')" // This is the original query builder but called as an expression
);
}
}
To filter the channel choice type with channel restriction, you need to include the \MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait
and call the enabledFilteredChannelChoiceType
method in the load
method.
Your current resource form type
namespace Foo\SyliusBarPlugin\Form\Type;
use Sylius\Bundle\ChannelBundle\Form\Type\ChannelChoiceType;
use Sylius\Bundle\ResourceBundle\Form\Type\AbstractResourceType;
use Symfony\Component\Form\FormBuilderInterface;
class MyResourceType extends AbstractResourceType
{
/**
* @inheritdoc
*/
public function buildForm(FormBuilderInterface $builder, array $options): void
{
$builder
->add('channels', ChannelChoiceType::class, [
'label' => 'fo_bar_my_resource.ui.form.channels',
'required' => false,
'multiple' => true,
'expanded' => true,
])
// ...
;
}
Your plugin extension file
namespace Foo\SyliusBarPlugin\DependencyInjection;
use Foo\SyliusBarPlugin\Form\Type\MyResourceType;
use MonsieurBiz\SyliusPlusAdapterPlugin\DependencyInjection\SyliusPlusCompatibilityTrait;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Extension\Extension;
use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface;
class FooSyliusBarPluginExtension extends Extension implements PrependExtensionInterface
{
use SyliusPlusCompatibilityTrait;
public function load(array $config, ContainerBuilder $container): void
{
// Loading your plugin configuration ...
$this->enabledFilteredChannelChoiceType($container, ['my_resource' => MyResourceType::class]);
}
}
Because this plugin is a kind of sidekick for your plugins, it's not intended to be used in a standalone project.
Even more because it requires Sylius Plus to be useful. Our traditional test application then seems useless.
But to be fair, we still added a test app with our CMS plugin installed and configured to use the SyliusPlusCompatibilityTrait
trait.
It would be useful to be sure that everything is working as expected in a normal Sylius even if this plugin is installed and used.
This plugin is under the MIT license. Please see the LICENSE file for more information.