_subForms) as $name) { // Zend returns values from subforms grouped by their names, but we want them flat $values = array_merge($values, $values[$name]); unset($values[$name]); } return $values; } /** * Set the configuration to use when populating the form or when saving the user's input * * @param Config $config The configuration to use * * @return $this */ public function setIniConfig(Config $config) { $this->config = $config; return $this; } /** * {@inheritdoc} */ public function onSuccess() { $sections = array(); foreach ($this->getValues() as $sectionAndPropertyName => $value) { if ($value === '' || $value === false || $value === []) { $value = null; // Causes the config writer to unset it } list($section, $property) = explode('_', $sectionAndPropertyName, 2); $sections[$section][$property] = $value; } foreach ($sections as $section => $config) { $this->config->setSection($section, $config); } if ($this->save()) { Notification::success($this->translate('New configuration has successfully been stored')); } else { return false; } } /** * {@inheritdoc} */ public function onRequest() { $values = array(); foreach ($this->config as $section => $properties) { foreach ($properties as $name => $value) { $values[$section . '_' . $name] = $value; } } $this->populate($values); } /** * Persist the current configuration to disk * * If an error occurs the user is shown a view describing the issue and displaying the raw INI configuration. * * @return bool Whether the configuration could be persisted */ public function save() { try { $this->writeConfig($this->config); } catch (Exception $e) { $this->addDecorator('ViewScript', array( 'viewModule' => 'default', 'viewScript' => 'showConfiguration.phtml', 'errorMessage' => $e->getMessage(), 'configString' => $this->config, 'filePath' => $this->config->getConfigFile(), 'placement' => Zend_Form_Decorator_Abstract::PREPEND )); return false; } return true; } /** * Write the configuration to disk * * @param Config $config */ protected function writeConfig(Config $config) { $config->saveIni(); } /** * Transform all empty values of the given array to null * * @param array $values * * @return array */ public static function transformEmptyValuesToNull(array $values) { return array_map(function ($v) { return ($v === '' || $v === false || $v === []) ? null : $v; }, $values); } }