123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556 |
- <?php
- class SubLanguageManager
- {
-
- public function __construct()
- {
- }
-
- public static function getAllLanguages($onlyActive = false)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT * FROM '.$table;
- if ($onlyActive) {
- $sql .= ' WHERE available = 1';
- }
- $rs = Database::query($sql);
- $all_languages = [];
- while ($row = Database::fetch_array($rs, 'ASSOC')) {
- $all_languages[$row['dokeos_folder']] = $row;
- }
- return $all_languages;
- }
-
- public static function get_lang_folder_files_list($path, $only_main_name = false)
- {
- $content_dir = [];
- if (is_dir($path)) {
- if ($dh = opendir($path)) {
- while (($file = readdir($dh)) !== false) {
- if ($file[0] != '.' && substr($file, -4, strlen($file)) == '.php') {
- if ($only_main_name) {
- if ($file != '' && strpos($file, '.inc.php')) {
- $content_dir[] = substr($file, 0, strpos($file, '.inc.php'));
- }
- } else {
- $content_dir[] = $file;
- }
- }
- }
- }
- closedir($dh);
- }
- return $content_dir;
- }
-
- public static function get_all_information_of_sub_language($parent_id, $sub_language_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $parent_id = intval($parent_id);
- $sub_language_id = intval($sub_language_id);
- $sql = "SELECT * FROM $table
- WHERE
- parent_id = $parent_id AND
- id = $sub_language_id";
- $rs = Database::query($sql);
- $all_information = [];
- while ($row = Database::fetch_array($rs, 'ASSOC')) {
- $all_information = $row;
- }
- return $all_information;
- }
-
- public static function get_all_information_of_language($parent_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT * FROM '.$table.' WHERE id = "'.intval($parent_id).'"';
- $rs = Database::query($sql);
- $all_information = [];
- while ($row = Database::fetch_array($rs, 'ASSOC')) {
- $all_information = $row;
- }
- return $all_information;
- }
-
- public static function get_all_language_variable_in_file($system_path_file, $get_as_string_index = false)
- {
- $res_list = [];
- if (!is_readable($system_path_file)) {
- return $res_list;
- }
- $info_file = file($system_path_file);
- foreach ($info_file as $line) {
- if (substr($line, 0, 1) != '$') {
- continue;
- }
- list($var, $val) = explode('=', $line, 2);
- $var = trim($var);
- $val = trim($val);
- if ($get_as_string_index) {
- $var = substr($var, 1);
- }
- $res_list[$var] = $val;
- }
- return $res_list;
- }
-
- public static function add_file_in_language_directory($system_path_file)
- {
- $return_value = @file_put_contents($system_path_file, '<?php'.PHP_EOL);
- return $return_value;
- }
-
- public static function write_data_in_file($path_file, $new_term, $new_variable)
- {
- $return_value = false;
- $new_data = $new_variable.'='.$new_term;
- $resource = @fopen($path_file, "a");
- if (file_exists($path_file) && $resource) {
- if (fwrite($resource, $new_data.PHP_EOL) === false) {
-
- $return_value = false;
- } else {
- $return_value = true;
- }
- fclose($resource);
- }
- return $return_value;
- }
-
- public static function add_language_directory($sub_language_dir)
- {
- if (empty($sub_language_dir)) {
- return false;
- }
- $dir = api_get_path(SYS_LANG_PATH).$sub_language_dir;
- if (is_dir($dir)) {
- return true;
- }
- return @mkdir($dir, api_get_permissions_for_new_directories());
- }
-
- public static function remove_sub_language($parent_id, $sub_language_id)
- {
- if (empty($parent_id) ||
- (intval($parent_id) != $parent_id) ||
- empty($sub_language_id) ||
- (intval($sub_language_id) != $sub_language_id)
- ) {
- return false;
- }
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT dokeos_folder FROM '.$table.'
- WHERE parent_id = '.$parent_id.' and id = '.$sub_language_id;
- $res = Database::query($sql);
- if ($res === false or Database::num_rows($res) < 1) {
- return false;
- }
- $row = Database::fetch_assoc($res);
- $res = self::remove_language_directory($row['dokeos_folder']);
- if ($res === false) {
- return false;
- }
- $sql = 'DELETE FROM '.$table.'
- WHERE id= '.intval($sub_language_id);
- $res = Database::query($sql);
- return $res;
- }
-
- public static function remove_language_directory($sub_language_dir)
- {
- if (empty($sub_language_dir)) {
- return false;
- }
- $dir = api_get_path(SYS_LANG_PATH).$sub_language_dir;
- if (!is_dir($dir)) {
- return true;
- }
- $content = self::get_lang_folder_files_list($dir);
- if (count($content) > 0) {
- foreach ($content as $value_content) {
- $path_file = $dir.'/'.$value_content;
- unlink($path_file);
- }
- return @rmdir($dir);
- } else {
- return @rmdir($dir);
- }
- }
-
- public static function check_if_exist_language_by_id($language_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT count(*) as count
- FROM '.$table.'
- WHERE id="'.intval($language_id).'"';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- if (Database::result($rs, 0, 'count') == 1) {
- return true;
- } else {
- return false;
- }
- } else {
- return false;
- }
- }
-
- public static function get_name_of_language_by_id($language_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $language_id = intval($language_id);
- $sql = "SELECT original_name
- FROM $table
- WHERE id = $language_id";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- return Database::result($rs, 0, 'original_name');
- } else {
- return '';
- }
- }
-
- public static function check_if_language_is_sub_language($language_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT count(*) AS count FROM '.$table.'
- WHERE id = '.intval($language_id).' AND NOT ISNULL(parent_id)';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0 && Database::result($rs, '0', 'count') == 1) {
- return true;
- } else {
- return false;
- }
- }
-
- public static function check_if_language_is_used($language_id)
- {
- $language_info = self::get_all_information_of_language($language_id);
- $table = Database::get_main_table(TABLE_MAIN_USER);
- $sql = 'SELECT count(*) AS count FROM '.$table.'
- WHERE language ="'.Database::escape_string($language_info['english_name']).'"';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0 && Database::result($rs, '0', 'count') >= 1) {
- return true;
- } else {
- return false;
- }
- }
-
- public static function check_if_language_is_father($language_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = 'SELECT count(*) AS count FROM '.$table.'
- WHERE parent_id= '.intval($language_id).' AND NOT ISNULL(parent_id);';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0 && Database::result($rs, '0', 'count') == 1) {
- return true;
- } else {
- return false;
- }
- }
-
- public static function make_unavailable_language($language_id)
- {
- $tbl_admin_languages = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = "UPDATE $tbl_admin_languages SET available='0'
- WHERE id = ".intval($language_id)."";
- $result = Database::query($sql);
- return $result !== false;
- }
-
- public static function make_available_language($language_id)
- {
- $tbl_admin_languages = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = "UPDATE $tbl_admin_languages SET available='1'
- WHERE id = ".intval($language_id)."";
- $result = Database::query($sql);
- return $result !== false;
- }
-
- public static function set_platform_language($language_id)
- {
- if (empty($language_id) || (intval($language_id) != $language_id)) {
- return false;
- }
- $language_id = intval($language_id);
- $tbl_admin_languages = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $tbl_settings_current = Database::get_main_table(TABLE_MAIN_SETTINGS_CURRENT);
- $sql = "SELECT english_name FROM $tbl_admin_languages
- WHERE id = $language_id";
- $result = Database::query($sql);
- $lang = Database::fetch_array($result);
- $sql_update_2 = "UPDATE $tbl_settings_current SET selected_value = '".$lang['english_name']."'
- WHERE variable='platformLanguage'";
- $result_2 = Database::query($sql_update_2);
- Event::addEvent(
- LOG_PLATFORM_LANGUAGE_CHANGE,
- LOG_PLATFORM_LANGUAGE,
- $lang['english_name']
- );
- return $result_2 !== false;
- }
-
- public static function get_platform_language_id()
- {
- $name = api_get_setting('platformLanguage');
- $tbl_admin_languages = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = "SELECT id FROM $tbl_admin_languages WHERE english_name ='$name'";
- $res = Database::query($sql);
- if (Database::num_rows($res) < 1) {
- return false;
- }
- $row = Database::fetch_array($res);
- return (int) $row['id'];
- }
-
- public static function get_parent_language_path($language_path)
- {
- $tbl_admin_languages = Database::get_main_table(TABLE_MAIN_LANGUAGE);
- $sql = "SELECT dokeos_folder
- FROM ".$tbl_admin_languages."
- WHERE id = (
- SELECT parent_id FROM ".$tbl_admin_languages."
- WHERE dokeos_folder = '".Database::escape_string($language_path)."'
- )
- ";
- $result = Database::query($sql);
- if (Database::num_rows($result) == 0) {
- return null;
- }
- $row = Database::fetch_array($result);
- return $row['dokeos_folder'];
- }
-
- public static function getLanguageFromIsocode($isocode)
- {
- $isocode = Database::escape_string($isocode);
- $adminLanguagesTable = Database::get_main_table(TABLE_MAIN_LANGUAGE);
-
- $sql = "SELECT english_name
- FROM ".$adminLanguagesTable."
- WHERE
- isocode ='$isocode' AND
- available = 1
- ORDER BY id
- DESC LIMIT 1";
- $res = Database::query($sql);
- if (Database::num_rows($res) < 1) {
- return false;
- }
- $row = Database::fetch_assoc($res);
- return $row['english_name'];
- }
-
- public static function getLanguageFromBrowserPreference($preferences)
- {
- if (empty($preferences)) {
- return false;
- }
- $preferencesArray = explode(',', $preferences);
- if (count($preferencesArray) > 0) {
- foreach ($preferencesArray as $pref) {
- $s = strpos($pref, ';');
- if ($s >= 2) {
- $code = substr($pref, 0, $s);
- } else {
- $code = $pref;
- }
- $name = self::getLanguageFromIsocode($code);
- if ($name !== false) {
- return $name;
- }
- }
- }
- return false;
- }
- }
|