Merge branch 'feature/regexp-split-13841'
This commit is contained in:
commit
59f19267c7
|
@ -0,0 +1,51 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Icinga\Module\Director\PropertyModifier;
|
||||||
|
|
||||||
|
use Icinga\Module\Director\Hook\PropertyModifierHook;
|
||||||
|
use Icinga\Module\Director\Web\Form\QuickForm;
|
||||||
|
|
||||||
|
class PropertyModifierRegexpSplit extends PropertyModifierHook
|
||||||
|
{
|
||||||
|
public static function addSettingsFormFields(QuickForm $form)
|
||||||
|
{
|
||||||
|
$form->addElement('text', 'pattern', array(
|
||||||
|
'label' => $form->translate('Pattern'),
|
||||||
|
'required' => true,
|
||||||
|
'description' => $form->translate(
|
||||||
|
'Regular expression pattern to split the string (e.g. /\s+/ or /[,;]/)'
|
||||||
|
)
|
||||||
|
));
|
||||||
|
|
||||||
|
$form->addElement('select', 'when_empty', array(
|
||||||
|
'label' => $form->translate('When empty'),
|
||||||
|
'required' => true,
|
||||||
|
'description' => $form->translate(
|
||||||
|
'What should happen when the given string is empty?'
|
||||||
|
),
|
||||||
|
'value' => 'empty_array',
|
||||||
|
'multiOptions' => $form->optionalEnum(array(
|
||||||
|
'empty_array' => $form->translate('return an empty array'),
|
||||||
|
'null' => $form->translate('return NULL'),
|
||||||
|
))
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function transform($value)
|
||||||
|
{
|
||||||
|
if (! strlen(trim($value))) {
|
||||||
|
if ($this->getSetting('when_empty', 'empty_array') === 'empty_array') {
|
||||||
|
return array();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return preg_split(
|
||||||
|
$this->getSetting('pattern'),
|
||||||
|
$value,
|
||||||
|
-1,
|
||||||
|
PREG_SPLIT_NO_EMPTY
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
1
run.php
1
run.php
|
@ -21,6 +21,7 @@ $this->provideHook('director/DataType', $prefix . 'DataType\\DataTypeString');
|
||||||
|
|
||||||
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierLowercase');
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierLowercase');
|
||||||
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierRegexReplace');
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierRegexReplace');
|
||||||
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierRegexSplit');
|
||||||
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierReplace');
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierReplace');
|
||||||
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierStripDomain');
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierStripDomain');
|
||||||
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierSubstring');
|
$this->provideHook('director/PropertyModifier', $prefix . 'PropertyModifier\\PropertyModifierSubstring');
|
||||||
|
|
Loading…
Reference in New Issue