From 12348253fb7b97831bbdd047b02aff17d7612790 Mon Sep 17 00:00:00 2001 From: Marcel Werk Date: Wed, 8 May 2013 17:00:27 +0200 Subject: [PATCH] Added content pattern --- .../system/option/TextOptionType.class.php | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/wcfsetup/install/files/lib/system/option/TextOptionType.class.php b/wcfsetup/install/files/lib/system/option/TextOptionType.class.php index faff47c82f..39520387e3 100644 --- a/wcfsetup/install/files/lib/system/option/TextOptionType.class.php +++ b/wcfsetup/install/files/lib/system/option/TextOptionType.class.php @@ -64,6 +64,8 @@ class TextOptionType extends AbstractOptionType implements ISearchableUserOption * @see wcf\system\option\IOptionType::validate() */ public function validate(Option $option, $newValue) { + $newValue = $this->getContent($option, $newValue); + if ($option->minlength !== null && $option->minlength > StringUtil::length($newValue)) { throw new UserInputException($option->optionName, 'tooShort'); } @@ -71,4 +73,29 @@ class TextOptionType extends AbstractOptionType implements ISearchableUserOption throw new UserInputException($option->optionName, 'tooLong'); } } + + /** + * @see wcf\system\option\IOptionType::getData() + */ + public function getData(Option $option, $newValue) { + return $this->getContent($option, $newValue); + } + + /** + * Tries to extract content from value. + * + * @param wcf\data\option\Option $option + * @param string $newValue + * @return string + */ + protected function getContent(Option $option, $newValue) { + if ($option->contentpattern) { + if (preg_match('~'.$option->contentpattern.'~', $newValue, $matches)) { + unset($matches[0]); + $newValue = implode('', $matches); + } + } + + return $newValue; + } } -- 2.20.1