You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
242 lines
9.0 KiB
242 lines
9.0 KiB
<?php
|
|
/* For licensing terms, see /dokeos_license.txt */
|
|
/**
|
|
==================================================================================
|
|
@author Isaac flores paz <florespaz@bidsoftperu.com> - Added 9 july of 2009
|
|
==================================================================================
|
|
*/
|
|
/*
|
|
==============================================================================
|
|
Class SubLanguageManager
|
|
==============================================================================
|
|
*/
|
|
class SubLanguageManager {
|
|
|
|
private function __construct() {
|
|
//void
|
|
}
|
|
/**
|
|
* Get all data of dokeos folder (forum.inc.php,gradebook.inc.php,notebook.inc.php)
|
|
* @param String The dokeos path folder (/var/www/my_dokeos/main/lang/spanish)
|
|
* @param bool true if we only want the "subname" trad4all instead of trad4all.inc.php
|
|
* @return Array All file of dokeos folder
|
|
*
|
|
*/
|
|
public static function get_all_data_of_dokeos_folder ($dokeos_path_folder,$only_main_name=false) {
|
|
$content_dir=array();
|
|
if (is_dir($dokeos_path_folder)) {
|
|
if ($dh = opendir($dokeos_path_folder)) {
|
|
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;
|
|
}
|
|
}
|
|
/**
|
|
* Get all information of sub-language
|
|
* @param Integer The parent id(Language father id)
|
|
* @param Integer The sub language id
|
|
* @return Array All information about sub-language
|
|
*/
|
|
public static function get_all_information_of_sub_language ($parent_id,$sub_language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT * FROM '.$tbl_admin_languages.' WHERE parent_id="'.Database::escape_string($parent_id).'" AND id="'.Database::escape_string($sub_language_id).'"';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
$all_information=array();
|
|
while ($row=Database::fetch_array($rs,'ASSOC')) {
|
|
$all_information=$row;
|
|
}
|
|
return $all_information;
|
|
}
|
|
/**
|
|
* Get all information of language
|
|
* @param Integer The parent id(Language father id)
|
|
* @return Array All information about language
|
|
*/
|
|
public static function get_all_information_of_language ($parent_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT * FROM '.$tbl_admin_languages.' WHERE id="'.Database::escape_string($parent_id).'"';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
$all_information=array();
|
|
while ($row=Database::fetch_array($rs,'ASSOC')) {
|
|
$all_information=$row;
|
|
}
|
|
return $all_information;
|
|
}
|
|
/**
|
|
* Get all information of dokeos file
|
|
* @param String The dokeos path file (/var/www/my_dokeos/main/lang/spanish/gradebook.inc.php)
|
|
* @return Array Contains all information of dokeos file
|
|
*/
|
|
public static function get_all_language_variable_in_file ($dokeos_path_file) {
|
|
$info_file=file($dokeos_path_file);
|
|
foreach ($info_file as $line) {
|
|
if (substr($line,0,1)!='$') { continue; }
|
|
list($var,$val) = split('=',$line,2);
|
|
$var = trim($var); $val = trim($val);
|
|
$res_list[$var] = $val;
|
|
}
|
|
return $res_list;
|
|
}
|
|
|
|
/**
|
|
* Add file in sub-language directory and add header(tag php)
|
|
* @param String The dokeos path file (/var/www/my_dokeos/main/lang/spanish/gradebook.inc.php)
|
|
* @return void()
|
|
*/
|
|
public static function add_file_in_language_directory ($dokeos_path_file) {
|
|
file_put_contents($dokeos_path_file,'<?php'.PHP_EOL);
|
|
}
|
|
/**
|
|
* Write in file of sub-language
|
|
* @param String The path file (/var/www/my_dokeos/main/lang/spanish/gradebook.inc.php)
|
|
* @param String The new sub-language
|
|
* @param String The language variable
|
|
* @return void()
|
|
*/
|
|
public static function write_data_in_file ($path_file,$new_sub_language,$variable_sub_language) {
|
|
$new_data=$variable_sub_language.'='.$new_sub_language;
|
|
$g_open_file = fopen($path_file, "a");
|
|
if (fwrite($g_open_file, $new_data.PHP_EOL) === false) {
|
|
//not allow to write
|
|
}
|
|
fclose($g_open_file);
|
|
}
|
|
/**
|
|
* Add directory for sub-language
|
|
* @param String The sub-language path directory ( /var/www/my_dokeos/main/lang/spanish_corporate )
|
|
* @return boolean
|
|
*/
|
|
public static function add_directory_of_sub_language($path_sub_language) {
|
|
$rs=@mkdir($path_sub_language,0777);
|
|
if ($rs) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
/**
|
|
* Delete sub-language
|
|
* @param Integer The parent id
|
|
* @return void()
|
|
*/
|
|
public static function removed_sub_language ($parent_id,$sub_language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='DELETE FROM '.$tbl_admin_languages.' WHERE parent_id="'.Database::escape_string($parent_id).'" AND id="'.Database::escape_string($sub_language_id).'" ';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
}
|
|
/**
|
|
* check if language exist by id
|
|
* @param Integer The language id
|
|
* @return Boolean
|
|
*/
|
|
public static function check_if_exist_language_by_id ($language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT count(*) as count FROM '.$tbl_admin_languages.' WHERE id="'.Database::escape_string($language_id).'"';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
if (Database::num_rows($rs)>0) {
|
|
if (Database::result($rs,0,'count') ==1) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
} else {
|
|
return false;;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get name of language by id
|
|
* @param Integer The language id
|
|
* @return String The original name of language
|
|
*/
|
|
public static function get_name_of_language_by_id ($language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT original_name FROM '.$tbl_admin_languages.' WHERE id="'.Database::escape_string($language_id).'"';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
if (Database::num_rows($rs)>0) {
|
|
return Database::result($rs,0,'original_name');
|
|
} else {
|
|
return '';
|
|
}
|
|
|
|
}
|
|
/**
|
|
* Verified if language is sub-language
|
|
* @param Integer The language id
|
|
* @return Boolean
|
|
*/
|
|
public static function check_if_language_is_sub_language ($language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT count(*) AS count FROM '.$tbl_admin_languages.' WHERE id="'.Database::escape_string($language_id).'" AND NOT ISNULL(parent_id)';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
|
|
if (Database::num_rows($rs)>0 && Database::result($rs,'0','count')==1) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
/**
|
|
* Verified if language is father of an sub-language
|
|
* @param Integer The language id
|
|
* @return Boolean
|
|
*/
|
|
public static function check_if_language_is_father ($language_id) {
|
|
$tbl_admin_languages = Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql='SELECT count(*) AS count FROM '.$tbl_admin_languages.' WHERE parent_id="'.Database::escape_string($language_id).'" AND NOT ISNULL(parent_id);';
|
|
$rs=Database::query($sql,__FILE__,__LINE__);
|
|
|
|
if (Database::num_rows($rs)>0 && Database::result($rs,'0','count')==1) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
/**
|
|
* Make unavailable the language
|
|
* @param Integer The language id
|
|
* @return void()
|
|
*/
|
|
public static function make_unavailable_language ($language_id) {
|
|
$tbl_admin_languages= Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql_make_unavailable = "UPDATE $tbl_admin_languages SET available='0' WHERE id='".Database::escape_string($language_id)."'";
|
|
$result = Database::query($sql_make_unavailable,__FILE__,__LINE__);
|
|
}
|
|
/**
|
|
* Make available the language
|
|
* @param Integer The language id
|
|
* @return void()
|
|
*/
|
|
public static function make_available_language ($language_id) {
|
|
$tbl_admin_languages= Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$sql_make_available = "UPDATE $tbl_admin_languages SET available='1' WHERE id='".Database::escape_string($language_id)."'";
|
|
$result = Database::query($sql_make_available,__FILE__,__LINE__);
|
|
}
|
|
/**
|
|
* Set platform language
|
|
* @param Integer The language id
|
|
* @return void()
|
|
*/
|
|
public static function set_platform_language ($language_id) {
|
|
$tbl_admin_languages= Database :: get_main_table(TABLE_MAIN_LANGUAGE);
|
|
$tbl_settings_current = Database :: get_main_table(TABLE_MAIN_SETTINGS_CURRENT);
|
|
$sql_update = "SELECT english_name FROM ". $tbl_admin_languages." WHERE id='".Database::escape_string($language_id)."'";
|
|
$result = Database::query($sql_update,__FILE__,__LINE__);
|
|
$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);
|
|
}
|
|
}
|
|
?>
|