@ -25,23 +25,22 @@ 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/**  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*	@package dokeos.main  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					* 	@author Patrick Cool < patrick.cool @ UGent . be > , Ghent University, Refactoring  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					* 	@version $Id: index.php 22368 2009-07-24 23:25:57Z iflorespaz $  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*   @todo check the different @todos in this page and really do them  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					* 	@todo check if the news management works as expected  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 *	@package dokeos.main  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 *	@author Patrick Cool < patrick.cool @ UGent . be > , Ghent University, Refactoring  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 *	@version $Id: index.php 22368 2009-07-24 23:25:57Z iflorespaz $  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 *	@todo check the different @todos in this page and really do them  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 *	@todo check if the news management works as expected  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// only this script should have this constant defined. This is used to activate the javascript that  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// gives the login name automatic focus in header.inc.html.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/** @todo   Couldn't this be done using the $HtmlHeadXtra array? */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/** @todo Couldn't this be done using the $HtmlHeadXtra array? */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					define('DOKEOS_HOMEPAGE', true);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// the language file  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$language_file = array ('courses', 'index');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/* Flag forcing the 'current course' reset, as we're not inside a course anymore   */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/* Flag forcing the 'current course' reset, as we're not inside a course anymore */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// maybe we should change this into an api function? an example: Coursemanager::unset();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$cidReset = true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -51,35 +50,40 @@ $cidReset = true; 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						Included libraries  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					-----------------------------------------------------------  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/** @todo make all the library files consistent, use filename.lib.php and not filename.lib.inc.php */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					require_once ( 'main/inc/global.inc.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'course.lib.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'debug.lib.inc.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'events.lib.inc.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'system_announcements.lib.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'groupmanager.lib.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once ( api_get_path(LIBRARY_PATH).'formvalidator/FormValidator.class.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					require_once 'main/inc/global.inc.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'course.lib.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'debug.lib.inc.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'events.lib.inc.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'system_announcements.lib.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'groupmanager.lib.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					include_once api_get_path(LIBRARY_PATH).'formvalidator/FormValidator.class.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					require_once 'main/chat/chat_functions.lib.php';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$loginFailed = isset($_GET['loginFailed']) ? true : isset($loginFailed);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$setting_show_also_closed_courses = ( api_get_setting('show_closed_courses')=='true') ? true : false ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$setting_show_also_closed_courses = api_get_setting('show_closed_courses')  ==  'true';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// the section (for the tabs)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$this_section = SECTION_CAMPUS;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/*  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					-----------------------------------------------------------  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						Action Handling  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					-----------------------------------------------------------  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/** @todo 	wouldn't it make more sense if this would be done in local.inc.php so that local.inc.php become the only place where authentication is done?  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/** @todo 	Wouldn't it make more sense if this would be done in local.inc.php so that local.inc.php become the only place where authentication is done?  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * 			by doing this you could logout from any page instead of only from index.php. From the moment there is a logout=true in the url you will be logged out  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * 			this can be usefull when you are on an open course and you need to log in to edit something and you immediately want to check how anonymous users  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * 			will see it.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					  $my_user_id=api_get_user_id(); 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$my_user_id  =  api_get_user_id();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (!empty($_GET['logout'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						logout();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/*  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					-----------------------------------------------------------  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						Table definitions  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -103,12 +107,12 @@ if (isset($_user['user_id'])) { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$nameTools = api_get_setting('siteName');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/*  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					==============================================================================  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							LOGIN  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					==============================================================================  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/**  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * @todo This piece of code should probably move to local.inc.php where the actual login / logout procedure is handled.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * @todo consider removing this piece of code because does nothing.  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -119,11 +123,13 @@ if (isset($_GET['submitAuth']) && $_GET['submitAuth'] == 1) { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						session_destroy();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						die();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					//Delete session neccesary for legal terms  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (api_get_setting('allow_terms_conditions')=='true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						unset($_SESSION['update_term_and_condition']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						unset($_SESSION['info_current_user']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/**  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * @todo This piece of code should probably move to local.inc.php where the actual login procedure is handled.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * @todo check if this code is used. I think this code is never executed because after clicking the submit button  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -131,31 +137,32 @@ if (api_get_setting('allow_terms_conditions')=='true') { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * 		 on api_get_setting('page_after_login')  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 */  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (!empty($_POST["submitAuth" ])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (!empty($_POST['submitAuth' ])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// the user is already authenticated, we now find the last login of the user.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (isset ($_user['user_id'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$sql_last_login = "SELECT UNIX_TIMESTAMP(login_date)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													FROM $track_login_table  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													WHERE login_user_id = '".$_user['user_id']."'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													ORDER BY login_date DESC LIMIT 1";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$result_last_login = api_sql_ query($sql_last_login, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (!$result_last_login)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$result_last_login = Database:: query($sql_last_login, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (!$result_last_login) {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if (Database::num_rows($result_last_login) > 0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$user_last_login_datetime = Database::fetch_array($result_last_login);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$user_last_login_datetime = $user_last_login_datetime[0];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									api_session_register('user_last_login_datetime');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							mysql_free_result($result_last_login);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							//event_login();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (api_is_platform_admin()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								// decode all open event informations and fill the track_c_* tables  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include (api_get_path(LIBRARY_PATH)."stats.lib.inc.php") ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include api_get_path(LIBRARY_PATH).'stats.lib.inc.php' ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								decodeOpenInfos();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					} // end login -- if($_POST["submitAuth" ])  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					} // end login -- if ($_POST['submitAuth' ])  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// only if login form was not sent because if the form is sent the user was already on the page.  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -170,6 +177,7 @@ Display :: display_header('', 'dokeos'); 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							MAIN CODE  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					==============================================================================  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					echo '< div  class = "maincontent"  id = "content" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// Plugins for loginpage_main AND campushomepage_main  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -179,17 +187,17 @@ if (!api_get_user_id()) { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						api_plugin('campushomepage_main');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$home= 'home/';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if ($_configuration['multiple_access_urls']==true ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$home  = 'home/';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if ($_configuration['multiple_access_urls']) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$access_url_id = api_get_current_access_url_id();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($access_url_id != -1){  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$url_info = api_get_access_url($access_url_id);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							// "http://" and the final "/" replaced  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$url = substr($url_info['url'],7,strlen($url_info['url'])-8);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$url = substr($url_info['url'],  7,  strlen($url_info['url'])  -  8);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$clean_url = replace_dangerous_char($url);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$clean_url = str_replace('/','-',$clean_url);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$clean_url = str_replace('/',  '-',  $clean_url);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$clean_url = $clean_url.'/';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$home_old   = 'home/';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$home_old = 'home/';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$home= 'home/'.$clean_url;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -197,35 +205,35 @@ if ($_configuration['multiple_access_urls']==true) { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					// Including the page for the news  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					$page_included = false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (!empty  ($_GET['include']) & &  preg_match('/^[a-zA-Z0-9_-]*\.html$/',$_GET['include'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						include ( './'.$home.$_GET['include']) ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					if (!empty($_GET['include']) & &  preg_match('/^[a-zA-Z0-9_-]*\.html$/',  $_GET['include'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						include './'.$home.$_GET['include'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$page_included = true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!empty($_SESSION['user_language_choice'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language=$_SESSION['user_language_choice'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} elseif(!empty($_SESSION['_user']['language'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language=$_SESSION['_user']['language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language  =  $_SESSION['user_language_choice'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} elseif  (!empty($_SESSION['_user']['language'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language  =  $_SESSION['_user']['language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language=api_get_setting('platformLanguage');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language  =  api_get_setting('platformLanguage');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if(!file_exists($home.'home_news_'.$user_selected_language.'.html')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_top.html'))  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp=file($home.'home_top.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp=file($home_old.'home_top.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if  (!file_exists($home.'home_news_'.$user_selected_language.'.html')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_top.html')) {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp  =  file($home.'home_top.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp  =  file($home_old.'home_top.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$home_top_temp=implode('',$home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$open=str_replace('{rel_path}',api_get_path(REL_PATH),$home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$home_top_temp  =  implode('',  $home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$open  =  str_replace('{rel_path}',  api_get_path(REL_PATH),  $home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo $open;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if(file_exists($home.'home_top_'.$user_selected_language.'.html')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if  (file_exists($home.'home_top_'.$user_selected_language.'.html')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp = file_get_contents($home.'home_top_'.$user_selected_language.'.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$home_top_temp = file_get_contents($home.'home_top.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$open=str_replace('{rel_path}',api_get_path(REL_PATH),$home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$open  =  str_replace('{rel_path}',  api_get_path(REL_PATH),  $home_top_temp);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo $open;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
	
		
			
				
					
						
							
								 
							 
						
						
							
								 
							 
						
						
					 
				
				 
				 
				
					@ -272,10 +280,10 @@ function logout() 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $_configuration, $extAuthSource;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// variable initialisation  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$query_string='';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$query_string  =  '';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!empty($_SESSION['user_language_choice'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$query_string='?language='.$_SESSION['user_language_choice'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$query_string  =  '?language='.$_SESSION['user_language_choice'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// Database table definition  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -283,16 +291,16 @@ function logout() 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// selecting the last login of the user  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$uid = intval($_GET['uid']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_last_connection="SELECT login_id, login_date FROM $tbl_track_login WHERE login_user_id='$uid' ORDER BY login_date DESC LIMIT 0,1";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$q_last_connection=api_sql_query($sql_last_connection );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (Database::num_rows($q_last_connection)>0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$i_id_last_connection=Database::result($q_last_connection,0,"login_id" );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_last_connection  =  "SELECT login_id, login_date FROM $tbl_track_login WHERE login_user_id='$uid' ORDER BY login_date DESC LIMIT 0,1";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$q_last_connection = Database::query($sql_last_connection, __FILE__, __LINE__ );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (Database::num_rows($q_last_connection)  >  0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$i_id_last_connection = Database::result($q_last_connection, 0, 'login_id' );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!isset($_SESSION['login_as'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$current_date=date('Y-m-d H:i:s',time());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$s_sql_update_logout_date="UPDATE $tbl_track_login SET logout_date='".$current_date."' WHERE login_id='$i_id_last_connection'";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							api_sql_query($s_sql_update_logout_date );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$current_date  =  date('Y-m-d H:i:s',  time());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$s_sql_update_logout_date  =  "UPDATE $tbl_track_login SET logout_date='".$current_date."' WHERE login_id='$i_id_last_connection'";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							Database::query($s_sql_update_logout_date, __FILE__, __LINE__ );  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						LoginDelete($uid, $_configuration['statistics_database']); //from inc/lib/online.inc.php - removes the "online" status  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -306,7 +314,7 @@ function logout() 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (is_array($extAuthSource[$uinfo['auth_source']])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$subarray = $extAuthSource[$uinfo['auth_source']];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if (!empty($subarray['logout']) & &  file_exists($subarray['logout'])) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									include_once($subarray['logout']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									include_once  ($subarray['logout']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$logout_function = $uinfo['auth_source'].'_logout';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (function_exists($logout_function)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$logout_function($uinfo);  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -329,19 +337,19 @@ function logout() 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					function category_has_open_courses($category) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $setting_show_also_closed_courses;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_identified = (api_get_user_id()>0 & &  !api_is_anonymous());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_identified = (api_get_user_id()  >  0 & &  !api_is_anonymous());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$main_course_table = Database :: get_main_table(TABLE_MAIN_COURSE);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_query = "SELECT * FROM $main_course_table WHERE category_code='$category'";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_result = api_sql_ query($sql_query, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_result = Database:: query($sql_query, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						while ($course = Database::fetch_array($sql_result)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($setting_show_also_closed_courses == false ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ((api_get_user_id()>0  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									and  $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									or  ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (! $setting_show_also_closed_courses) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ((api_get_user_id()  >  0  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									& &   $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									||  ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									return true; //at least one open course  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else   {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if(isset($course['visibility'])){  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if  (isset($course['visibility'])){  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									return true; //at least one course (does not matter weither it's open or not because $setting_show_also_closed_courses = true  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
	
		
			
				
					
						
							
								 
							 
						
						
							
								 
							 
						
						
					 
				
				 
				 
				
					@ -369,7 +377,7 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$platformLanguage = api_get_setting('platformLanguage');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ( !($_user['user_id']) or api_is_anonymous($_user['user_id']) ) {   // only display if the user isn't logged in  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!($_user['user_id']) || api_is_anonymous($_user['user_id']) ) {  // only display if the user isn't logged in  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							api_display_language_form(true);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< br  / > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							display_login_form();  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -378,7 +386,7 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo '< br  / > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								handle_login_failed();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (api_get_setting('allow_lostpassword') == 'true' OR  api_get_setting('allow_registration') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (api_get_setting('allow_lostpassword') == 'true' ||  api_get_setting('allow_registration') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo '< div  class = "menusection" > < span  class = "menusectioncaption" > '.get_lang('MenuUser').'< / span > < ul  class = "menulist" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if (api_get_setting('allow_registration') < > 'false') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									echo '< li > < a  href = "main/auth/inscription.php" > '.get_lang('Reg').'< / a > < / li > ';  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -397,29 +405,28 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// My Account section  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (isset($_SESSION['_user']['user_id']) & &  $_SESSION['_user']['user_id']!=0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (isset($_SESSION['_user']['user_id']) & &  $_SESSION['_user']['user_id']  !=  0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							// tabs that are deactivated are added here  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_menu=false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_create_link=false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_course_link=false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_menu = false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_create_link = false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$show_course_link = false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$display_add_course_link = api_is_allowed_to_create_course() & &  ($_SESSION["studentview"] != "studentenview");  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($display_add_course_link) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								//display_create_course_link();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$show_menu=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$show_create_link=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$show_menu  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$show_create_link  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (api_is_platform_admin() || api_is_course_admin() || api_is_allowed_to_create_course()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_menu=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_course_link=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_menu  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_course_link  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if (api_get_setting('allow_students_to_browse_courses')=='true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_menu=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_course_link=true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if (api_get_setting('allow_students_to_browse_courses')  ==  'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_menu  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$show_course_link  =  true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -427,10 +434,12 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< div  class = \"menusection\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< span  class = \"menusectioncaption\" > ".get_lang("MenuUser")."< / span > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< ul  class = \"menulist\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($show_create_link)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($show_create_link) {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									display_create_course_link();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($show_course_link)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($show_course_link) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									display_edit_course_list_links();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< / ul > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< / div > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -439,8 +448,8 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< div  class = \"menusection\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< span  class = \"menusectioncaption\" > ".get_lang("MainNavigation")."< / span > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								echo "< ul  class = \"menulist\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								foreach($menu_navigation as $section => $navigation_info) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$current = ( $section == $GLOBALS['this_section'] ? ' id="current"' : '') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								foreach  ($menu_navigation as $section => $navigation_info) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$current = $section == $GLOBALS['this_section'] ? ' id="current"' : '';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									echo '< li ' . $ current . ' > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									echo '< a  href = "'.$navigation_info['url'].'"  target = "_self" > '.$navigation_info['title'].'< / a > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									echo '< / li > ';  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -452,33 +461,29 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// help section  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						/*** hide right menu "general" and other parts on anonymous right menu   *****/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						/*** hide right menu "general" and other parts on anonymous right menu *****/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_selected_language = api_get_interface_language();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $home, $home_old;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!isset ($user_selected_language))  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!isset($user_selected_language)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$user_selected_language = $platformLanguage;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!file_exists($home.'home_menu_'.$user_selected_language.'.html') & &  file_exists($home.'home_menu.html') & &  file_get_contents($home.'home_menu.html')!='')  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!file_exists($home.'home_menu_'.$user_selected_language.'.html') & &  file_exists($home.'home_menu.html') & &  file_get_contents($home.'home_menu.html') != '') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo "< div  class = \"menusection\" > ", "< span  class = \"menusectioncaption\" > ".get_lang("MenuGeneral")."< / span > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						 	echo "< ul  class = \"menulist\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_menu.html'))  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_menu.html')) {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include ($home.'home_menu.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include ($home_old.'home_menu.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / ul > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / div > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						elseif(file_exists($home.'home_menu_'.$user_selected_language.'.html') & &  file_get_contents($home.'home_menu_'.$user_selected_language.'.html')!='')  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						elseif(file_exists($home.'home_menu_'.$user_selected_language.'.html') & &  file_get_contents($home.'home_menu_'.$user_selected_language.'.html') != '') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo "< div  class = \"menusection\" > ", "< span  class = \"menusectioncaption\" > ".get_lang("MenuGeneral")."< / span > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						 	echo "< ul  class = \"menulist\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							include($home.'home_menu_'.$user_selected_language.'.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							include  ($home.'home_menu_'.$user_selected_language.'.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / ul > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / div > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -491,15 +496,16 @@ function display_anonymous_right_menu() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// includes for any files to be displayed below anonymous right menu  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!file_exists($home.'home_notice_'.$user_selected_language.'.html') & &  file_exists($home.'home_notice.html') & &  file_get_contents($home.'home_notice.html')!='') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (!file_exists($home.'home_notice_'.$user_selected_language.'.html') & &  file_exists($home.'home_notice.html') & &  file_get_contents($home.'home_notice.html')  !=  '') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< div  class = "note" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_notice.html'))  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if (file_exists($home.'home_notice.html')) {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include ($home.'home_notice.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								include ($home_old.'home_notice.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / div > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} elseif(file_exists($home.'home_notice_'.$user_selected_language.'.html') & &  file_get_contents($home.'home_notice_'.$user_selected_language.'.html')!='') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						elseif(file_exists($home.'home_notice_'.$user_selected_language.'.html') & &  file_get_contents($home.'home_notice_'.$user_selected_language.'.html') != '') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< div  class = "note" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							include($home.'home_notice_'.$user_selected_language.'.html');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< / div > ';  
				
			 
			
		
	
	
		
			
				
					
						
							
								 
							 
						
						
							
								 
							 
						
						
					 
				
				 
				 
				
					@ -528,16 +534,16 @@ function handle_login_failed() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									break;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								case 'account_expired':  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message=get_lang('AccountExpired');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message  =  get_lang('AccountExpired');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									break;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								case 'account_inactive':  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message=get_lang('AccountInactive');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message  =  get_lang('AccountInactive');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									break;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								case 'user_password_incorrect':  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message=get_lang('InvalidId');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message  =  get_lang('InvalidId');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									break;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								case 'access_url_inactive':  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message=get_lang('AccountURLInactive');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$message  =  get_lang('AccountURLInactive');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									break;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -548,20 +554,20 @@ function handle_login_failed() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*	Adds a form to let users login  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*	@version 1.1  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					*/  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					function display_login_form()  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					function display_login_form() {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form = new FormValidator('formLogin');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('text','login',get_lang('UserName'),array('size'=>17));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('password','password',get_lang('Pass'),array('size'=>17));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('style_submit_button','submitAuth',get_lang('langEnter'), array('class'=>'login'));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('text',  'login',  get_lang('UserName'),  array('size'  =>  17));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('password',  'password',  get_lang('Pass'),  array('size'  =>  17));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->addElement('style_submit_button','submitAuth',  get_lang('langEnter'), array('class'  =>  'login'));  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$renderer =&  $form->defaultRenderer();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$renderer->setElementTemplate('< div > < label > {label}< / label > < / div > < div > {element}< / div > ');  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$form->display();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (api_get_setting('openid_authentication')=='true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							include_once('main/auth/openid/login.php') ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (api_get_setting('openid_authentication')  ==  'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							include_once 'main/auth/openid/login.php' ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo '< div > '.openid_form().'< / div > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					/**  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 * Displays a link to the lost password section  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					 */  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -581,7 +587,7 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$stok = Security::get_token();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						//init  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_identified = (api_get_user_id()>0 & &  !api_is_anonymous());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_identified = (api_get_user_id()  >  0 & &  !api_is_anonymous());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$web_course_path = api_get_path(WEB_COURSE_PATH);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$category = Database::escape_string($_GET['category']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $setting_show_also_closed_courses;  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -599,18 +605,18 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						//showing only the courses of the current access_url_id  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $_configuration;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($_configuration['multiple_access_urls']==true) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($_configuration['multiple_access_urls']  ==  true) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$url_access_id = api_get_current_access_url_id();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($url_access_id !=-1) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$sql_get_course_list="SELECT * FROM $main_course_table as course INNER JOIN $tbl_url_rel_course as url_rel_course  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$sql_get_course_list  =  "SELECT * FROM $main_course_table as course INNER JOIN $tbl_url_rel_course as url_rel_course  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										ON (url_rel_course.course_code=course.code)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										WHERE access_url_id = $url_access_id AND category_code = '".Database::escape_string($_GET["category"])."' ORDER BY title, UPPER(visual_code)";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						//removed: AND cours.visibility='".COURSE_VISIBILITY_OPEN_WORLD."'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_result_courses = api_sql_ query($sql_get_course_list, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_result_courses = Database:: query($sql_get_course_list, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						while ($course_result = Database::fetch_array($sql_result_courses)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$course_list[] = $course_result;  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -621,13 +627,13 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if($user_identified) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($setting_show_also_closed_courses) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$platform_visible_courses = '';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else   {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$platform_visible_courses = "  AND (t3.visibility='".COURSE_VISIBILITY_OPEN_WORLD."' OR t3.visibility='".COURSE_VISIBILITY_OPEN_PLATFORM."' )";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($setting_show_also_closed_courses) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$platform_visible_courses = '';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else   {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$platform_visible_courses = "  AND (t3.visibility='".COURSE_VISIBILITY_OPEN_WORLD."' )";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -642,9 +648,9 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						//showing only the category of courses of the current access_url_id  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						global $_configuration;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($_configuration['multiple_access_urls']==true) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($_configuration['multiple_access_urls']  ==  true) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$url_access_id = api_get_current_access_url_id();  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($url_access_id !=-1) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							if ($url_access_id !=  -1) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$sqlGetSubCatList = "  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									SELECT t1.name,t1.code,t1.parent_id,t1.children_count,COUNT(DISTINCT t3.code) AS nbCourse  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -653,12 +659,12 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									LEFT JOIN $main_course_table t3 ON (t3.category_code=t1.code $platform_visible_courses)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									INNER JOIN $tbl_url_rel_course as url_rel_course  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										ON (url_rel_course.course_code=t3.code)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									WHERE access_url_id = $url_access_id AND t1.parent_id ".  (empty  ($category) ? "IS NULL" : "='$category'")."  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									WHERE access_url_id = $url_access_id AND t1.parent_id ".(empty($category) ? "IS NULL" : "='$category'")."  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									GROUP BY t1.name,t1.code,t1.parent_id,t1.children_count ORDER BY t1.tree_pos, t1.name";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$resCats = api_sql_ query($sqlGetSubCatList, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$resCats = Database:: query($sqlGetSubCatList, __FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$thereIsSubCat = false;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if (Database::num_rows($resCats) > 0) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$htmlListCat = "< h4  style = \"margin-top:  0px ; \ " > ".get_lang("CatList")."< / h4 > "."< ul > ";  
				
			 
			
		
	
	
		
			
				
					
						
							
								 
							 
						
						
							
								 
							 
						
						
					 
				
				 
				 
				
					@ -690,14 +696,14 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$htmlListCat .= $catLine['name'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$htmlListCat .= "< / li > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$thereIsSubCat = true;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}//else don't set thereIsSubCat to true to avoid printing things if not requested  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  //else don't set thereIsSubCat to true to avoid printing things if not requested  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$htmlTitre = "< p > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('show_back_link_on_top_of_tree') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$htmlTitre .= "< a  href = \"".api_get_self()."\" > "."< <  ".get_lang("BackToHomePage")."< / a > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (!is_null($catLine['parent_id']) || (api_get_setting('show_back_link_on_top_of_tree') < > 'true' & &  !is_null($catLine['code']))) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$htmlTitre .= "< a  href = \"".api_get_self()."?category=".$catLine['parent_id']."\" > "."< <  ".get_lang("Up" )."< / a > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$htmlTitre .= "< a  href = \"".api_get_self()."?category=".$catLine['parent_id']."\" > "."< <  ".get_lang('Up' )."< / a > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$htmlTitre .= "< / p > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if ($category != "" & &  !is_null($catLine['code'])) {  
				
			 
			
		
	
	
		
			
				
					
						
							
								 
							 
						
						
							
								 
							 
						
						
					 
				
				 
				 
				
					@ -729,27 +735,27 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								$courses_of_user = get_courses_of_user(api_get_user_id());  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							foreach ($course_list AS  $course) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							foreach ($course_list as  $course) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								// $setting_show_also_closed_courses  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($setting_show_also_closed_courses==false) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								if ($setting_show_also_closed_courses  ==  false) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// if we do not show the closed courses  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// we only show the courses that are open to the world (to everybody)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// and the courses that are open to the platform (if the current user is a registered user  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if( ($user_identified & &  $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM) OR  ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if( ($user_identified & &  $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM) ||  ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_shown++;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= "< li > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$courses_list_string .= "< a  href = \"".$web_course_path.$course['directory']."/\" > ".$course['title']."< / a > < br  / > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting("display_coursecode_in_courselist") == "true" ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_coursecode_in_courselist') == 'true' ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= $course['visual_code'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting("display_coursecode_in_courselist") == "true" AND api_get_setting("display_teacher_in_courselist") == "true" ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= " - " ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_coursecode_in_courselist') == 'true' & &  api_get_setting('display_teacher_in_courselist') == 'true' ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= ' - ' ;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting("display_teacher_in_courselist") == "true" ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_teacher_in_courselist') == 'true' ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= $course['tutor_name'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] < >  api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] !=  api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= ' - '.$course['course_language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= "< / li > \n";  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -766,50 +772,49 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$courses_shown++;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$courses_list_string .= "< li > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if ( $course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR ($user_identified AND $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR ($user_identified AND key_exists($course['code'],$courses_of_user) AND $course['visibility'] < > COURSE_VISIBILITY_CLOSED)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR $courses_of_user[$course['code']]['status'] == '1'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR api_is_platform_admin()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= "< a  href = \"".$web_course_path.$course['directory']."/\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= $course['title'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if ( $course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR ($user_identified AND $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR ($user_identified AND key_exists($course['code'],$courses_of_user) AND $course['visibility'] < > COURSE_VISIBILITY_CLOSED)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR $courses_of_user[$course['code']]['status'] == '1'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												OR api_is_platform_admin()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .="< / a > < br  / > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting("display_coursecode_in_courselist") == "true") {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= $course['visual_code'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting("display_coursecode_in_courselist") == "true" AND api_get_setting("display_teacher_in_courselist") == "true") {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= " - ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting("display_teacher_in_courselist") == "true")  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										{  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= $course['tutor_name'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] < > api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| ($user_identified & &  $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| ($user_identified & &  key_exists($course['code'], $courses_of_user) & &  $course['visibility'] != COURSE_VISIBILITY_CLOSED)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| $courses_of_user[$course['code']]['status'] == '1'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| api_is_platform_admin()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= "< a  href = \"".$web_course_path.$course['directory']."/\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$courses_list_string .= $course['title'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| ($user_identified & &  $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| ($user_identified & &  key_exists($course['code'], $courses_of_user) & &  $course['visibility'] != COURSE_VISIBILITY_CLOSED)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| $courses_of_user[$course['code']]['status'] == '1'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											|| api_is_platform_admin()) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= "< / a > < br  / > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_coursecode_in_courselist') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= $course['visual_code'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_coursecode_in_courselist') == 'true' & &  api_get_setting('display_teacher_in_courselist') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= ' - ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('display_teacher_in_courselist') == 'true') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= $course['tutor_name'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] != api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= ' - '.$course['course_language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] < > api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= ' - '.$course['course_language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										// We display a subscription link if  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										// 1. it is allowed to register for the course and if the course is not already in the courselist of the user and if the user is identiefied  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										// 2  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if ($user_identified AND !key_exists($course['code'],$courses_of_user)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											if ($course['subscribe'] == '1') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												$courses_list_string .= "< form  action = \"main/auth/courses.php?action=subscribe&category=".$_GET['category']."\"  method = \"post\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												$courses_list_string .= '< input  type = "hidden"  name = "sec_token"  value = "'.$stok.'" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												$courses_list_string .= "< input  type = \"hidden\"  name = \"subscribe\"  value = \"".$course['code']."\"  / > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												$courses_list_string .= "< input  type = \"image\"  name = \"unsub\"  src = \"main/img/enroll.gif\"  alt = \"".get_lang("Subscribe")."\"  / > ".get_lang("Subscribe")."< / form > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
												$courses_list_string .= '< br  / > '.get_lang("SubscribingNotAllowed");  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if (api_get_setting('show_different_course_language') == 'true' & &  $course['course_language'] != api_get_setting('platformLanguage')) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										$courses_list_string .= ' - '.$course['course_language'];  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// We display a subscription link if  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// 1. it is allowed to register for the course and if the course is not already in the courselist of the user and if the user is identiefied  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									// 2  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									if ($user_identified & &  !key_exists($course['code'], $courses_of_user)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										if ($course['subscribe'] == '1') {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= "< form  action = \"main/auth/courses.php?action=subscribe&category=".$_GET['category']."\"  method = \"post\" > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= '< input  type = "hidden"  name = "sec_token"  value = "'.$stok.'" > ';  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= "< input  type = \"hidden\"  name = \"subscribe\"  value = \"".$course['code']."\"  / > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= "< input  type = \"image\"  name = \"unsub\"  src = \"main/img/enroll.gif\"  alt = \"".get_lang("Subscribe")."\"  / > ".get_lang("Subscribe")."< / form > ";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										} else {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
											$courses_list_string .= '< br  / > '.get_lang("SubscribingNotAllowed");  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
										}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
									$courses_list_string .= "< / li > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
								}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							}  
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -818,11 +823,11 @@ function display_anonymous_course_list() { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							// echo "< blockquote > ",get_lang('_No_course_publicly_available'),"< / blockquote > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($courses_shown > 0) { //only display the list of courses and categories if there was more than  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						   // 0 courses visible to the world (we're in the anonymous list here)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							 // 0 courses visible to the world (we're in the anonymous list here)  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo $courses_list_string;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($category != "" ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo "< p > ", "< a  href = \"".api_get_self()."\" > < b > < / b >   ", Display :: return_icon('back.png', get_lang('BackToHomePage')),get_lang("BackToHomePage"), "< / a > ", "< / p > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						if ($category != '' ) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							echo "< p > ", "< a  href = \"".api_get_self()."\" >  ", Display :: return_icon('back.png', get_lang('BackToHomePage')),  get_lang("BackToHomePage"), "< / a > ", "< / p > \n";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
	
		
			
				
					
						
						
						
							
								 
							 
						
					 
				
				 
				 
				
					@ -836,20 +841,20 @@ function get_courses_of_user($user_id) { 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$table_course		= Database::get_main_table(TABLE_MAIN_COURSE);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$table_course_user	= Database::get_main_table(TABLE_MAIN_COURSE_USER);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					
 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// Secondly we select the courses that are in a category (user_course_cat< >0) and sort these according to the sort of the category  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						// Secondly we select the courses that are in a category (user_course_cat  < >  0) and sort these according to the sort of the category  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$user_id = intval($user_id);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_select_courses="SELECT course.code k, course.visual_code  vc, course.subscribe subscr, course.unsubscribe unsubscr,  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$sql_select_courses  =  "SELECT course.code k, course.visual_code  vc, course.subscribe subscr, course.unsubscribe unsubscr,  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													course.title i, course.tutor_name t, course.db_name db, course.directory dir, course_rel_user.status status,  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													course_rel_user.sort sort, course_rel_user.user_course_cat user_course_cat  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							                         FROM    $table_course       course,  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													 FROM    $table_course       course,  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
															$table_course_user  course_rel_user  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							                         WHERE course.code = course_rel_user.course_code  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							                         AND   course_rel_user.user_id = '".$user_id."'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							                         ORDER BY course_rel_user.sort ASC";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$result = api_sql_query($sql_select_courses,__FILE__, __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						while ($row=Database::fetch_array($result)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													 WHERE course.code = course_rel_user.course_code  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													 AND   course_rel_user.user_id = '".$user_id."'  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
													 ORDER BY course_rel_user.sort ASC";  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						$result = Database::query($sql_select_courses, __FILE__,  __LINE__);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						while ($row  =  Database::fetch_array($result)) {  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							// we only need the database name of the course  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$courses[$row['k']] = array("db"=> $row['db'], "code" => $row['k'], "visual_code" => $row['vc'], "title" => $row['i'], "directory" => $row['dir'], "status" => $row['status'], "tutor" => $row['t'], "subscribe" => $row['subscr'], "unsubscribe" => $row['unsubscr'], "sort" => $row['sort'], "user_course_category"  => $row['user_course_cat']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
							$courses[$row['k']] = array('db' => $row['db'], 'code' => $row['k'], 'visual_code' => $row['vc'], 'title' => $row['i'], 'directory' => $row['dir'], 'status' => $row['status'], 'tutor' => $row['t'], 'subscribe' => $row['subscr'], 'unsubscribe' => $row['unsubscr'], 'sort' => $row['sort'], 'user_course_category'  => $row['user_course_cat']);  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						}  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
						return $courses;  
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					}