3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2017 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2017
35 * This class generates form components generic to CiviCRM settings.
37 class CRM_Admin_Form_Setting
extends CRM_Core_Form
{
39 protected $_settings = array();
42 * Set default values for the form.
44 * Default values are retrieved from the database.
46 public function setDefaultValues() {
47 if (!$this->_defaults
) {
48 $this->_defaults
= array();
49 $formArray = array('Component', 'Localization');
51 if (in_array($this->_name
, $formArray)) {
55 CRM_Core_BAO_ConfigSetting
::retrieve($this->_defaults
);
57 // we can handle all the ones defined in the metadata here. Others to be converted
58 foreach ($this->_settings
as $setting => $group) {
59 $this->_defaults
[$setting] = civicrm_api('setting', 'getvalue', array(
67 $this->_defaults
['contact_autocomplete_options'] = self
::getAutocompleteContactSearch();
68 $this->_defaults
['contact_reference_options'] = self
::getAutocompleteContactReference();
69 $this->_defaults
['enableSSL'] = Civi
::settings()->get('enableSSL');
70 $this->_defaults
['verifySSL'] = Civi
::settings()->get('verifySSL');
71 $this->_defaults
['environment'] = CRM_Core_Config
::environment();
72 $this->_defaults
['enableComponents'] = Civi
::settings()->get('enable_components');
75 return $this->_defaults
;
79 * Build the form object.
81 public function buildQuickForm() {
82 CRM_Core_Session
::singleton()->pushUserContext(CRM_Utils_System
::url('civicrm/admin', 'reset=1'));
83 $this->addButtons(array(
91 'name' => ts('Cancel'),
96 $descriptions = array();
97 $settingMetaData = $this->getSettingsMetaData();
98 foreach ($settingMetaData as $setting => $props) {
99 if (isset($props['quick_form_type'])) {
100 if (isset($props['pseudoconstant'])) {
101 if (array_key_exists('optionGroupName', $props['pseudoconstant'])) {
102 $optionValues = civicrm_api3('OptionValue', 'get', array(
103 'return' => array("label", "value"),
104 'option_group_id' => $setting,
106 if ($optionValues['count'] > 0) {
107 foreach ($optionValues['values'] as $key => $values) {
108 $vals[$values['value']] = $values['label'];
110 $options['values'] = $vals;
114 $options = civicrm_api3('Setting', 'getoptions', array(
123 $add = 'add' . $props['quick_form_type'];
124 if ($add == 'addElement') {
129 ($options !== NULL) ?
$options['values'] : CRM_Utils_Array
::value('html_attributes', $props, array()),
130 ($options !== NULL) ? CRM_Utils_Array
::value('html_attributes', $props, array()) : NULL
133 elseif ($add == 'addSelect') {
134 $element = $this->addElement('select', $setting, ts($props['title']), $options['values'], CRM_Utils_Array
::value('html_attributes', $props));
135 if (defined('CIVICRM_ENVIRONMENT')) {
137 CRM_Core_Session
::setStatus(ts('The environment settings have been disabled because it has been overridden in the settings file.'), ts('Environment settings'), 'info');
140 elseif ($add == 'addCheckBox') {
141 $this->addCheckBox($setting, ts($props['title']), $options['values'], NULL, CRM_Utils_Array
::value('html_attributes', $props), NULL, NULL, array(' '));
143 elseif ($add == 'addChainSelect') {
144 $this->addChainSelect($setting, array(
145 'label' => ts($props['title']),
148 elseif ($add == 'addMonthDay') {
149 $this->add('date', $setting, ts($props['title']), CRM_Core_SelectValues
::date(NULL, 'M d'));
152 $this->$add($setting, ts($props['title']));
154 // Migrate to using an array as easier in smart...
155 $descriptions[$setting] = ts($props['description']);
156 $this->assign("{$setting}_description", ts($props['description']));
157 if ($setting == 'max_attachments') {
158 //temp hack @todo fix to get from metadata
159 $this->addRule('max_attachments', ts('Value should be a positive number'), 'positiveInteger');
161 if ($setting == 'maxFileSize') {
163 $this->addRule('maxFileSize', ts('Value should be a positive number'), 'positiveInteger');
168 // setting_description should be deprecated - see Mail.tpl for metadata based tpl.
169 $this->assign('setting_descriptions', $descriptions);
170 $this->assign('settings_fields', $settingMetaData);
174 * Get default entity.
178 public function getDefaultEntity() {
183 * Process the form submission.
185 public function postProcess() {
186 // store the submitted values in an array
187 $params = $this->controller
->exportValues($this->_name
);
189 self
::commonProcess($params);
195 * @todo Document what I do.
197 * @param array $params
199 public function commonProcess(&$params) {
201 // save autocomplete search options
202 if (!empty($params['contact_autocomplete_options'])) {
203 Civi
::settings()->set('contact_autocomplete_options',
204 CRM_Utils_Array
::implodePadded(array_keys($params['contact_autocomplete_options'])));
205 unset($params['contact_autocomplete_options']);
208 // save autocomplete contact reference options
209 if (!empty($params['contact_reference_options'])) {
210 Civi
::settings()->set('contact_reference_options',
211 CRM_Utils_Array
::implodePadded(array_keys($params['contact_reference_options'])));
212 unset($params['contact_reference_options']);
215 // save components to be enabled
216 if (array_key_exists('enableComponents', $params)) {
217 civicrm_api3('setting', 'create', array(
218 'enable_components' => $params['enableComponents'],
220 unset($params['enableComponents']);
223 foreach (array('verifySSL', 'enableSSL') as $name) {
224 if (isset($params[$name])) {
225 Civi
::settings()->set($name, $params[$name]);
226 unset($params[$name]);
229 $settings = array_intersect_key($params, $this->_settings
);
230 $result = civicrm_api('setting', 'create', $settings +
array('version' => 3));
231 foreach ($settings as $setting => $settingGroup) {
232 //@todo array_diff this
233 unset($params[$setting]);
235 if (!empty($result['error_message'])) {
236 CRM_Core_Session
::setStatus($result['error_message'], ts('Save Failed'), 'error');
239 //CRM_Core_BAO_ConfigSetting::create($params);
240 $params = CRM_Core_BAO_ConfigSetting
::filterSkipVars($params);
241 if (!empty($params)) {
242 CRM_Core_Error
::fatal('Unrecognized setting. This may be a config field which has not been properly migrated to a setting. (' . implode(', ', array_keys($params)) . ')');
245 CRM_Core_Config
::clearDBCache();
246 CRM_Utils_System
::flushCache();
247 CRM_Core_Resources
::singleton()->resetCacheCode();
249 CRM_Core_Session
::setStatus(" ", ts('Changes Saved'), "success");
252 public function rebuildMenu() {
253 // ensure config is set with new values
254 $config = CRM_Core_Config
::singleton(TRUE, TRUE);
256 // rebuild menu items
257 CRM_Core_Menu
::store();
259 // also delete the IDS file so we can write a new correct one on next load
260 $configFile = $config->uploadDir
. 'Config.IDS.ini';
261 @unlink
($configFile);
265 * Ugh, this shouldn't exist.
267 * Get the selected values of "contact_reference_options" formatted for checkboxes.
271 public static function getAutocompleteContactReference() {
272 $cRlist = array_flip(CRM_Core_OptionGroup
::values('contact_reference_options',
273 FALSE, FALSE, TRUE, NULL, 'name'
275 $cRlistEnabled = CRM_Core_BAO_Setting
::valueOptions(CRM_Core_BAO_Setting
::SYSTEM_PREFERENCES_NAME
,
276 'contact_reference_options'
278 $cRSearchFields = array();
279 if (!empty($cRlist) && !empty($cRlistEnabled)) {
280 $cRSearchFields = array_combine($cRlist, $cRlistEnabled);
288 * Ugh, this shouldn't exist.
290 * Get the selected values of "contact_autocomplete_options" formatted for checkboxes.
294 public static function getAutocompleteContactSearch() {
295 $list = array_flip(CRM_Core_OptionGroup
::values('contact_autocomplete_options',
296 FALSE, FALSE, TRUE, NULL, 'name'
298 $listEnabled = CRM_Core_BAO_Setting
::valueOptions(CRM_Core_BAO_Setting
::SYSTEM_PREFERENCES_NAME
,
299 'contact_autocomplete_options'
301 $autoSearchFields = array();
302 if (!empty($list) && !empty($listEnabled)) {
303 $autoSearchFields = array_combine($list, $listEnabled);
305 //Set defaults for autocomplete and contact reference options
308 ) +
$autoSearchFields;
312 * Get the metadata relating to the settings on the form, ordered by the keys in $this->_settings.
316 protected function getSettingsMetaData() {
317 $allSettingMetaData = civicrm_api3('setting', 'getfields', array());
318 $settingMetaData = array_intersect_key($allSettingMetaData['values'], $this->_settings
);
319 // This array_merge re-orders to the key order of $this->_settings.
320 $settingMetaData = array_merge($this->_settings
, $settingMetaData);
321 return $settingMetaData;