config.class.inc.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501
  1. <?php
  2. // Copyright (C) 2010 Combodo SARL
  3. //
  4. // This program is free software; you can redistribute it and/or modify
  5. // it under the terms of the GNU General Public License as published by
  6. // the Free Software Foundation; version 3 of the License.
  7. //
  8. // This program is distributed in the hope that it will be useful,
  9. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. // GNU General Public License for more details.
  12. //
  13. // You should have received a copy of the GNU General Public License
  14. // along with this program; if not, write to the Free Software
  15. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  16. /**
  17. * Configuration read/write
  18. *
  19. * @author Erwan Taloc <erwan.taloc@combodo.com>
  20. * @author Romain Quetiez <romain.quetiez@combodo.com>
  21. * @author Denis Flaven <denis.flaven@combodo.com>
  22. * @license http://www.opensource.org/licenses/gpl-3.0.html LGPL
  23. */
  24. require_once('coreexception.class.inc.php');
  25. class ConfigException extends CoreException
  26. {
  27. }
  28. define ('DEFAULT_LOG_GLOBAL', true);
  29. define ('DEFAULT_LOG_NOTIFICATION', true);
  30. define ('DEFAULT_LOG_ISSUE', true);
  31. define ('DEFAULT_LOG_WEB_SERVICE', true);
  32. define ('DEFAULT_MIN_DISPLAY_LIMIT', 10);
  33. define ('DEFAULT_MAX_DISPLAY_LIMIT', 15);
  34. define ('DEFAULT_STANDARD_RELOAD_INTERVAL', 5*60);
  35. define ('DEFAULT_FAST_RELOAD_INTERVAL', 1*60);
  36. define ('DEFAULT_SECURE_CONNECTION_REQUIRED', false);
  37. /**
  38. * Config
  39. * configuration data (this class cannot not be localized, because it is responsible for loading the dictionaries)
  40. *
  41. * @package iTopORM
  42. */
  43. class Config
  44. {
  45. //protected $m_bIsLoaded = false;
  46. protected $m_sFile = '';
  47. protected $m_aAppModules;
  48. protected $m_aDataModels;
  49. protected $m_aAddons;
  50. protected $m_aDictionaries;
  51. protected $m_sDBHost;
  52. protected $m_sDBUser;
  53. protected $m_sDBPwd;
  54. protected $m_sDBName;
  55. protected $m_sDBSubname;
  56. /**
  57. * @var integer Event log options (see LOG_... definition)
  58. */
  59. protected $m_bLogGlobal;
  60. protected $m_bLogNotification;
  61. protected $m_bLogIssue;
  62. protected $m_bLogWebService;
  63. /**
  64. * @var integer Number of elements to be displayed when there are more than m_iMaxDisplayLimit elements
  65. */
  66. protected $m_iMinDisplayLimit;
  67. /**
  68. * @var integer Max number of elements before truncating the display
  69. */
  70. protected $m_iMaxDisplayLimit;
  71. /**
  72. * @var integer Number of seconds between two reloads of the display (standard)
  73. */
  74. protected $m_iStandardReloadInterval;
  75. /**
  76. * @var integer Number of seconds between two reloads of the display (fast)
  77. */
  78. protected $m_iFastReloadInterval;
  79. /**
  80. * @var boolean Whether or not a secure connection is required for using the application
  81. */
  82. protected $m_bSecureConnectionRequired;
  83. /**
  84. * @var string Langage code, default if the user language is undefined
  85. */
  86. protected $m_sDefaultLanguage;
  87. public function __construct($sConfigFile, $bLoadConfig = true)
  88. {
  89. $this->m_sFile = $sConfigFile;
  90. $this->m_aAppModules = array();
  91. $this->m_aDataModels = array();
  92. $this->m_aAddons = array();
  93. $this->m_aDictionaries = array();
  94. $this->m_sDBHost = '';
  95. $this->m_sDBUser = '';
  96. $this->m_sDBPwd = '';
  97. $this->m_sDBName = '';
  98. $this->m_sDBSubname = '';
  99. $this->m_bLogGlobal = DEFAULT_LOG_GLOBAL;
  100. $this->m_bLogNotification = DEFAULT_LOG_NOTIFICATION;
  101. $this->m_bLogIssue = DEFAULT_LOG_ISSUE;
  102. $this->m_bLogWebService = DEFAULT_LOG_WEB_SERVICE;
  103. $this->m_iMinDisplayLimit = DEFAULT_MIN_DISPLAY_LIMIT;
  104. $this->m_iMaxDisplayLimit = DEFAULT_MAX_DISPLAY_LIMIT;
  105. $this->m_iStandardReloadInterval = DEFAULT_STANDARD_RELOAD_INTERVAL;
  106. $this->m_iFastReloadInterval = DEFAULT_FAST_RELOAD_INTERVAL;
  107. $this->m_bSecureConnectionRequired = DEFAULT_SECURE_CONNECTION_REQUIRED;
  108. $this->m_sDefaultLanguage = 'EN US';
  109. if ($bLoadConfig)
  110. {
  111. $this->Load($sConfigFile);
  112. $this->Verify();
  113. }
  114. }
  115. protected function CheckFile($sPurpose, $sFileName)
  116. {
  117. if (!file_exists($sFileName))
  118. {
  119. throw new ConfigException("Could not find $sPurpose file", array('file' => $sFileName));
  120. }
  121. }
  122. protected function Load($sConfigFile)
  123. {
  124. $this->CheckFile('configuration', $sConfigFile);
  125. $sConfigCode = trim(file_get_contents($sConfigFile));
  126. // This does not work on several lines
  127. // preg_match('/^<\\?php(.*)\\?'.'>$/', $sConfigCode, $aMatches)...
  128. // So, I've implemented a solution suggested in the PHP doc (search for phpWrapper)
  129. try
  130. {
  131. ob_start();
  132. eval('?'.'>'.trim($sConfigCode));
  133. $sNoise = trim(ob_get_contents());
  134. ob_end_clean();
  135. }
  136. catch (Exception $e)
  137. {
  138. // well, never reach in case of parsing error :-(
  139. // will be improved in PHP 6 ?
  140. throw new ConfigException('Error in configuration file', array('file' => $sConfigFile, 'error' => $e->getMessage()));
  141. }
  142. if (strlen($sNoise) > 0)
  143. {
  144. // Note: sNoise is an html output, but so far it was ok for me (e.g. showing the entire call stack)
  145. throw new ConfigException('Syntax error in configuration file', array('file' => $sConfigFile, 'error' => '<tt>'.htmlentities($sNoise).'</tt>'));
  146. }
  147. if (!isset($MySettings) || !is_array($MySettings))
  148. {
  149. throw new ConfigException('Missing array in configuration file', array('file' => $sConfigFile, 'expected' => '$MySettings'));
  150. }
  151. if (!isset($MyModules) || !is_array($MyModules))
  152. {
  153. throw new ConfigException('Missing item in configuration file', array('file' => $sConfigFile, 'expected' => '$MyModules'));
  154. }
  155. if (!array_key_exists('application', $MyModules))
  156. {
  157. throw new ConfigException('Missing item in configuration file', array('file' => $sConfigFile, 'expected' => '$MyModules[\'application\']'));
  158. }
  159. if (!array_key_exists('business', $MyModules))
  160. {
  161. throw new ConfigException('Missing item in configuration file', array('file' => $sConfigFile, 'expected' => '$MyModules[\'business\']'));
  162. }
  163. if (!array_key_exists('addons', $MyModules))
  164. {
  165. throw new ConfigException('Missing item in configuration file', array('file' => $sConfigFile, 'expected' => '$MyModules[\'addons\']'));
  166. }
  167. if (!array_key_exists('user rights', $MyModules['addons']))
  168. {
  169. $MyModules['addons']['user rights'] = '../addons/userrights/userrightsnull.class.inc.php';
  170. }
  171. if (!array_key_exists('dictionaries', $MyModules))
  172. {
  173. throw new ConfigException('Missing item in configuration file', array('file' => $sConfigFile, 'expected' => '$MyModules[\'dictionaries\']'));
  174. }
  175. $this->m_aAppModules = $MyModules['application'];
  176. $this->m_aDataModels = $MyModules['business'];
  177. $this->m_aAddons = $MyModules['addons'];
  178. $this->m_aDictionaries = $MyModules['dictionaries'];
  179. $this->m_sDBHost = trim($MySettings['db_host']);
  180. $this->m_sDBUser = trim($MySettings['db_user']);
  181. $this->m_sDBPwd = trim($MySettings['db_pwd']);
  182. $this->m_sDBName = trim($MySettings['db_name']);
  183. $this->m_sDBSubname = trim($MySettings['db_subname']);
  184. $this->m_bLogGlobal = isset($MySettings['log_global']) ? trim($MySettings['log_global']) : DEFAULT_LOG_GLOBAL;
  185. $this->m_bLogNotification = isset($MySettings['log_notification']) ? trim($MySettings['log_notification']) : DEFAULT_LOG_NOTIFICATION;
  186. $this->m_bLogIssue = isset($MySettings['log_issue']) ? trim($MySettings['log_issue']) : DEFAULT_LOG_ISSUE;
  187. $this->m_bLogWebService = isset($MySettings['log_web_service']) ? trim($MySettings['log_web_service']) : DEFAULT_LOG_WEB_SERVICE;
  188. $this->m_iMinDisplayLimit = isset($MySettings['min_display_limit']) ? trim($MySettings['min_display_limit']) : DEFAULT_MIN_DISPLAY_LIMIT;
  189. $this->m_iMaxDisplayLimit = isset($MySettings['max_display_limit']) ? trim($MySettings['max_display_limit']) : DEFAULT_MAX_DISPLAY_LIMIT;
  190. $this->m_iStandardReloadInterval = isset($MySettings['standard_reload_interval']) ? trim($MySettings['standard_reload_interval']) : DEFAULT_STANDARD_RELOAD_INTERVAL;
  191. $this->m_iFastReloadInterval = isset($MySettings['fast_reload_interval']) ? trim($MySettings['fast_reload_interval']) : DEFAULT_FAST_RELOAD_INTERVAL;
  192. $this->m_bSecureConnectionRequired = isset($MySettings['secure_connection_required']) ? trim($MySettings['secure_connection_required']) : DEFAULT_SECURE_CONNECTION_REQUIRED;
  193. $this->m_sDefaultLanguage = isset($MySettings['default_language']) ? trim($MySettings['default_language']) : 'EN US';
  194. }
  195. protected function Verify()
  196. {
  197. foreach ($this->m_aAppModules as $sModule => $sToInclude)
  198. {
  199. $this->CheckFile('application module', $sToInclude);
  200. }
  201. foreach ($this->m_aDataModels as $sModule => $sToInclude)
  202. {
  203. $this->CheckFile('business model', $sToInclude);
  204. }
  205. foreach ($this->m_aAddons as $sModule => $sToInclude)
  206. {
  207. $this->CheckFile('addon module', $sToInclude);
  208. }
  209. foreach ($this->m_aDictionaries as $sModule => $sToInclude)
  210. {
  211. $this->CheckFile('dictionary', $sToInclude);
  212. }
  213. }
  214. public function GetAppModules()
  215. {
  216. return $this->m_aAppModules;
  217. }
  218. public function GetDataModels()
  219. {
  220. return $this->m_aDataModels;
  221. }
  222. public function GetAddons()
  223. {
  224. return $this->m_aAddons;
  225. }
  226. public function GetDictionaries()
  227. {
  228. return $this->m_aDictionaries;
  229. }
  230. public function GetDBHost()
  231. {
  232. return $this->m_sDBHost;
  233. }
  234. public function GetDBName()
  235. {
  236. return $this->m_sDBName;
  237. }
  238. public function GetDBSubname()
  239. {
  240. return $this->m_sDBSubname;
  241. }
  242. public function GetDBUser()
  243. {
  244. return $this->m_sDBUser;
  245. }
  246. public function GetDBPwd()
  247. {
  248. return $this->m_sDBPwd;
  249. }
  250. public function GetLogGlobal()
  251. {
  252. return $this->m_bLogGlobal;
  253. }
  254. public function GetLogNotification()
  255. {
  256. return $this->m_bLogNotification;
  257. }
  258. public function GetLogIssue()
  259. {
  260. return $this->m_bLogIssue;
  261. }
  262. public function GetLogWebService()
  263. {
  264. return $this->m_bLogWebService;
  265. }
  266. public function GetMinDisplayLimit()
  267. {
  268. return $this->m_iMinDisplayLimit;
  269. }
  270. public function GetMaxDisplayLimit()
  271. {
  272. return $this->m_iMaxDisplayLimit;
  273. }
  274. public function GetStandardReloadInterval()
  275. {
  276. return $this->m_iStandardReloadInterval;
  277. }
  278. public function GetFastReloadInterval()
  279. {
  280. return $this->m_iFastReloadInterval;
  281. }
  282. public function GetSecureConnectionRequired()
  283. {
  284. return $this->m_bSecureConnectionRequired;
  285. }
  286. public function GetDefaultLanguage()
  287. {
  288. return $this->m_sDefaultLanguage;
  289. }
  290. public function SetDBHost($sDBHost)
  291. {
  292. $this->m_sDBHost = $sDBHost;
  293. }
  294. public function SetDBName($sDBName)
  295. {
  296. $this->m_sDBName = $sDBName;
  297. }
  298. public function SetDBSubname($sDBSubName)
  299. {
  300. $this->m_sDBSubname = $sDBSubName;
  301. }
  302. public function SetDBUser($sUser)
  303. {
  304. $this->m_sDBUser = $sUser;
  305. }
  306. public function SetDBPwd($sPwd)
  307. {
  308. $this->m_sDBPwd = $sPwd;
  309. }
  310. public function SetLogGlobal($iLogGlobal)
  311. {
  312. $this->m_iLogGlobal = $iLogGlobal;
  313. }
  314. public function SetLogNotification($iLogNotification)
  315. {
  316. $this->m_iLogNotification = $iLogNotification;
  317. }
  318. public function SetLogIssue($iLogIssue)
  319. {
  320. $this->m_iLogIssue = $iLogIssue;
  321. }
  322. public function SetLogWebService($iLogWebService)
  323. {
  324. $this->m_iLogWebService = $iLogWebService;
  325. }
  326. public function SetMinDisplayLimit($iMinDisplayLimit)
  327. {
  328. $this->m_iMinDisplayLimit = $iMinDisplayLimit;
  329. }
  330. public function SetMaxDisplayLimit($iMaxDisplayLimit)
  331. {
  332. $this->m_iMaxDisplayLimit = $iMaxDisplayLimit;
  333. }
  334. public function SetStandardReloadInterval($iStandardReloadInterval)
  335. {
  336. $this->m_iStandardReloadInterval = $iStandardReloadInterval;
  337. }
  338. public function SetFastReloadInterval($iFastReloadInterval)
  339. {
  340. $this->m_iFastReloadInterval = $iFastReloadInterval;
  341. }
  342. public function SetSecureConnectionRequired($bSecureConnectionRequired)
  343. {
  344. $this->m_bSecureConnectionRequired = $bSecureConnectionRequired;
  345. }
  346. public function SetDefaultLanguage($sLanguageCode)
  347. {
  348. $this->m_sDefaultLanguage = $sLanguageCode;
  349. }
  350. public function FileIsWritable()
  351. {
  352. return is_writable($this->m_sFile);
  353. }
  354. /**
  355. * Write the configuration to a file (php format) that can be reloaded later
  356. * By default write to the same file that was specified when constructing the object
  357. * @param $sFileName string Name of the file to write to (emtpy to write to the same file)
  358. * @return boolean True otherwise throws an Exception
  359. */
  360. public function WriteToFile($sFileName = '')
  361. {
  362. if (empty($sFileName))
  363. {
  364. $sFileName = $this->m_sFile;
  365. }
  366. $hFile = @fopen($sFileName, 'w');
  367. if ($hFile !== false)
  368. {
  369. fwrite($hFile, "<?php\n");
  370. fwrite($hFile, "\n/**\n");
  371. fwrite($hFile, " *\n");
  372. fwrite($hFile, " * phpMyORM configuration file, generated by the iTop configuration wizard\n");
  373. fwrite($hFile, " *\n");
  374. fwrite($hFile, " * The file is used in MetaModel::LoadConfig() which does all the necessary initialization job\n");
  375. fwrite($hFile, " *\n");
  376. fwrite($hFile, " */\n");
  377. fwrite($hFile, "\n");
  378. fwrite($hFile, "\$MySettings = array(\n");
  379. fwrite($hFile, "\t'db_host' => '{$this->m_sDBHost}',\n");
  380. fwrite($hFile, "\t'db_user' => '{$this->m_sDBUser}',\n");
  381. fwrite($hFile, "\t'db_pwd' => '".addslashes($this->m_sDBPwd)."',\n");
  382. fwrite($hFile, "\t'db_name' => '{$this->m_sDBName}',\n");
  383. fwrite($hFile, "\t'db_subname' => '{$this->m_sDBSubname}',\n");
  384. fwrite($hFile, "\n");
  385. fwrite($hFile, "\t'log_global' => {$this->m_bLogGlobal},\n");
  386. fwrite($hFile, "\t'log_notification' => {$this->m_bLogNotification},\n");
  387. fwrite($hFile, "\t'log_issue' => {$this->m_bLogIssue},\n");
  388. fwrite($hFile, "\t'log_web_service' => {$this->m_bLogWebService},\n");
  389. fwrite($hFile, "\t'min_display_limit' => {$this->m_iMinDisplayLimit},\n");
  390. fwrite($hFile, "\t'max_display_limit' => {$this->m_iMaxDisplayLimit},\n");
  391. fwrite($hFile, "\t'standard_reload_interval' => {$this->m_iStandardReloadInterval},\n");
  392. fwrite($hFile, "\t'fast_reload_interval' => {$this->m_iFastReloadInterval},\n");
  393. fwrite($hFile, "\t'secure_connection_required' => ".($this->m_bSecureConnectionRequired ? 'true' : 'false').",\n");
  394. fwrite($hFile, "\t'default_language' => '{$this->m_sDefaultLanguage}',\n");
  395. fwrite($hFile, ");\n");
  396. fwrite($hFile, "\n/**\n");
  397. fwrite($hFile, " *\n");
  398. fwrite($hFile, " * Data model modules to be loaded. Names should be specified as absolute paths\n");
  399. fwrite($hFile, " *\n");
  400. fwrite($hFile, " */\n");
  401. fwrite($hFile, "\$MyModules = array(\n");
  402. fwrite($hFile, "\t'application' => array (\n");
  403. fwrite($hFile, "\t\t'../application/menunode.class.inc.php',\n");
  404. fwrite($hFile, "\t\t'../application/audit.rule.class.inc.php',\n");
  405. // Romain - That's dirty, because those 3 classes are in fact part of the core
  406. // but I needed those classes to be derived from cmdbAbstractObject
  407. // (to be managed via the GUI) and this class in not really known from
  408. // the core, PLUS I needed the includes to be there also for the setup
  409. // to create the tables.
  410. fwrite($hFile, "\t\t'../core/event.class.inc.php',\n");
  411. fwrite($hFile, "\t\t'../core/action.class.inc.php',\n");
  412. fwrite($hFile, "\t\t'../core/trigger.class.inc.php',\n");
  413. fwrite($hFile, "\t\t// to be continued...\n");
  414. fwrite($hFile, "\t),\n");
  415. fwrite($hFile, "\t'business' => array (\n");
  416. fwrite($hFile, "\t\t'../business/itop.business.class.inc.php'\n");
  417. fwrite($hFile, "\t\t// to be continued...\n");
  418. fwrite($hFile, "\t),\n");
  419. fwrite($hFile, "\t'addons' => array (\n");
  420. fwrite($hFile, "\t\t'user rights' => '../addons/userrights/userrightsprofile.class.inc.php',\n");
  421. fwrite($hFile, "\t\t// other modules to come later\n");
  422. fwrite($hFile, "\t),\n");
  423. fwrite($hFile, "\t'dictionaries' => array (\n");
  424. fwrite($hFile, "\t\t'../dictionaries/dictionary.itop.model.php',\n");
  425. fwrite($hFile, "\t\t'../dictionaries/dictionary.itop.core.php',\n");
  426. fwrite($hFile, "\t\t'../dictionaries/dictionary.itop.ui.php',\n");
  427. fwrite($hFile, "\t\t// to be continued...\n");
  428. fwrite($hFile, "\t),\n");
  429. fwrite($hFile, ");\n");
  430. fwrite($hFile, '?'.'>'); // Avoid perturbing the syntax highlighting !
  431. return fclose($hFile);
  432. }
  433. else
  434. {
  435. throw new ConfigException("Could not write to configuration file", array('file' => $sFileName));
  436. }
  437. }
  438. }
  439. ?>