global.inc.php 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * It is recommended that ALL Chamilo scripts include this important file.
  5. * This script manages
  6. * - include of /app/config/configuration.php;
  7. * - include of several libraries: api, database, display, text, security;
  8. * - selecting the main database;
  9. * - include of language files.
  10. *
  11. * @package chamilo.include
  12. * @todo remove the code that displays the button that links to the install page
  13. * but use a redirect immediately. By doing so the $alreadyInstalled variable can be removed.
  14. *
  15. */
  16. // Showing/hiding error codes in global error messages.
  17. define('SHOW_ERROR_CODES', false);
  18. // Include the libraries that are necessary everywhere
  19. require_once __DIR__.'/../../vendor/autoload.php';
  20. require_once __DIR__.'/../../app/AppKernel.php';
  21. $kernel = new AppKernel('', '');
  22. // Determine the directory path where this current file lies.
  23. // This path will be useful to include the other initialisation files.
  24. $includePath = __DIR__;
  25. // Include the main Chamilo platform configuration file.
  26. $alreadyInstalled = false;
  27. if (file_exists($kernel->getConfigurationFile())) {
  28. require_once $kernel->getConfigurationFile();
  29. $alreadyInstalled = true;
  30. // Recalculate a system absolute path symlinks insensible.
  31. $includePath = $_configuration['root_sys'].'main/inc/';
  32. } else {
  33. $_configuration = array();
  34. //Redirects to the main/install/ page
  35. if (!$alreadyInstalled) {
  36. $global_error_code = 2;
  37. // The system has not been installed yet.
  38. require_once __DIR__.'/../inc/global_error_message.inc.php';
  39. die();
  40. }
  41. }
  42. $kernel->setApi($_configuration);
  43. // Ensure that _configuration is in the global scope before loading
  44. // main_api.lib.php. This is particularly helpful for unit tests
  45. if (!isset($GLOBALS['_configuration'])) {
  46. $GLOBALS['_configuration'] = $_configuration;
  47. }
  48. // Include the main Chamilo platform library file.
  49. require_once $_configuration['root_sys'].'main/inc/lib/api.lib.php';
  50. $passwordEncryption = api_get_configuration_value('password_encryption');
  51. if ($passwordEncryption === 'bcrypt') {
  52. require_once __DIR__.'/../../vendor/ircmaxell/password-compat/lib/password.php';
  53. }
  54. // Check the PHP version
  55. api_check_php_version($includePath.'/');
  56. // Specification for usernames:
  57. // 1. ASCII-letters, digits, "." (dot), "_" (underscore) are acceptable, 40 characters maximum length.
  58. // 2. Empty username is formally valid, but it is reserved for the anonymous user.
  59. // 3. Checking the login_is_email portal setting in order to accept 100 chars maximum
  60. $defaultUserNameLength = 50;
  61. if (api_get_setting('login_is_email') == 'true') {
  62. $defaultUserNameLength = 100;
  63. }
  64. define('USERNAME_MAX_LENGTH', $defaultUserNameLength);
  65. // Fix bug in IIS that doesn't fill the $_SERVER['REQUEST_URI'].
  66. api_request_uri();
  67. define('_MPDF_TEMP_PATH', __DIR__.'/../../app/cache/mpdf/');
  68. define('_MPDF_TTFONTDATAPATH', __DIR__.'/../../app/cache/mpdf/');
  69. // Include the libraries that are necessary everywhere
  70. require_once __DIR__.'/../../vendor/autoload.php';
  71. // Do not over-use this variable. It is only for this script's local use.
  72. $libraryPath = __DIR__.'/lib/';
  73. // @todo convert this libs in classes
  74. require_once $libraryPath.'database.constants.inc.php';
  75. require_once $libraryPath.'text.lib.php';
  76. require_once $libraryPath.'array.lib.php';
  77. require_once $libraryPath.'online.inc.php';
  78. require_once $libraryPath.'banner.lib.php';
  79. require_once $libraryPath.'fileManage.lib.php';
  80. require_once $libraryPath.'fileUpload.lib.php';
  81. require_once $libraryPath.'fileDisplay.lib.php';
  82. require_once $libraryPath.'course_category.lib.php';
  83. if (!is_dir(_MPDF_TEMP_PATH)) {
  84. mkdir(_MPDF_TEMP_PATH, api_get_permissions_for_new_directories(), true);
  85. }
  86. // Connect to the server database and select the main chamilo database.
  87. // When $_configuration['db_persistent_connection'] is set, it is expected to be a boolean type.
  88. /*$dbPersistConnection = api_get_configuration_value('db_persistent_connection');
  89. // $_configuration['db_client_flags'] can be set in configuration.php to pass
  90. // flags to the DB connection
  91. $dbFlags = api_get_configuration_value('db_client_flags');
  92. $params = array(
  93. 'server' => $_configuration['db_host'],
  94. 'username' => $_configuration['db_user'],
  95. 'password' => $_configuration['db_password'],
  96. 'persistent' => $dbPersistConnection,
  97. 'client_flags' => $dbFlags,
  98. );*/
  99. // Doctrine ORM configuration
  100. $dbParams = array(
  101. 'driver' => 'pdo_mysql',
  102. 'host' => $_configuration['db_host'],
  103. 'user' => $_configuration['db_user'],
  104. 'password' => $_configuration['db_password'],
  105. 'dbname' => $_configuration['main_database'],
  106. // Only relevant for pdo_sqlite, specifies the path to the SQLite database.
  107. 'path' => isset($_configuration['db_path']) ? $_configuration['db_path'] : '',
  108. // Only relevant for pdo_mysql, pdo_pgsql, and pdo_oci/oci8,
  109. 'port' => isset($_configuration['db_port']) ? $_configuration['db_port'] : ''
  110. );
  111. try {
  112. $database = new \Database();
  113. $database->connect($dbParams);
  114. } catch (Exception $e) {
  115. $global_error_code = 3;
  116. // The database server is not available or credentials are invalid.
  117. require $includePath.'/global_error_message.inc.php';
  118. die();
  119. }
  120. /* RETRIEVING ALL THE CHAMILO CONFIG SETTINGS FOR MULTIPLE URLs FEATURE*/
  121. if (!empty($_configuration['multiple_access_urls'])) {
  122. $_configuration['access_url'] = 1;
  123. $access_urls = api_get_access_urls();
  124. $root_rel = api_get_self();
  125. $root_rel = substr($root_rel, 1);
  126. $pos = strpos($root_rel, '/');
  127. $root_rel = substr($root_rel, 0, $pos);
  128. $protocol = 'http://';
  129. if (!empty($_SERVER['HTTPS']) && strtoupper($_SERVER['HTTPS']) != 'OFF') {
  130. $protocol = 'https://';
  131. } elseif (!empty($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') {
  132. $protocol = 'https://';
  133. }
  134. //urls with subdomains (HTTP_HOST is preferred - see #6764)
  135. $request_url_root = '';
  136. if (empty($_SERVER['HTTP_HOST'])) {
  137. if (empty($_SERVER['SERVER_NAME'])) {
  138. $request_url_root = $protocol.'localhost/';
  139. } else {
  140. $request_url_root = $protocol.$_SERVER['SERVER_NAME'].'/';
  141. }
  142. } else {
  143. $request_url_root = $protocol.$_SERVER['HTTP_HOST'].'/';
  144. }
  145. //urls with subdirs
  146. $request_url_sub = $request_url_root.$root_rel.'/';
  147. // You can use subdirs as multi-urls, but in this case none of them can be
  148. // the root dir. The admin portal should be something like https://host/adm/
  149. // At this time, subdirs will still hold a share cookie, so not ideal yet
  150. // see #6510
  151. foreach ($access_urls as $details) {
  152. if ($request_url_sub == $details['url']) {
  153. $_configuration['access_url'] = $details['id'];
  154. break; //found one match with subdir, get out of foreach
  155. }
  156. // Didn't find any? Now try without subdirs
  157. if ($request_url_root == $details['url']) {
  158. $_configuration['access_url'] = $details['id'];
  159. break; //found one match, get out of foreach
  160. }
  161. }
  162. } else {
  163. $_configuration['access_url'] = 1;
  164. }
  165. // Check if APCu is available. If so, store the value in $_configuration
  166. if (extension_loaded('apcu')) {
  167. $apcEnabled = ini_get('apc.enabled');
  168. if (!empty($apcEnabled) && $apcEnabled != 'Off' && $apcEnabled != 'off') {
  169. $_configuration['apc'] = true;
  170. $_configuration['apc_prefix'] = $_configuration['main_database'].'_'.$_configuration['access_url'].'_';
  171. }
  172. }
  173. $charset = 'UTF-8';
  174. // Enables the portability layer and configures PHP for UTF-8
  175. \Patchwork\Utf8\Bootup::initAll();
  176. // Start session after the internationalization library has been initialized.
  177. ChamiloSession::instance()->start($alreadyInstalled);
  178. // Remove quotes added by PHP - get_magic_quotes_gpc() is deprecated in PHP 5 see #2970
  179. if (function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) {
  180. array_walk_recursive_limited($_GET, 'stripslashes', true);
  181. array_walk_recursive_limited($_POST, 'stripslashes', true);
  182. array_walk_recursive_limited($_COOKIE, 'stripslashes', true);
  183. array_walk_recursive_limited($_REQUEST, 'stripslashes', true);
  184. }
  185. // access_url == 1 is the default chamilo location
  186. if ($_configuration['access_url'] != 1) {
  187. $url_info = api_get_access_url($_configuration['access_url']);
  188. if ($url_info['active'] == 1) {
  189. $settings_by_access = & api_get_settings(null, 'list', $_configuration['access_url'], 1);
  190. foreach ($settings_by_access as & $row) {
  191. if (empty($row['variable'])) {
  192. $row['variable'] = 0;
  193. }
  194. if (empty($row['subkey'])) {
  195. $row['subkey'] = 0;
  196. }
  197. if (empty($row['category'])) {
  198. $row['category'] = 0;
  199. }
  200. $settings_by_access_list[$row['variable']][$row['subkey']][$row['category']] = $row;
  201. }
  202. }
  203. }
  204. $result = & api_get_settings(null, 'list', 1);
  205. foreach ($result as & $row) {
  206. if ($_configuration['access_url'] != 1) {
  207. if ($url_info['active'] == 1) {
  208. $var = empty($row['variable']) ? 0 : $row['variable'];
  209. $subkey = empty($row['subkey']) ? 0 : $row['subkey'];
  210. $category = empty($row['category']) ? 0 : $row['category'];
  211. }
  212. if ($row['access_url_changeable'] == 1 && $url_info['active'] == 1) {
  213. if (isset($settings_by_access_list[$var]) &&
  214. isset($settings_by_access_list[$var][$subkey]) &&
  215. $settings_by_access_list[$var][$subkey][$category]['selected_value'] != '') {
  216. if ($row['subkey'] == null) {
  217. $_setting[$row['variable']] = $settings_by_access_list[$var][$subkey][$category]['selected_value'];
  218. } else {
  219. $_setting[$row['variable']][$row['subkey']] = $settings_by_access_list[$var][$subkey][$category]['selected_value'];
  220. }
  221. } else {
  222. if ($row['subkey'] == null) {
  223. $_setting[$row['variable']] = $row['selected_value'];
  224. } else {
  225. $_setting[$row['variable']][$row['subkey']] = $row['selected_value'];
  226. }
  227. }
  228. } else {
  229. if ($row['subkey'] == null) {
  230. $_setting[$row['variable']] = $row['selected_value'];
  231. } else {
  232. $_setting[$row['variable']][$row['subkey']] = $row['selected_value'];
  233. }
  234. }
  235. } else {
  236. if ($row['subkey'] == null) {
  237. $_setting[$row['variable']] = $row['selected_value'];
  238. } else {
  239. $_setting[$row['variable']][$row['subkey']] = $row['selected_value'];
  240. }
  241. }
  242. }
  243. $result = & api_get_settings('Plugins', 'list', $_configuration['access_url']);
  244. $_plugins = array();
  245. foreach ($result as & $row) {
  246. $key = & $row['variable'];
  247. if (isset($_setting[$key]) && is_string($_setting[$key])) {
  248. $_setting[$key] = array();
  249. }
  250. $_setting[$key][] = $row['selected_value'];
  251. $_plugins[$key][] = $row['selected_value'];
  252. }
  253. // Error reporting settings.
  254. if (api_get_setting('server_type') == 'test') {
  255. ini_set('display_errors', '1');
  256. ini_set('log_errors', '1');
  257. error_reporting(-1);
  258. if (function_exists('opcache_reset')) {
  259. opcache_reset();
  260. }
  261. } else {
  262. error_reporting(E_COMPILE_ERROR | E_ERROR | E_CORE_ERROR);
  263. }
  264. // Load allowed tag definitions for kses and/or HTMLPurifier.
  265. require_once $libraryPath.'formvalidator/Rule/allowed_tags.inc.php';
  266. // Before we call local.inc.php, let's define a global $this_section variable
  267. // which will then be usable from the banner and header scripts
  268. $this_section = SECTION_GLOBAL;
  269. // Include Chamilo Mail conf this is added here because the api_get_setting works
  270. // Fixes bug in Chamilo 1.8.7.1 array was not set
  271. $administrator['email'] = isset($administrator['email']) ? $administrator['email'] : 'admin@example.com';
  272. $administrator['name'] = isset($administrator['name']) ? $administrator['name'] : 'Admin';
  273. // Including configuration files
  274. $configurationFiles = array(
  275. 'mail.conf.php',
  276. 'profile.conf.php',
  277. 'course_info.conf.php',
  278. 'add_course.conf.php',
  279. 'events.conf.php',
  280. 'auth.conf.php',
  281. 'portfolio.conf.php'
  282. );
  283. foreach ($configurationFiles as $file) {
  284. $file = api_get_path(CONFIGURATION_PATH).$file;
  285. if (file_exists($file)) {
  286. require_once $file;
  287. }
  288. }
  289. /* LOAD LANGUAGE FILES SECTION */
  290. // if we use the javascript version (without go button) we receive a get
  291. // if we use the non-javascript version (with the go button) we receive a post
  292. $user_language = '';
  293. $browser_language = '';
  294. // see #8149
  295. if (!empty($_SESSION['user_language_choice'])) {
  296. $user_language = $_SESSION['user_language_choice'];
  297. }
  298. if (!empty($_GET['language'])) {
  299. $user_language = $_GET['language'];
  300. }
  301. if (!empty($_POST['language_list'])) {
  302. $user_language = str_replace('index.php?language=', '', $_POST['language_list']);
  303. }
  304. if (empty($user_language) && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && !isset($_SESSION['_user'])) {
  305. $l = SubLanguageManager::getLanguageFromBrowserPreference($_SERVER['HTTP_ACCEPT_LANGUAGE']);
  306. if (!empty($l)) {
  307. $user_language = $browser_language = $l;
  308. }
  309. }
  310. // Include all files (first english and then current interface language)
  311. $langpath = api_get_path(SYS_LANG_PATH);
  312. /* This will only work if we are in the page to edit a sub_language */
  313. if (isset($this_script) && $this_script == 'sub_language') {
  314. // getting the arrays of files i.e notification, trad4all, etc
  315. $language_files_to_load = SubLanguageManager:: get_lang_folder_files_list(
  316. api_get_path(SYS_LANG_PATH).'english',
  317. true
  318. );
  319. //getting parent info
  320. $parent_language = SubLanguageManager::get_all_information_of_language($_REQUEST['id']);
  321. //getting sub language info
  322. $sub_language = SubLanguageManager::get_all_information_of_language($_REQUEST['sub_language_id']);
  323. $english_language_array = $parent_language_array = $sub_language_array = array();
  324. foreach ($language_files_to_load as $language_file_item) {
  325. $lang_list_pre = array_keys($GLOBALS);
  326. //loading english
  327. $path = $langpath.'english/'.$language_file_item.'.inc.php';
  328. if (file_exists($path)) {
  329. include $path;
  330. }
  331. $lang_list_post = array_keys($GLOBALS);
  332. $lang_list_result = array_diff($lang_list_post, $lang_list_pre);
  333. unset($lang_list_pre);
  334. // english language array
  335. $english_language_array[$language_file_item] = compact($lang_list_result);
  336. //cleaning the variables
  337. foreach ($lang_list_result as $item) {
  338. unset(${$item});
  339. }
  340. $parent_file = $langpath.$parent_language['dokeos_folder'].'/'.$language_file_item.'.inc.php';
  341. if (file_exists($parent_file) && is_file($parent_file)) {
  342. include_once $parent_file;
  343. }
  344. // parent language array
  345. $parent_language_array[$language_file_item] = compact($lang_list_result);
  346. //cleaning the variables
  347. foreach ($lang_list_result as $item) {
  348. unset(${$item});
  349. }
  350. $sub_file = $langpath.$sub_language['dokeos_folder'].'/'.$language_file_item.'.inc.php';
  351. if (file_exists($sub_file) && is_file($sub_file)) {
  352. include $sub_file;
  353. }
  354. // sub language array
  355. $sub_language_array[$language_file_item] = compact($lang_list_result);
  356. //cleaning the variables
  357. foreach ($lang_list_result as $item) {
  358. unset(${$item});
  359. }
  360. }
  361. }
  362. // Checking if we have a valid language. If not we set it to the platform language.
  363. $valid_languages = api_get_languages();
  364. if (!empty($valid_languages)) {
  365. if (!in_array($user_language, $valid_languages['folder'])) {
  366. $user_language = api_get_setting('platformLanguage');
  367. }
  368. $language_priority1 = api_get_setting('languagePriority1');
  369. $language_priority2 = api_get_setting('languagePriority2');
  370. $language_priority3 = api_get_setting('languagePriority3');
  371. $language_priority4 = api_get_setting('languagePriority4');
  372. if (isset($_GET['language']) ||
  373. (isset($_POST['language_list']) && !empty($_POST['language_list'])) ||
  374. !empty($browser_language)
  375. ) {
  376. $user_selected_language = $user_language; // $_GET['language']; or HTTP_ACCEPT_LANGUAGE
  377. $_SESSION['user_language_choice'] = $user_selected_language;
  378. $platformLanguage = $user_selected_language;
  379. }
  380. if (!empty($language_priority4) && api_get_language_from_type($language_priority4) !== false) {
  381. $language_interface = api_get_language_from_type($language_priority4);
  382. } else {
  383. $language_interface = api_get_setting('platformLanguage');
  384. }
  385. if (!empty($language_priority3) && api_get_language_from_type($language_priority3) !== false) {
  386. $language_interface = api_get_language_from_type($language_priority3);
  387. } else {
  388. if (isset($_SESSION['user_language_choice'])) {
  389. $language_interface = $_SESSION['user_language_choice'];
  390. }
  391. }
  392. if (!empty($language_priority2) && api_get_language_from_type($language_priority2) !== false) {
  393. $language_interface = api_get_language_from_type($language_priority2);
  394. } else {
  395. if (isset($_user['language'])) {
  396. $language_interface = $_user['language'];
  397. }
  398. }
  399. if (!empty($language_priority1) && api_get_language_from_type($language_priority1) !== false) {
  400. $language_interface = api_get_language_from_type($language_priority1);
  401. } else {
  402. if (isset($_course['language'])) {
  403. $language_interface = $_course['language'];
  404. }
  405. }
  406. // If language is set via browser ignore the priority
  407. if (isset($_GET['language'])) {
  408. $language_interface = $user_language;
  409. }
  410. }
  411. // Sometimes the variable $language_interface is changed
  412. // temporarily for achieving translation in different language.
  413. // We need to save the genuine value of this variable and
  414. // to use it within the function get_lang(...).
  415. $language_interface_initial_value = $language_interface;
  416. /**
  417. * Include the trad4all language file
  418. */
  419. // if the sub-language feature is on
  420. $parent_path = SubLanguageManager::get_parent_language_path($language_interface);
  421. if (!empty($parent_path)) {
  422. // include English
  423. include $langpath.'english/trad4all.inc.php';
  424. // prepare string for current language and its parent
  425. $lang_file = $langpath.$language_interface.'/trad4all.inc.php';
  426. $parent_lang_file = $langpath.$parent_path.'/trad4all.inc.php';
  427. // load the parent language file first
  428. if (file_exists($parent_lang_file)) {
  429. include $parent_lang_file;
  430. }
  431. // overwrite the parent language translations if there is a child
  432. if (file_exists($lang_file)) {
  433. include $lang_file;
  434. }
  435. } else {
  436. // if the sub-languages feature is not on, then just load the
  437. // set language interface
  438. // include English
  439. include $langpath.'english/trad4all.inc.php';
  440. // prepare string for current language
  441. $langfile = $langpath.$language_interface.'/trad4all.inc.php';
  442. if (file_exists($langfile)) {
  443. include $langfile;
  444. }
  445. }
  446. // include the local (contextual) parameters of this course or section
  447. require $includePath.'/local.inc.php';
  448. // The global variable $text_dir has been defined in the language file trad4all.inc.php.
  449. // For determining text direction correspondent to the current language
  450. // we use now information from the internationalization library.
  451. $text_dir = api_get_text_direction();
  452. // ===== "who is logged in?" module section =====
  453. // check and modify the date of user in the track.e.online table
  454. if (!$x = strpos($_SERVER['PHP_SELF'], 'whoisonline.php')) {
  455. preventMultipleLogin($_user["user_id"]);
  456. LoginCheck(isset($_user['user_id']) ? $_user['user_id'] : '');
  457. }
  458. // ===== end "who is logged in?" module section =====
  459. //Update of the logout_date field in the table track_e_login
  460. // (needed for the calculation of the total connection time)
  461. if (!isset($_SESSION['login_as']) && isset($_user)) {
  462. // if $_SESSION['login_as'] is set, then the user is an admin logged as the user
  463. $tbl_track_login = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
  464. $sql = "SELECT login_id, login_date
  465. FROM $tbl_track_login
  466. WHERE
  467. login_user_id='".$_user["user_id"]."'
  468. ORDER BY login_date DESC
  469. LIMIT 0,1";
  470. $q_last_connection = Database::query($sql);
  471. if (Database::num_rows($q_last_connection) > 0) {
  472. $i_id_last_connection = Database::result($q_last_connection, 0, 'login_id');
  473. // is the latest logout_date still relevant?
  474. $sql = "SELECT logout_date FROM $tbl_track_login
  475. WHERE login_id = $i_id_last_connection";
  476. $q_logout_date = Database::query($sql);
  477. $res_logout_date = convert_sql_date(Database::result($q_logout_date, 0, 'logout_date'));
  478. if ($res_logout_date < time() - $_configuration['session_lifetime']) {
  479. // it isn't, we should create a fresh entry
  480. Event::event_login($_user['user_id']);
  481. // now that it's created, we can get its ID and carry on
  482. $i_id_last_connection = Database::result($q_last_connection, 0, 'login_id');
  483. }
  484. $now = api_get_utc_datetime(time());
  485. $sql = "UPDATE $tbl_track_login SET logout_date = '$now'
  486. WHERE login_id='$i_id_last_connection'";
  487. Database::query($sql);
  488. $tableUser = Database::get_main_table(TABLE_MAIN_USER);
  489. $sql = "UPDATE $tableUser SET last_login = '$now'
  490. WHERE user_id = ".$_user["user_id"];
  491. Database::query($sql);
  492. }
  493. }
  494. // Add language_measure_frequency to your main/inc/conf/configuration.php in
  495. // order to generate language variables frequency measurements (you can then
  496. // see them through main/cron/lang/langstats.php)
  497. // The langstat object will then be used in the get_lang() function.
  498. // This block can be removed to speed things up a bit as it should only ever
  499. // be used in development versions.
  500. if (isset($_configuration['language_measure_frequency']) &&
  501. $_configuration['language_measure_frequency'] == 1
  502. ) {
  503. require_once api_get_path(SYS_CODE_PATH).'/cron/lang/langstats.class.php';
  504. $langstats = new langstats();
  505. }
  506. //Default quota for the course documents folder
  507. $default_quota = api_get_setting('default_document_quotum');
  508. //Just in case the setting is not correctly set
  509. if (empty($default_quota)) {
  510. $default_quota = 100000000;
  511. }
  512. define('DEFAULT_DOCUMENT_QUOTA', $default_quota);
  513. // Forcing PclZip library to use a custom temporary folder.
  514. define('PCLZIP_TEMPORARY_DIR', api_get_path(SYS_ARCHIVE_PATH));