Spaces:
No application file
No application file
| namespace Mautic\ConfigBundle\Event; | |
| use Mautic\CoreBundle\Event\CommonEvent; | |
| use Symfony\Component\HttpFoundation\File\UploadedFile; | |
| use Symfony\Component\HttpFoundation\ParameterBag; | |
| class ConfigEvent extends CommonEvent | |
| { | |
| /** | |
| * @var mixed[] | |
| */ | |
| private array $preserve = []; | |
| /** | |
| * @var mixed[] | |
| */ | |
| private array $errors = []; | |
| /** | |
| * @var mixed[] | |
| */ | |
| private array $fieldErrors = []; | |
| /** | |
| * Data got from build form before update. | |
| */ | |
| private ?array $originalNormData = null; | |
| /** | |
| * Data got from build form after update. | |
| * | |
| * @var array | |
| */ | |
| private $normData; | |
| /** | |
| * @param mixed[]|null $config | |
| */ | |
| public function __construct( | |
| private ?array $config, | |
| private ParameterBag $post | |
| ) { | |
| } | |
| /** | |
| * Returns the config array. | |
| * | |
| * @param string $key | |
| * | |
| * @return array | |
| */ | |
| public function getConfig($key = null) | |
| { | |
| if ($key) { | |
| return $this->config[$key] ?? []; | |
| } | |
| return $this->config; | |
| } | |
| /** | |
| * Sets the config array. | |
| * | |
| * @param string $key | |
| */ | |
| public function setConfig(array $config, $key = null): void | |
| { | |
| if ($key) { | |
| $this->config[$key] = $config; | |
| } else { | |
| $this->config = $config; | |
| } | |
| } | |
| public function getPost(): ParameterBag | |
| { | |
| return $this->post; | |
| } | |
| /** | |
| * Set fields such as passwords that will not overwrite existing values | |
| * if the current is empty. | |
| * | |
| * @param array|string $fields | |
| */ | |
| public function unsetIfEmpty($fields): void | |
| { | |
| if (!is_array($fields)) { | |
| $fields = [$fields]; | |
| } | |
| $this->preserve = array_merge($this->preserve, $fields); | |
| } | |
| /** | |
| * Return array of fields to unset if empty so that existing values are not | |
| * overwritten if empty. | |
| * | |
| * @return array | |
| */ | |
| public function getPreservedFields() | |
| { | |
| return $this->preserve; | |
| } | |
| /** | |
| * Set error message. | |
| * | |
| * @param string $message (untranslated) | |
| * @param array $messageVars for translation | |
| * @param string|null $key | |
| * @param string|null $field | |
| * | |
| * @return ConfigEvent | |
| */ | |
| public function setError($message, $messageVars = [], $key = null, $field = null) | |
| { | |
| if (!empty($key) && !empty($field)) { | |
| if (!isset($this->errors[$key])) { | |
| $this->fieldErrors[$key] = []; | |
| } | |
| $this->fieldErrors[$key][$field] = [ | |
| $message, | |
| $messageVars, | |
| ]; | |
| return $this; | |
| } | |
| $this->errors[$message] = $messageVars; | |
| return $this; | |
| } | |
| /** | |
| * Get error messages. | |
| * | |
| * @return array | |
| */ | |
| public function getErrors() | |
| { | |
| return $this->errors; | |
| } | |
| /** | |
| * @return array | |
| */ | |
| public function getFieldErrors() | |
| { | |
| return $this->fieldErrors; | |
| } | |
| public function getFileContent(UploadedFile $file): string | |
| { | |
| $tmpFile = $file->getRealPath(); | |
| $content = trim(file_get_contents($tmpFile)); | |
| @unlink($tmpFile); | |
| return $content; | |
| } | |
| public function encodeFileContents($content): string | |
| { | |
| return base64_encode($content); | |
| } | |
| /** | |
| * @return array | |
| */ | |
| public function getOriginalNormData() | |
| { | |
| return $this->originalNormData; | |
| } | |
| /** | |
| * @return ConfigEvent | |
| */ | |
| public function setOriginalNormData(array $normData) | |
| { | |
| $this->originalNormData = $normData; | |
| return $this; | |
| } | |
| /** | |
| * @return array | |
| */ | |
| public function getNormData() | |
| { | |
| return $this->normData; | |
| } | |
| /** | |
| * @param array $normData | |
| */ | |
| public function setNormData($normData): void | |
| { | |
| $this->normData = $normData; | |
| } | |
| } | |