micayael / parameterizer-client-bundle
Parameterizer 客户端
1.0.2
2018-07-03 14:39 UTC
Requires
- doctrine/doctrine-cache-bundle: ^1.3
- guzzlehttp/guzzle: ^6.3
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.10
This package is auto-updated.
Last update: 2024-09-29 04:37:14 UTC
README
安装 bundle
安装
composer require micayael/parameterizer-client-bundle:1.0.*
在 AppKernel.php 中激活 bundle
$bundles = [
...
new Micayael\Parameterizer\ClientBundle\ParameterizerClientBundle(),
...
];
配置 Guzzle 以查询 authenticator 服务
parameterizer_client:
host: https://:8000 # host de la aplicación parameterizer
username: user # usuario de acceso
password: pass # clave de acceso
agrupado: true # true|false (opcional, default: true)
"分组" 选项指示服务是否按域名返回分组参数
在控制器中使用它
执行 bin/console cache:clear 后,可以使用以下服务获取参数
# Para obtener todos los parámetros de la aplicación como un array
$this->get('parameterizer_client.cache')->getAll()
# Para obtener todos los parámetros de un dominio específico como un array
$this->get('parameterizer_client.cache')->get($dominio);
# Para obtener un parámetro específico
$this->get('parameterizer_client.cache')->get($dominio, $codigo);
在 twig 中使用它
# Para obtener todos los parámetros de la aplicación como un array
{% dump(get_params()) %}
# Para obtener todos los parámetros de un dominio específico como un array
{% dump(get_params(dominio)) %}
# Para obtener un parámetro específico
{% dump(get_param(dominio, codigo)) %}
在表单中使用它
可以从控制器中通过表单的 options 传递参数
$form = $this->createForm('AppBundle\Form\BuscadorType', null, ['parametros' => $this->get('parameterizer_client.cache')->getAll()]);
必须配置表单以接收此新选项
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setRequired('parametros');
}
在 buildForm 方法中接收选项作为参数
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('estado', ChoiceType::class, [
'placeholder' => 'Seleccione una opción',
'empty_data' => null,
'choices' => array_flip($options['parametros'][$dominio]),
])
}