Commit | Line | Data |
---|---|---|
6a488035 TO |
1 | <?php |
2 | /* | |
3 | +--------------------------------------------------------------------+ | |
fee14197 | 4 | | CiviCRM version 5 | |
6a488035 | 5 | +--------------------------------------------------------------------+ |
6b83d5bd | 6 | | Copyright CiviCRM LLC (c) 2004-2019 | |
6a488035 TO |
7 | +--------------------------------------------------------------------+ |
8 | | This file is a part of CiviCRM. | | |
9 | | | | |
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. | | |
13 | | | | |
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. | | |
18 | | | | |
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 | +--------------------------------------------------------------------+ | |
d25dd0ee | 26 | */ |
6a488035 TO |
27 | |
28 | /** | |
29 | * | |
30 | * @package CRM | |
6b83d5bd | 31 | * @copyright CiviCRM LLC (c) 2004-2019 |
6a488035 TO |
32 | */ |
33 | ||
34 | /** | |
ce064e4f | 35 | * This class generates form components generic to CiviCRM settings. |
6a488035 TO |
36 | */ |
37 | class CRM_Admin_Form_Setting extends CRM_Core_Form { | |
38 | ||
946389fb | 39 | use CRM_Admin_Form_SettingTrait; |
40 | ||
6a488035 TO |
41 | protected $_settings = array(); |
42 | ||
4dd431ca | 43 | protected $includesReadOnlyFields; |
44 | ||
6a488035 | 45 | /** |
c490a46a | 46 | * Set default values for the form. |
6a488035 | 47 | * |
ee0ce2ef | 48 | * Default values are retrieved from the database. |
6a488035 | 49 | */ |
00be9182 | 50 | public function setDefaultValues() { |
6a488035 TO |
51 | if (!$this->_defaults) { |
52 | $this->_defaults = array(); | |
353ffa53 TO |
53 | $formArray = array('Component', 'Localization'); |
54 | $formMode = FALSE; | |
6a488035 TO |
55 | if (in_array($this->_name, $formArray)) { |
56 | $formMode = TRUE; | |
57 | } | |
58 | ||
601361a3 | 59 | $this->setDefaultsForMetadataDefinedFields(); |
6a488035 | 60 | |
ec3cc27f | 61 | // @todo these should be retrievable from the above function. |
aaffa79f | 62 | $this->_defaults['enableSSL'] = Civi::settings()->get('enableSSL'); |
63 | $this->_defaults['verifySSL'] = Civi::settings()->get('verifySSL'); | |
f008885c | 64 | $this->_defaults['environment'] = CRM_Core_Config::environment(); |
f4fb2d79 | 65 | $this->_defaults['enableComponents'] = Civi::settings()->get('enable_components'); |
6a488035 TO |
66 | } |
67 | ||
68 | return $this->_defaults; | |
69 | } | |
70 | ||
71 | /** | |
567b2076 | 72 | * Build the form object. |
6a488035 TO |
73 | */ |
74 | public function buildQuickForm() { | |
089360bb | 75 | CRM_Core_Session::singleton()->pushUserContext(CRM_Utils_System::url('civicrm/admin', 'reset=1')); |
6a488035 TO |
76 | $this->addButtons(array( |
77 | array( | |
78 | 'type' => 'next', | |
79 | 'name' => ts('Save'), | |
80 | 'isDefault' => TRUE, | |
81 | ), | |
82 | array( | |
83 | 'type' => 'cancel', | |
84 | 'name' => ts('Cancel'), | |
85 | ), | |
86 | ) | |
87 | ); | |
88 | ||
e894ae15 | 89 | $this->addFieldsDefinedInSettingsMetadata(); |
4dd431ca | 90 | |
91 | if ($this->includesReadOnlyFields) { | |
92 | CRM_Core_Session::setStatus(ts("Some fields are loaded as 'readonly' as they have been set (overridden) in civicrm.settings.php."), '', 'info', array('expires' => 0)); | |
93 | } | |
6a488035 TO |
94 | } |
95 | ||
96 | /** | |
ee0ce2ef | 97 | * Process the form submission. |
6a488035 TO |
98 | */ |
99 | public function postProcess() { | |
100 | // store the submitted values in an array | |
101 | $params = $this->controller->exportValues($this->_name); | |
102 | ||
103 | self::commonProcess($params); | |
104 | } | |
105 | ||
e0ef6999 | 106 | /** |
5c9ff055 EM |
107 | * Common Process. |
108 | * | |
109 | * @todo Document what I do. | |
110 | * | |
c490a46a | 111 | * @param array $params |
946389fb | 112 | * @throws \CRM_Core_Exception |
e0ef6999 | 113 | */ |
6a488035 TO |
114 | public function commonProcess(&$params) { |
115 | ||
2efcf0c2 | 116 | // save components to be enabled |
9dda9790 | 117 | if (array_key_exists('enableComponents', $params)) { |
c8074a93 TO |
118 | civicrm_api3('setting', 'create', array( |
119 | 'enable_components' => $params['enableComponents'], | |
120 | )); | |
121 | unset($params['enableComponents']); | |
3124edb3 DS |
122 | } |
123 | ||
5e7f101a | 124 | foreach (array('verifySSL', 'enableSSL') as $name) { |
125 | if (isset($params[$name])) { | |
126 | Civi::settings()->set($name, $params[$name]); | |
127 | unset($params[$name]); | |
128 | } | |
6a488035 | 129 | } |
946389fb | 130 | try { |
131 | $settings = $this->getSettingsToSetByMetadata($params); | |
6821aa1d | 132 | $this->saveMetadataDefinedSettings($params); |
6a488035 | 133 | } |
946389fb | 134 | catch (CiviCRM_API3_Exception $e) { |
135 | CRM_Core_Session::setStatus($e->getMessage(), ts('Save Failed'), 'error'); | |
af962699 TO |
136 | } |
137 | ||
946389fb | 138 | $this->filterParamsSetByMetadata($params); |
139 | ||
7e0c769c TO |
140 | $params = CRM_Core_BAO_ConfigSetting::filterSkipVars($params); |
141 | if (!empty($params)) { | |
946389fb | 142 | throw new CRM_Core_Exception('Unrecognized setting. This may be a config field which has not been properly migrated to a setting. (' . implode(', ', array_keys($params)) . ')'); |
7e0c769c | 143 | } |
b08fb110 CW |
144 | |
145 | CRM_Core_Config::clearDBCache(); | |
0a12cd4a | 146 | Civi::cache('session')->clear(); // This doesn't make a lot of sense to me, but it maintains pre-existing behavior. |
b08fb110 CW |
147 | CRM_Utils_System::flushCache(); |
148 | CRM_Core_Resources::singleton()->resetCacheCode(); | |
149 | ||
4481526f | 150 | CRM_Core_Session::setStatus(" ", ts('Changes Saved'), "success"); |
6a488035 TO |
151 | } |
152 | ||
153 | public function rebuildMenu() { | |
154 | // ensure config is set with new values | |
155 | $config = CRM_Core_Config::singleton(TRUE, TRUE); | |
156 | ||
157 | // rebuild menu items | |
158 | CRM_Core_Menu::store(); | |
159 | ||
160 | // also delete the IDS file so we can write a new correct one on next load | |
161 | $configFile = $config->uploadDir . 'Config.IDS.ini'; | |
162 | @unlink($configFile); | |
163 | } | |
96025800 | 164 | |
6a488035 | 165 | } |