Update Copywrite year to be 2019
[civicrm-core.git] / CRM / Admin / Form / Setting.php
CommitLineData
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 */
37class 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}