login already done, continue with this value
$_user['user_id'] = $_SESSION['_user']['user_id'];
}
else
{
unset($_user['user_id']); // uid not in session ? prevent any hacking
if(isset($_POST['login']) && isset($_POST['password'])) // $login && $password are given to log in
{
$login = $_POST['login'];
$password = $_POST['password'];
//lookup the user in the main database
$user_table = Database::get_main_table(TABLE_MAIN_USER);
$sql = "SELECT user_id, username, password, auth_source, active, expiration_date
FROM $user_table
WHERE username = '".trim(addslashes($login))."'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0)
{
$uData = mysql_fetch_array($result);
if ($uData['auth_source'] == PLATFORM_AUTH_SOURCE)
{
//the authentification of this user is managed by Dokeos itself
$password = trim(stripslashes($password));
// determine if the password needs to be encrypted before checking
// $userPasswordCrypted is set in an external configuration file
if ($userPasswordCrypted)
{
$password = md5($password);
}
// check the user's password
if ($password == $uData['password'] AND (trim($login) == $uData['username']))
{
// check if the account is active (not locked)
if ($uData['active']=='1')
{
// check if the expiration date has not been reached
if ($uData['expiration_date']>date('Y-m-d H:i:s') OR $uData['expiration_date']=='0000-00-00 00:00:00')
{
$_user['user_id'] = $uData['user_id'];
api_session_register('_user');
if(!function_exists('event_login')){
include(api_get_path(LIBRARY_PATH)."events.lib.inc.php");
event_login();
}
}
else
{
$loginFailed = true;
api_session_unregister('_uid');
header('Location: index.php?loginFailed=1&error=account_expired');
exit;
}
}
else
{
$loginFailed = true;
api_session_unregister('_uid');
header('Location: index.php?loginFailed=1&error=account_inactive');
exit;
}
}
else // login failed: username or password incorrect
{
$loginFailed = true;
api_session_unregister('_uid');
header('Location: index.php?loginFailed=1&error=user_password_incorrect');
exit;
}
if (isset($uData['creator_id']) && $_user['user_id'] != $uData['creator_id'])
{
//first login for a not self registred
//e.g. registered by a teacher
//do nothing (code may be added later)
}
}
else // no standard Dokeos login - try external authentification
{
/*
* Process external authentication
* on the basis of the given login name
*/
$loginFailed = true; // Default initialisation. It could
// change after the external authentication
$key = $uData['auth_source'];
/* >>>>>>>>>>>>>>>> External authentication modules <<<<<<<<<<<<<<<< */
// see configuration.php to define these
include_once($extAuthSource[$key]['login']);
/* >>>>>>>>>>>>>>>> External authentication modules <<<<<<<<<<<<<<<<<< */
}
if(!empty($_SESSION['request_uri']))
{
$req = $_SESSION['request_uri'];
unset($_SESSION['request_uri']);
header('location: '.$req);
}
else
{
header('location: '.api_get_path(WEB_PATH).api_get_setting('page_after_login').$param);
}
}
else // login failed, mysql_num_rows($result) <= 0
{
$loginFailed = true; // Default initialisation. It could
// change after the external authentication
/*
* In this section:
* there is no entry for the $login user in the Dokeos
* database. This also means there is no auth_source for the user.
* We let all external procedures attempt to add him/her
* to the system.
*
* Process external login on the basis
* of the authentication source list
* provided by the configuration settings.
* If the login succeeds, for going further,
* Dokeos needs the $_user['user_id'] variable to be
* set and registered in the session. It's the
* responsability of the external login script
* to provide this $_user['user_id'].
*/
if (is_array($extAuthSource))
{
foreach($extAuthSource as $thisAuthSource)
{
include_once($thisAuthSource['newUser']);
}
} //end if is_array($extAuthSource)
} //end else login failed
}
// else {} => continue as anonymous user
$uidReset = true;
// $cidReset = true;
// $gidReset = true;
}
// if the requested course is different from the course in session
if (!empty($cidReq) && (!isset($_SESSION['_cid']) or (isset($_SESSION['_cid']) && $cidReq != $_SESSION['_cid'])))
{
$cidReset = true;
$gidReset = true; // As groups depend from courses, group id is reset
}
// if the requested group is different from the group in session
if ($gidReq && $gidReq != $_SESSION['_gid'])
{
$gidReset = true;
}
//////////////////////////////////////////////////////////////////////////////
// USER INIT
//////////////////////////////////////////////////////////////////////////////
if (isset($uidReset) && $uidReset) // session data refresh requested
{
$is_platformAdmin = false; $is_allowedCreateCourse = false;
if (isset($_user['user_id']) && $_user['user_id']) // a uid is given (log in succeeded)
{
$user_table = Database::get_main_table(TABLE_MAIN_USER);
$admin_table = Database::get_main_table(TABLE_MAIN_ADMIN);
if ($_configuration['tracking_enabled'])
{
$sql = "SELECT `user`.*, `a`.`user_id` `is_admin`,
UNIX_TIMESTAMP(`login`.`login_date`) `login_date`
FROM $user_table
LEFT JOIN $admin_table `a`
ON `user`.`user_id` = `a`.`user_id`
LEFT JOIN `".$_configuration['statistics_database']."`.`track_e_login` `login`
ON `user`.`user_id` = `login`.`login_user_id`
WHERE `user`.`user_id` = '".$_user['user_id']."'
ORDER BY `login`.`login_date` DESC LIMIT 1";
}
else
{
$sql = "SELECT `user`.*, `a`.`user_id` `is_admin`
FROM $user_table
LEFT JOIN $admin_table `a`
ON `user`.`user_id` = `a`.`user_id`
WHERE `user`.`user_id` = '".$_user['user_id']."'";
}
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0)
{
// Extracting the user data
$uData = mysql_fetch_array($result);
$_user ['firstName'] = $uData ['firstname' ];
$_user ['lastName' ] = $uData ['lastname' ];
$_user ['mail' ] = $uData ['email' ];
$_user ['lastLogin'] = $uData ['login_date'];
$_user ['official_code'] = $uData ['official_code'];
$_user ['picture_uri'] = $uData ['picture_uri'];
$_user ['user_id'] = $uData ['user_id'];
$_user ['language'] = $uData ['language'];
$is_platformAdmin = (bool) (! is_null( $uData['is_admin']));
$is_allowedCreateCourse = (bool) ($uData ['status'] == 1);
api_session_register('_user');
}
else
{
exit("WARNING UNDEFINED UID !! ");
}
}
else // no uid => logout or Anonymous
{
api_session_unregister('_user');
api_session_unregister('_uid');
}
api_session_register('is_platformAdmin');
api_session_register('is_allowedCreateCourse');
}
else // continue with the previous values
{
$_user = $_SESSION['_user'];
$is_platformAdmin = $_SESSION['is_platformAdmin'];
$is_allowedCreateCourse = $_SESSION['is_allowedCreateCourse'];
}
//////////////////////////////////////////////////////////////////////////////
// COURSE INIT
//////////////////////////////////////////////////////////////////////////////
if (isset($cidReset) && $cidReset) // course session data refresh requested or empty data
{
api_session_unregister('id_session');
api_session_unregister('session_name');
if ($cidReq)
{
$course_table = Database::get_main_table(TABLE_MAIN_COURSE);
$course_cat_table = Database::get_main_table(TABLE_MAIN_CATEGORY);
$sql = "SELECT `course`.*, `course_category`.`code` `faCode`, `course_category`.`name` `faName`
FROM $course_table
LEFT JOIN $course_cat_table
ON `course`.`category_code` = `course_category`.`code`
WHERE `course`.`code` = '$cidReq'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result)>0)
{
$cData = mysql_fetch_array($result);
$_cid = $cData['code' ];
$_course = array();
$_course['id' ] = $cData['code' ]; //auto-assigned integer
$_course['name' ] = $cData['title' ];
$_course['official_code'] = $cData['visual_code' ]; // use in echo
$_course['sysCode' ] = $cData['code' ]; // use as key in db
$_course['path' ] = $cData['directory' ]; // use as key in path
$_course['dbName' ] = $cData['db_name' ]; // use as key in db list
$_course['dbNameGlu' ] = $_configuration['table_prefix'] . $cData['db_name'] . $_configuration['db_glue']; // use in all queries
$_course['titular' ] = $cData['tutor_name' ];
$_course['language' ] = $cData['course_language' ];
$_course['extLink' ]['url' ] = $cData['department_url' ];
$_course['extLink' ]['name'] = $cData['department_name'];
$_course['categoryCode'] = $cData['faCode' ];
$_course['categoryName'] = $cData['faName' ];
$_course['visibility' ] = $cData['visibility'];
$_course['subscribe_allowed'] = $cData['subscribe'];
$_course['unubscribe_allowed'] = $cData['unsubscribe'];
api_session_register('_cid');
api_session_register('_course');
//We add a new record in the course tracking table
$course_tracking_table = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
$sql="INSERT INTO $course_tracking_table(course_code, user_id, login_course_date, logout_course_date, counter)" .
"VALUES('".$_course['official_code']."', '".$_user['user_id']."', NOW(), NOW(), '1')";
api_sql_query($sql,__FILE__,__LINE__);
if(api_get_setting("Ajax_course_tracking_refresh")!=0 && !isset($noajax)){
include("common_course_tracking.ajax.php");
$i_milliseconds_for_refresh=intval(api_get_setting("Ajax_course_tracking_refresh"))*1000;
$htmlHeadXtra[] = $xajax_course_tracking->getJavascript(api_get_path(WEB_LIBRARY_PATH).'xajax/');
$htmlHeadXtra[] = "";
}
}
else
{
exit("WARNING UNDEFINED CID !! ");
}
}
else
{
api_session_unregister('_cid');
api_session_unregister('_course');
}
}
else // continue with the previous values
{
if(empty($_SESSION['_course']) OR empty($_SESSION['_cid']))
{ //no previous values...
$_cid = -1; //set default values that will be caracteristic of being unset
$_course = -1;
}
else
{
$_cid = $_SESSION['_cid' ];
$_course = $_SESSION['_course'];
$course_tracking_table = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
//We select the last record for the current course in the course tracking table
$sql="SELECT course_access_id FROM $course_tracking_table WHERE user_id='".$_user ['user_id']."' ORDER BY login_course_date DESC LIMIT 0,1";
$result=api_sql_query($sql,__FILE__,__LINE__);
$i_course_access_id = mysql_result($result,0,0);
//We update the course tracking table
$sql="UPDATE $course_tracking_table " .
"SET logout_course_date = NOW(), " .
"counter = counter+1 " .
"WHERE course_access_id='$i_course_access_id'";
if(!isset($noajax)){
api_sql_query($sql,__FILE__,__LINE__);
}
if(api_get_setting("Ajax_course_tracking_refresh")!=0 && !isset($noajax)){
include("common_course_tracking.ajax.php");
$i_milliseconds_for_refresh=intval(api_get_setting("Ajax_course_tracking_refresh"))*1000;
$htmlHeadXtra[] = $xajax_course_tracking->getJavascript(api_get_path(WEB_LIBRARY_PATH).'xajax/');
$htmlHeadXtra[] = "";
}
}
}
//////////////////////////////////////////////////////////////////////////////
// COURSE / USER REL. INIT
//////////////////////////////////////////////////////////////////////////////
if ((isset($uidReset) && $uidReset) || (isset($cidReset) && $cidReset)) // session data refresh requested
{
if (isset($_user['user_id']) && $_user['user_id'] && isset($_cid) && $_cid) // have keys to search data
{
if(api_get_setting('use_session_mode') != 'true')
{
$course_user_table = Database::get_main_table(TABLE_MAIN_COURSE_USER);
$sql = "SELECT * FROM $course_user_table
WHERE `user_id` = '".$_user['user_id']."'
AND `course_code` = '$cidReq'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0) // this user have a recorded state for this course
{
$cuData = mysql_fetch_array($result);
$is_courseMember = true;
$is_courseTutor = (bool) ($cuData['tutor_id' ] == 1 );
$is_courseAdmin = (bool) ($cuData['status'] == 1 );
api_session_register('_courseUser');
}
else // this user has no status related to this course
{
$is_courseMember = false;
$is_courseAdmin = false;
$is_courseTutor = false;
}
$is_courseAdmin = (bool) ($is_courseAdmin || $is_platformAdmin);
}
else
{
$tbl_course_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
$sql = "SELECT * FROM ".$tbl_course_user."
WHERE `user_id` = '".$_user['user_id']."'
AND `course_code` = '$cidReq'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0) // this user have a recorded state for this course
{
$cuData = mysql_fetch_array($result);
$_courseUser['role'] = $cuData['role' ];
$is_courseMember = true;
$is_courseTutor = (bool) ($cuData['tutor_id' ] == 1 );
$is_courseAdmin = (bool) ($cuData['status'] == 1 );
api_session_register('_courseUser');
}
else // this user has no status related to this course
{
// is it the session coach ?
$tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
$tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE);
$tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
$sql = "SELECT 1
FROM ".$tbl_session."
INNER JOIN ".$tbl_session_course."
ON session_rel_course.id_session = session.id
AND session_rel_course.course_code='$_cid'
WHERE session.id_coach = '".$_user['user_id']."'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if($row = mysql_fetch_array($result)){
$_courseUser['role'] = 'Professor';
$is_courseMember = true;
$is_courseTutor = true;
$is_courseAdmin = true;
api_session_register('_courseUser');
}
else
{
// vérifier que c pas le coach du cours
$sql = "SELECT 1
FROM ".$tbl_session_course."
WHERE session_rel_course.course_code='$_cid'
AND session_rel_course.id_coach = '".$_user['user_id']."'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if($row = mysql_fetch_array($result))
{
$_courseUser['role'] = 'Professor';
$is_courseMember = true;
$is_courseTutor = true;
$tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
$sql="SELECT status FROM ".$tbl_user." WHERE user_id = ".$_user['user_id']."";
$result=api_sql_query($sql);
if(mysql_result($result,0,0)==1){
$is_courseAdmin = true;
}
else{
$is_courseAdmin = false;
}
api_session_register('_courseUser');
}
else
{
// vérifier que c pas un élève de la session
$sql = "SELECT * FROM ".$tbl_session_course_user."
WHERE `id_user` = '".$_user['user_id']."'
AND `course_code` = '$cidReq'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0) // this user have a recorded state for this course
{
while($row = mysql_fetch_array($result)){
$is_courseMember = true;
$is_courseTutor = false;
$is_courseAdmin = false;
api_session_register('_courseUser');
}
}
}
}
}
}
}
else // keys missing => not anymore in the course - user relation
{
//// course
$is_courseMember = false;
$is_courseAdmin = false;
$is_courseTutor = false;
api_session_unregister('_courseUser');
}
//DEPRECATED
//$is_courseAllowed=($_cid && ($_course['visibility'] || $is_courseMember || $is_platformAdmin))?true:false;
//NEW
if (isset($_course))
{
if ($_course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)
$is_allowed_in_course = true;
elseif ($_course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM && isset($_user['user_id']) )
$is_allowed_in_course = true;
elseif ($_course['visibility'] == COURSE_VISIBILITY_REGISTERED && ($is_platformAdmin || $is_courseMember))
$is_allowed_in_course = true;
elseif ($_course['visibility'] == COURSE_VISIBILITY_CLOSED && ($is_platformAdmin || $is_courseAdmin))
$is_allowed_in_course = true;
else $is_allowed_in_course = false;
}
// save the states
api_session_register('is_courseMember');
api_session_register('is_courseAdmin');
//api_session_register('is_courseAllowed'); //deprecated old permission var
api_session_register('is_courseTutor');
api_session_register('is_allowed_in_course'); //new permission var
}
else // continue with the previous values
{
$_courseUser = $_SESSION ['_courseUser' ];
$is_courseMember = $_SESSION ['is_courseMember' ];
$is_courseAdmin = $_SESSION ['is_courseAdmin' ];
//$is_courseAllowed = $_SESSION ['is_courseAllowed']; //deprecated
$is_allowed_in_course = $_SESSION ['is_allowed_in_course'];
$is_courseTutor = $_SESSION ['is_courseTutor' ];
}
//////////////////////////////////////////////////////////////////////////////
// GROUP INIT
//////////////////////////////////////////////////////////////////////////////
if ((isset($gidReset) && $gidReset) || (isset($cidReset) && $cidReset)) // session data refresh requested
{
if ($gidReq && $_cid ) // have keys to search data
{
$group_table = Database::get_course_table(TABLE_GROUP);
$sql = "SELECT * FROM $group_table WHERE `id` = '$gidReq'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if (mysql_num_rows($result) > 0) // This group has recorded status related to this course
{
$gpData = mysql_fetch_array($result);
$_gid = $gpData ['id' ];
api_session_register('_gid');
}
else
{
exit("WARNING UNDEFINED GID !! ");
}
}
elseif(isset($_SESSION['_gid']) or isset($_gid)) // Keys missing => not anymore in the group - course relation
{
api_session_unregister('_gid');
}
}
elseif(isset($_SESSION['_gid'])) // continue with the previous values
{
$_gid = $_SESSION ['_gid' ];
}
else
{ //if no previous value, assign caracteristic undefined value
$_gid = -1;
}
if(isset($_cid))
{
$tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
$sql="UPDATE $tbl_course SET last_visit=NOW() WHERE code='$_cid'";
api_sql_query($sql,__FILE__,__LINE__);
}
?>