CleverEzSettingsBundle is a modification of the MasevSettingsBundle for ezPlatform 2.x Link to MasevSettings : https://github.com/masev/MasevSettingsBundle/blob/master/README.md
CleverEzSettingsBundle introduce a settings system into eZ Platform 2.x All settings are injected in Symfony container as a parameter. There are compatible with the eZ Publish Config Resolver allowing you the define settings per siteaccess.
Add CleverEzSettingsBundle in your composer.json with the repository:
{
"require": {
"clever/settings-bundle": "dev-master"
},
"repositories": [
{
"type": "vcs",
"url": "https://github.com/cleverage/CleverEZSettingsBundle"
}
]
}
Now tell composer to download the bundle by running the command:
$ php composer.phar update clever/settings-bundle
Composer will install the bundle to your project's vendor/clever/settings-bundle
directory.
Enable the bundle in the kernel:
<?php
// app/AppKernel.php
public function registerBundles()
{
$bundles = array(
// ...
new Masev\SettingsBundle\MasevSettingsBundle(),
);
}
Add the bundle in your assetic configuration
# app/config/config.yml
assetic:
bundles: [ EzPlatformAdminUiBundle, MasevSettingsBundle ]
Add the routes in your routing base configuration
# app/config/routing.yml
piles_settings:
resource: "@MasevSettingsBundle/Resources/config/routing.yml"
prefix: /
Edit your application config file to provide connections informations to your storage and to list the bundle wich contains configurable parameters.
Mysql example :
# app/config/config.yml
masev_settings:
mysql:
host: 127.0.0.1
user: root
password: root
dbname: mysettings
varnish_purge:
enabled: true (to enable varnish purge)
purger_interface_id: 'ezplatform.http_cache.purge_client'
bundles: [ ... ]
form:
browse_limit: 500 (default 100) #change browse limit search
For Mysql Storage you need to initialize the setting table with the following query :
CREATE TABLE `masev_settings` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`identifier` varchar(255) NOT NULL DEFAULT '',
`value` TEXT NOT NULL,
`scope` varchar(255) NOT NULL DEFAULT 'default',
PRIMARY KEY (`id`),
UNIQUE KEY `identifier_scope` (`identifier`,`scope`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;
In your bundle, create a file name settings.xml in the folder <bundle_dir>/Resources/config/.
<?xml version="1.0" encoding="UTF-8" ?>
<settings xmlns="http://william-pottier.fr/schema/settings"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://william-pottier.fr/schema/settings https://raw.github.com/wpottier/WizadSettingsBundle/master/Resources/schema/settings-1.0.xsd">
<parameter key="category.sub_category.sender_name">
<name>Email sender name</name>
<default>Me</default>
</parameter>
<parameter key="category.sub_category.sender_email">
<name>Email sender address</name>
<default>[email protected]</default>
</parameter>
<parameter key="category.sub_category.message">
<name>Message</name>
<default></default>
<form type="textarea" cols="30" rows="10"></form>
</parameter>
</settings>
Settings key must have a category and sub_category name to be displayed correctly in the admin UI.
Clear the Symfony cache :
php bin/console cache:clear && php bin/console cache:warmup
At this step you should be able the define settings in the admin UI (configuration tab in the eZ Publish Legacy Administration).
Now that you have define settings you can query them with the eZ Publish config resolver.
// Get the 'category.sub_category.sender_name' settings in the current scope (i.e. current siteaccess)
$this->configResolver->getParameter('category.sub_category.sender_name', 'masev_settings');
// You can force siteaccess
$this->configResolver->getParameter('category.sub_category.sender_name', 'masev_settings', 'my_site_access');
In a twig template you can use the getMasevSettings() Twig function.