You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							823 lines
						
					
					
						
							38 KiB
						
					
					
				
			
		
		
	
	
							823 lines
						
					
					
						
							38 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
use \ChamiloSession as Session;
 | 
						|
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
/**
 | 
						|
 * 	Code library for login process
 | 
						|
 *
 | 
						|
 * @author Olivier Cauberghe <olivier.cauberghe@UGent.be>, Ghent University
 | 
						|
 * @author Julio Montoya		<gugli100@gmail.com>
 | 
						|
 * @package chamilo.login
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * Class
 | 
						|
 * @package chamilo.login
 | 
						|
 */
 | 
						|
class Login
 | 
						|
{
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get user account list
 | 
						|
     *
 | 
						|
     * @param array $user array with keys: email, password, uid, loginName
 | 
						|
     * @param boolean $reset
 | 
						|
     * @param boolean $by_username
 | 
						|
     * @return unknown
 | 
						|
     */
 | 
						|
    public static function get_user_account_list($user, $reset = false, $by_username = false)
 | 
						|
    {
 | 
						|
        global $_configuration;
 | 
						|
        $portal_url = api_get_path(WEB_PATH);
 | 
						|
 | 
						|
        if ($_configuration['multiple_access_urls']) {
 | 
						|
            $access_url_id = api_get_current_access_url_id();
 | 
						|
            if ($access_url_id != -1) {
 | 
						|
                $url = api_get_access_url($access_url_id);
 | 
						|
                $portal_url = $url['url'];
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        if ($reset) {
 | 
						|
            if ($by_username) {
 | 
						|
                $secret_word = self::get_secret_word($user['email']);
 | 
						|
                if ($reset) {
 | 
						|
                    $reset_link = $portal_url . "main/auth/lostPassword.php?reset=" . $secret_word . "&id=" . $user['uid'];
 | 
						|
                } else {
 | 
						|
                    $reset_link = get_lang('Pass') . " : $user[password]";
 | 
						|
                }
 | 
						|
                $user_account_list = get_lang('YourRegistrationData') . " : \n" . get_lang('UserName') . ' : ' . $user['loginName'] . "\n" . get_lang('ResetLink') . ' : ' . $reset_link . '';
 | 
						|
 | 
						|
                if ($user_account_list) {
 | 
						|
                    $user_account_list = "\n-----------------------------------------------\n" . $user_account_list;
 | 
						|
                }
 | 
						|
            } else {
 | 
						|
                foreach ($user as $this_user) {
 | 
						|
                    $secret_word = self::get_secret_word($this_user['email']);
 | 
						|
                    if ($reset) {
 | 
						|
                        $reset_link = $portal_url . "main/auth/lostPassword.php?reset=" . $secret_word . "&id=" . $this_user['uid'];
 | 
						|
                    } else {
 | 
						|
                        $reset_link = get_lang('Pass') . " : $this_user[password]";
 | 
						|
                    }
 | 
						|
                    $user_account_list[] = get_lang('YourRegistrationData') . " : \n" . get_lang('UserName') . ' : ' . $this_user['loginName'] . "\n" . get_lang('ResetLink') . ' : ' . $reset_link . '';
 | 
						|
                }
 | 
						|
                if ($user_account_list) {
 | 
						|
                    $user_account_list = implode("\n-----------------------------------------------\n", $user_account_list);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        } else {
 | 
						|
            if (!$by_username) {
 | 
						|
                $user = $user[0];
 | 
						|
            }
 | 
						|
            $reset_link = get_lang('Pass') . " : $user[password]";
 | 
						|
            $user_account_list = get_lang('YourRegistrationData') . " : \n" . get_lang('UserName') . ' : ' . $user['loginName'] . "\n" . $reset_link . '';
 | 
						|
        }
 | 
						|
        return $user_account_list;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * This function sends the actual password to the user
 | 
						|
     *
 | 
						|
     * @param int $user
 | 
						|
     * @author Olivier Cauberghe <olivier.cauberghe@UGent.be>, Ghent University
 | 
						|
     */
 | 
						|
    public static function send_password_to_user($user, $by_username = false) {
 | 
						|
        global $_configuration;
 | 
						|
        $email_subject = "[" . api_get_setting('siteName') . "] " . get_lang('LoginRequest'); // SUBJECT
 | 
						|
 | 
						|
        if ($by_username) { // Show only for lost password
 | 
						|
            $user_account_list = self::get_user_account_list($user, false, $by_username); // BODY
 | 
						|
            $email_to = $user['email'];
 | 
						|
        } else {
 | 
						|
            $user_account_list = self::get_user_account_list($user); // BODY
 | 
						|
            $email_to = $user[0]['email'];
 | 
						|
        }
 | 
						|
 | 
						|
        $portal_url = api_get_path(WEB_PATH);
 | 
						|
        if ($_configuration['multiple_access_urls']) {
 | 
						|
            $access_url_id = api_get_current_access_url_id();
 | 
						|
            if ($access_url_id != -1) {
 | 
						|
                $url = api_get_access_url($access_url_id);
 | 
						|
                $portal_url = $url['url'];
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $email_body = get_lang('YourAccountParam') . " " . $portal_url . "\n\n$user_account_list";
 | 
						|
        // SEND MESSAGE
 | 
						|
        $sender_name = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
 | 
						|
        $email_admin = api_get_setting('emailAdministrator');
 | 
						|
 | 
						|
        if (api_mail_html('', $email_to, $email_subject, $email_body, $sender_name, $email_admin) == 1) {
 | 
						|
            return get_lang('YourPasswordHasBeenReset');
 | 
						|
        } else {
 | 
						|
            $admin_email = Display :: encrypted_mailto_link(api_get_setting('emailAdministrator'), api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname')));
 | 
						|
            return sprintf(get_lang('ThisPlatformWasUnableToSendTheEmailPleaseContactXForMoreInformation'), $admin_email);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Handle encrypted password, send an email to a user with his password
 | 
						|
     *
 | 
						|
     * @param int	user id
 | 
						|
     * @param bool	$by_username
 | 
						|
     *
 | 
						|
     * @author Olivier Cauberghe <olivier.cauberghe@UGent.be>, Ghent University
 | 
						|
     */
 | 
						|
    public static function handle_encrypted_password($user, $by_username = false) {
 | 
						|
        $email_subject = "[" . api_get_setting('siteName') . "] " . get_lang('LoginRequest'); // SUBJECT
 | 
						|
 | 
						|
        if ($by_username) { // Show only for lost password
 | 
						|
            $user_account_list = self::get_user_account_list($user, true, $by_username); // BODY
 | 
						|
            $email_to = $user['email'];
 | 
						|
        } else {
 | 
						|
            $user_account_list = self::get_user_account_list($user, true); // BODY
 | 
						|
            $email_to = $user[0]['email'];
 | 
						|
        }
 | 
						|
        $email_body = get_lang('DearUser') . " :\n" . get_lang('password_request') . "\n";
 | 
						|
        $email_body .= $user_account_list . "\n-----------------------------------------------\n\n";
 | 
						|
        $email_body .= get_lang('PasswordEncryptedForSecurity');
 | 
						|
 | 
						|
        $email_body .= "\n\n" . get_lang('SignatureFormula') . ",\n" . api_get_setting('administratorName') . " " . api_get_setting('administratorSurname') . "\n" . get_lang('PlataformAdmin') . " - " . api_get_setting('siteName');
 | 
						|
 | 
						|
        $sender_name = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
 | 
						|
        $email_admin = api_get_setting('emailAdministrator');
 | 
						|
 | 
						|
        if (@api_mail_html('', $email_to, $email_subject, $email_body, $sender_name, $email_admin) == 1) {
 | 
						|
            if (CustomPages::enabled()) {
 | 
						|
                return get_lang('YourPasswordHasBeenEmailed');
 | 
						|
            } else {
 | 
						|
                Display::display_confirmation_message(get_lang('YourPasswordHasBeenEmailed'));
 | 
						|
            }
 | 
						|
        } else {
 | 
						|
            $admin_email = Display :: encrypted_mailto_link(api_get_setting('emailAdministrator'), api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname')));
 | 
						|
            $message = sprintf(get_lang('ThisPlatformWasUnableToSendTheEmailPleaseContactXForMoreInformation'), $admin_email);
 | 
						|
 | 
						|
            if (CustomPages::enabled()) {
 | 
						|
                return $message;
 | 
						|
            } else {
 | 
						|
                Display::display_error_message($message, false);
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the secret word
 | 
						|
     * @author Olivier Cauberghe <olivier.cauberghe@UGent.be>, Ghent University
 | 
						|
     */
 | 
						|
    public static function get_secret_word($add)
 | 
						|
    {
 | 
						|
        return $secret_word = sha1($add);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Resets a password
 | 
						|
     * @author Olivier Cauberghe <olivier.cauberghe@UGent.be>, Ghent University
 | 
						|
     */
 | 
						|
    public static function reset_password($secret, $id, $by_username = false)
 | 
						|
    {
 | 
						|
        $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
 | 
						|
        $id = intval($id);
 | 
						|
        $sql = "SELECT user_id AS uid, lastname AS lastName, firstname AS firstName, username AS loginName, password, email FROM " . $tbl_user . " WHERE user_id=$id";
 | 
						|
        $result = Database::query($sql);
 | 
						|
        $num_rows = Database::num_rows($result);
 | 
						|
 | 
						|
        if ($result && $num_rows > 0) {
 | 
						|
            $user = Database::fetch_array($result);
 | 
						|
        } else {
 | 
						|
            return get_lang('CouldNotResetPassword');
 | 
						|
        }
 | 
						|
 | 
						|
        if (self::get_secret_word($user['email']) == $secret) {
 | 
						|
            // OK, secret word is good. Now change password and mail it.
 | 
						|
            $user['password'] = api_generate_password();
 | 
						|
            $crypted = api_get_encrypted_password($user['password']);
 | 
						|
            $sql = "UPDATE " . $tbl_user . " SET password='$crypted' WHERE user_id = $id";
 | 
						|
            Database::query($sql);
 | 
						|
            return self::send_password_to_user($user, $by_username);
 | 
						|
        } else {
 | 
						|
            return get_lang('NotAllowed');
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *
 | 
						|
     * @global bool   $is_platformAdmin
 | 
						|
     * @global bool   $is_allowedCreateCourse
 | 
						|
     * @global object $_user
 | 
						|
     */
 | 
						|
    public static function init_user($user_id, $reset)
 | 
						|
    {
 | 
						|
        global $is_platformAdmin;
 | 
						|
        global $is_allowedCreateCourse;
 | 
						|
        global $_user;
 | 
						|
 | 
						|
        if (isset($reset) && $reset) {    // session data refresh requested
 | 
						|
            unset($_SESSION['_user']['uidReset']);
 | 
						|
            $is_platformAdmin = false;
 | 
						|
            $is_allowedCreateCourse = false;
 | 
						|
            $_user['user_id'] = $user_id;
 | 
						|
 | 
						|
            if (isset($_user['user_id']) && $_user['user_id'] && !api_is_anonymous()) {
 | 
						|
                // 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);
 | 
						|
                $track_e_login = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LOGIN);
 | 
						|
 | 
						|
                $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 $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";
 | 
						|
 | 
						|
                $result = Database::query($sql);
 | 
						|
 | 
						|
                if (Database::num_rows($result) > 0) {
 | 
						|
                    // Extracting the user data
 | 
						|
 | 
						|
                    $uData = Database::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'];
 | 
						|
                    $_user['auth_source'] = $uData['auth_source'];
 | 
						|
                    $_user['theme'] = $uData['theme'];
 | 
						|
                    $_user['status'] = $uData['status'];
 | 
						|
 | 
						|
                    $is_platformAdmin = (bool) (!is_null($uData['is_admin']));
 | 
						|
                    $is_allowedCreateCourse = (bool) (($uData ['status'] == 1) or (api_get_setting('drhCourseManagerRights') and $uData['status'] == 4));
 | 
						|
                    ConditionalLogin::check_conditions($uData);
 | 
						|
 | 
						|
                    Session::write('_user', $_user);
 | 
						|
                    UserManager::update_extra_field_value($_user['user_id'], 'already_logged_in', 'true');
 | 
						|
                    Session::write('is_platformAdmin', $is_platformAdmin);
 | 
						|
                    Session::write('is_allowedCreateCourse', $is_allowedCreateCourse);
 | 
						|
 | 
						|
//
 | 
						|
//
 | 
						|
//                    // If request_uri is setted we have to go further to have course permissions
 | 
						|
//                    if (empty($_SESSION['request_uri']) || !isset($_SESSION['request_uri'])) {
 | 
						|
//                        if (isset($_SESSION['noredirection'])) {
 | 
						|
//                            //If we just want to reset info without redirecting user
 | 
						|
//                            unset($_SESSION['noredirection']);
 | 
						|
//                        } else {
 | 
						|
//                            LoginRedirection::redirect();
 | 
						|
//                        }
 | 
						|
//                    }
 | 
						|
                } else {
 | 
						|
                    header('location:' . api_get_path(WEB_PATH));
 | 
						|
                    //exit("WARNING UNDEFINED UID !! ");
 | 
						|
                }
 | 
						|
            } else { // no uid => logout or Anonymous
 | 
						|
                Session::erase('_user');
 | 
						|
                Session::erase('_uid');
 | 
						|
            }
 | 
						|
 | 
						|
            Session::write('is_platformAdmin', $is_platformAdmin);
 | 
						|
            Session::write('is_allowedCreateCourse', $is_allowedCreateCourse);
 | 
						|
        } else { // continue with the previous values
 | 
						|
            $_user = $_SESSION['_user'];
 | 
						|
            $is_platformAdmin = $_SESSION['is_platformAdmin'];
 | 
						|
            $is_allowedCreateCourse = $_SESSION['is_allowedCreateCourse'];
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *
 | 
						|
     * @global bool $is_platformAdmin
 | 
						|
     * @global bool $is_allowedCreateCourse
 | 
						|
     * @global object $_user
 | 
						|
     * @global int $_cid
 | 
						|
     * @global array $_course
 | 
						|
     * @global type $_real_cid
 | 
						|
     * @global type $_courseUser
 | 
						|
     * @global type $is_courseAdmin
 | 
						|
     * @global type $is_courseTutor
 | 
						|
     * @global type $is_courseCoach
 | 
						|
     * @global type $is_courseMember
 | 
						|
     * @global type $is_sessionAdmin
 | 
						|
     * @global type $is_allowed_in_course
 | 
						|
     *
 | 
						|
     * @param type $course_id
 | 
						|
     * @param type $reset
 | 
						|
     */
 | 
						|
    static function init_course($course_id, $reset)
 | 
						|
    {
 | 
						|
        global $_configuration;
 | 
						|
        global $is_platformAdmin;
 | 
						|
        global $is_allowedCreateCourse;
 | 
						|
        global $_user;
 | 
						|
 | 
						|
        global $_cid;
 | 
						|
        global $_course;
 | 
						|
        global $_real_cid;
 | 
						|
        global $_courseUser;
 | 
						|
 | 
						|
        global $is_courseAdmin;  //course teacher
 | 
						|
        global $is_courseTutor;  //course teacher - some rights
 | 
						|
        global $is_courseCoach;  //course coach
 | 
						|
        global $is_courseMember; //course student
 | 
						|
        global $is_sessionAdmin;
 | 
						|
        global $is_allowed_in_course;
 | 
						|
 | 
						|
        if ($reset) {
 | 
						|
            // Course session data refresh requested or empty data
 | 
						|
            if ($course_id) {
 | 
						|
                $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 = '$course_id'";
 | 
						|
                $result = Database::query($sql);
 | 
						|
 | 
						|
                if (Database::num_rows($result) > 0) {
 | 
						|
                    $course_data = Database::fetch_array($result);
 | 
						|
                    //@TODO real_cid should be cid, for working with numeric course id
 | 
						|
                    $_real_cid = $course_data['id'];
 | 
						|
 | 
						|
                    $_cid = $course_data['code'];
 | 
						|
                    $_course = array();
 | 
						|
                    $_course['real_id'] = $course_data['id'];
 | 
						|
                    $_course['id'] = $course_data['code']; //auto-assigned integer
 | 
						|
                    $_course['code'] = $course_data['code'];
 | 
						|
                    $_course['name'] = $course_data['title'];
 | 
						|
                    $_course['title'] = $course_data['title'];
 | 
						|
                    $_course['official_code'] = $course_data['visual_code']; // use in echo
 | 
						|
                    $_course['sysCode'] = $course_data['code']; // use as key in db
 | 
						|
                    $_course['path'] = $course_data['directory']; // use as key in path
 | 
						|
                    $_course['dbName'] = $course_data['db_name']; // use as key in db list
 | 
						|
                    $_course['db_name'] = $course_data['db_name']; // not needed in Chamilo 1.9
 | 
						|
                    $_course['dbNameGlu'] = $_configuration['table_prefix'] . $course_data['db_name'] . $_configuration['db_glue']; // use in all queries //not needed in Chamilo 1.9
 | 
						|
                    $_course['titular'] = $course_data['tutor_name']; // this should be deprecated and use the table course_rel_user
 | 
						|
                    $_course['language'] = $course_data['course_language'];
 | 
						|
                    $_course['extLink']['url'] = $course_data['department_url'];
 | 
						|
                    $_course['extLink']['name'] = $course_data['department_name'];
 | 
						|
                    $_course['categoryCode'] = $course_data['faCode'];
 | 
						|
                    $_course['categoryName'] = $course_data['faName'];
 | 
						|
                    $_course['visibility'] = $course_data['visibility'];
 | 
						|
                    $_course['subscribe_allowed'] = $course_data['subscribe'];
 | 
						|
                    $_course['unsubscribe'] = $course_data['unsubscribe'];
 | 
						|
                    $_course['activate_legal'] = $course_data['activate_legal'];
 | 
						|
                    $_course['show_score'] = $course_data['show_score']; //used in the work tool
 | 
						|
 | 
						|
                    Session::write('_cid', $_cid);
 | 
						|
                    Session::write('_course', $_course);
 | 
						|
 | 
						|
                    //@TODO real_cid should be cid, for working with numeric course id
 | 
						|
                    Session::write('_real_cid', $_real_cid);
 | 
						|
 | 
						|
                    // if a session id has been given in url, we store the session
 | 
						|
 | 
						|
                    // Database Table Definitions
 | 
						|
                    $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);
 | 
						|
 | 
						|
                    if (!empty($_GET['id_session'])) {
 | 
						|
                        $_SESSION['id_session'] = intval($_GET['id_session']);
 | 
						|
                        $sql = 'SELECT name FROM ' . $tbl_session . ' WHERE id="' . intval($_SESSION['id_session']) . '"';
 | 
						|
                        $rs = Database::query($sql);
 | 
						|
                        list($_SESSION['session_name']) = Database::fetch_array($rs);
 | 
						|
                    } else {
 | 
						|
                        Session::erase('session_name');
 | 
						|
                        Session::erase('id_session');
 | 
						|
                    }
 | 
						|
 | 
						|
                    if (!isset($_SESSION['login_as'])) {
 | 
						|
                        //Course login
 | 
						|
                        if (isset($_user['user_id'])) {
 | 
						|
                            Event::event_course_login($_course['sysCode'], $_user['user_id'], api_get_session_id());
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                } else {
 | 
						|
                    //exit("WARNING UNDEFINED CID !! ");
 | 
						|
                    header('location:' . api_get_path(WEB_PATH));
 | 
						|
                }
 | 
						|
            } else {
 | 
						|
                Session::erase('_cid');
 | 
						|
                Session::erase('_real_cid');
 | 
						|
                Session::erase('_course');
 | 
						|
 | 
						|
                if (!empty($_SESSION)) {
 | 
						|
                    foreach ($_SESSION as $key => $session_item) {
 | 
						|
                        if (strpos($key, 'lp_autolunch_') === false) {
 | 
						|
                            continue;
 | 
						|
                        } else {
 | 
						|
                            if (isset($_SESSION[$key])) {
 | 
						|
                                Session::erase($key);
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                //Deleting session info
 | 
						|
                if (api_get_session_id()) {
 | 
						|
                    Session::erase('id_session');
 | 
						|
                    Session::erase('session_name');
 | 
						|
                }
 | 
						|
            }
 | 
						|
        } 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'];
 | 
						|
 | 
						|
                // these lines are usefull for tracking. Indeed we can have lost the id_session and not the cid.
 | 
						|
                // Moreover, if we want to track a course with another session it can be usefull
 | 
						|
                if (!empty($_GET['id_session'])) {
 | 
						|
                    $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
 | 
						|
                    $sql = 'SELECT name FROM ' . $tbl_session . ' WHERE id="' . intval($_SESSION['id_session']) . '"';
 | 
						|
                    $rs = Database::query($sql);
 | 
						|
                    list($_SESSION['session_name']) = Database::fetch_array($rs);
 | 
						|
                    $_SESSION['id_session'] = intval($_GET['id_session']);
 | 
						|
                }
 | 
						|
 | 
						|
                if (!isset($_SESSION['login_as'])) {
 | 
						|
                    $save_course_access = true;
 | 
						|
 | 
						|
                    //The value  $_dont_save_user_course_access should be added before the call of global.inc.php see the main/inc/chat.ajax.php file
 | 
						|
                    //Disables the updates in the TRACK_E_COURSE_ACCESS table
 | 
						|
                    if (isset($_dont_save_user_course_access) && $_dont_save_user_course_access == true) {
 | 
						|
                        $save_course_access = false;
 | 
						|
                    }
 | 
						|
 | 
						|
                    if ($save_course_access) {
 | 
						|
                        $course_tracking_table = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
 | 
						|
 | 
						|
                        /*
 | 
						|
                         * When $_configuration['session_lifetime'] is too big 100 hours (in order to let users take exercises with no problems)
 | 
						|
                         * the function Tracking::get_time_spent_on_the_course() returns big values (200h) due the condition:
 | 
						|
                         * login_course_date > now() - INTERVAL $session_lifetime SECOND
 | 
						|
                         *
 | 
						|
                         */
 | 
						|
                        /*
 | 
						|
                          if (isset($_configuration['session_lifetime'])) {
 | 
						|
                          $session_lifetime    = $_configuration['session_lifetime'];
 | 
						|
                          } else {
 | 
						|
                          $session_lifetime    = 3600; // 1 hour
 | 
						|
                          } */
 | 
						|
 | 
						|
                        $session_lifetime = 3600; // 1 hour
 | 
						|
 | 
						|
                        $course_code = $_course['sysCode'];
 | 
						|
                        $time = api_get_utc_datetime();
 | 
						|
 | 
						|
                        if (isset($_user['user_id']) && !empty($_user['user_id'])) {
 | 
						|
 | 
						|
                            //We select the last record for the current course in the course tracking table
 | 
						|
                            //But only if the login date is < than now + max_life_time
 | 
						|
                            $sql = "SELECT course_access_id FROM $course_tracking_table
 | 
						|
                            WHERE   user_id     = " . intval($_user ['user_id']) . " AND
 | 
						|
                                    course_code = '$course_code' AND
 | 
						|
                                    session_id  = " . api_get_session_id() . " AND
 | 
						|
                                    login_course_date > now() - INTERVAL $session_lifetime SECOND
 | 
						|
                        ORDER BY login_course_date DESC LIMIT 0,1";
 | 
						|
                            $result = Database::query($sql);
 | 
						|
 | 
						|
                            if (Database::num_rows($result) > 0) {
 | 
						|
                                $i_course_access_id = Database::result($result, 0, 0);
 | 
						|
                                //We update the course tracking table
 | 
						|
                                $sql = "UPDATE $course_tracking_table  SET logout_course_date = '$time', counter = counter+1
 | 
						|
                                WHERE course_access_id = " . intval($i_course_access_id) . " AND session_id = " . api_get_session_id();
 | 
						|
                                //error_log($sql);
 | 
						|
                                Database::query($sql);
 | 
						|
                            } else {
 | 
						|
                                $sql = "INSERT INTO $course_tracking_table (course_code, user_id, login_course_date, logout_course_date, counter, session_id)" .
 | 
						|
                                    "VALUES('" . $course_code . "', '" . $_user['user_id'] . "', '$time', '$time', '1','" . api_get_session_id() . "')";
 | 
						|
                                //error_log($sql);
 | 
						|
                                Database::query($sql);
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
        /*  COURSE / USER REL. INIT */
 | 
						|
 | 
						|
        $session_id = api_get_session_id();
 | 
						|
        $user_id = isset($_user['user_id']) ? $_user['user_id'] : null;
 | 
						|
 | 
						|
        //Course permissions
 | 
						|
        $is_courseAdmin = false; //course teacher
 | 
						|
        $is_courseTutor = false; //course teacher - some rights
 | 
						|
        $is_courseMember = false; //course student
 | 
						|
        //Course - User permissions
 | 
						|
        $is_sessionAdmin = false;
 | 
						|
 | 
						|
        if ($reset) {
 | 
						|
 | 
						|
            if (isset($user_id) && $user_id && isset($_cid) && $_cid) {
 | 
						|
 | 
						|
                //Check if user is subscribed in a course
 | 
						|
                $course_user_table = Database::get_main_table(TABLE_MAIN_COURSE_USER);
 | 
						|
                $sql = "SELECT * FROM $course_user_table
 | 
						|
                   WHERE user_id  = '" . $user_id . "' AND relation_type <> " . COURSE_RELATION_TYPE_RRHH . "
 | 
						|
                   AND course_code = '$course_id'";
 | 
						|
                $result = Database::query($sql);
 | 
						|
 | 
						|
                $cuData = null;
 | 
						|
                if (Database::num_rows($result) > 0) { // this  user have a recorded state for this course
 | 
						|
                    $cuData = Database::fetch_array($result, 'ASSOC');
 | 
						|
                    $is_courseAdmin = (bool) ($cuData['status'] == 1 );
 | 
						|
                    $is_courseTutor = (bool) ($cuData['tutor_id'] == 1 );
 | 
						|
                    $is_courseMember = true;
 | 
						|
 | 
						|
                    //Checking if the user filled the course legal agreement
 | 
						|
                    if ($_course['activate_legal'] == 1 && !api_is_platform_admin()) {
 | 
						|
                        $user_is_subscribed = CourseManager::is_user_accepted_legal($user_id, $_course['id'], $session_id);
 | 
						|
                        if (!$user_is_subscribed) {
 | 
						|
                            $url = api_get_path(WEB_CODE_PATH) . 'course_info/legal.php?course_code=' . $_course['code'] . '&session_id=' . $session_id;
 | 
						|
                            header('Location: ' . $url);
 | 
						|
                            exit;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                    $_courseUser['role'] = $cuData['role'];
 | 
						|
                    Session::write('_courseUser', $_courseUser);
 | 
						|
                }
 | 
						|
 | 
						|
                //We are in a session course? Check session permissions
 | 
						|
                if (!empty($session_id)) {
 | 
						|
 | 
						|
                    //I'm not the teacher of the course
 | 
						|
                    if ($is_courseAdmin == false) {
 | 
						|
                        // this user has no status related to this course
 | 
						|
                        // The user is subscribed in a session? The user is a Session coach a Session admin ?
 | 
						|
 | 
						|
                        $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);
 | 
						|
 | 
						|
                        //Session coach, session admin, course coach admin
 | 
						|
                        $sql = "SELECT session.id_coach, session_admin_id, session_rcru.id_user
 | 
						|
                		FROM $tbl_session session, $tbl_session_course_user session_rcru
 | 
						|
					    WHERE  session_rcru.id_session  = session.id AND
 | 
						|
					           session_rcru.course_code = '$_cid' AND
 | 
						|
					           session_rcru.id_user     = '$user_id' AND
 | 
						|
                               session_rcru.id_session  = $session_id AND
 | 
						|
					           session_rcru.status      = 2";
 | 
						|
 | 
						|
                        $result = Database::query($sql);
 | 
						|
                        $row = Database::store_result($result);
 | 
						|
 | 
						|
                        //I'm a session admin?
 | 
						|
                        if (isset($row) && isset($row[0]) && $row[0]['session_admin_id'] == $user_id) {
 | 
						|
                            $_courseUser['role'] = 'Professor';
 | 
						|
                            $is_courseMember = false;
 | 
						|
                            $is_courseTutor = false;
 | 
						|
                            $is_courseAdmin = false;
 | 
						|
                            $is_courseCoach = false;
 | 
						|
                            $is_sessionAdmin = true;
 | 
						|
                        } else {
 | 
						|
                            //Im a coach or a student?
 | 
						|
                            $sql = "SELECT id_user, status FROM " . $tbl_session_course_user . "
 | 
						|
                            WHERE   course_code = '$_cid' AND
 | 
						|
                                    id_user     = '" . $user_id . "' AND
 | 
						|
                                    id_session  = '" . $session_id . "'
 | 
						|
                            LIMIT 1";
 | 
						|
                            $result = Database::query($sql);
 | 
						|
 | 
						|
                            if (Database::num_rows($result)) {
 | 
						|
                                $row = Database::fetch_array($result, 'ASSOC');
 | 
						|
 | 
						|
                                $session_course_status = $row['status'];
 | 
						|
 | 
						|
                                switch ($session_course_status) {
 | 
						|
                                    case '2': // coach - teacher
 | 
						|
                                        $_courseUser['role'] = 'Professor';
 | 
						|
                                        $is_courseMember = true;
 | 
						|
                                        $is_courseTutor = true;
 | 
						|
                                        $is_courseCoach = true;
 | 
						|
                                        $is_sessionAdmin = false;
 | 
						|
 | 
						|
                                        if (api_get_setting('extend_rights_for_coach') == 'true') {
 | 
						|
                                            $is_courseAdmin = true;
 | 
						|
                                        } else {
 | 
						|
                                            $is_courseAdmin = false;
 | 
						|
                                        }
 | 
						|
                                        Session::write('_courseUser', $_courseUser);
 | 
						|
                                        break;
 | 
						|
                                    case '0': //student
 | 
						|
                                        $is_courseMember = true;
 | 
						|
                                        $is_courseTutor = false;
 | 
						|
                                        $is_courseAdmin = false;
 | 
						|
                                        $is_sessionAdmin = false;
 | 
						|
                                        Session::write('_courseUser', $_courseUser);
 | 
						|
                                        break;
 | 
						|
                                    default:
 | 
						|
                                        //unregister user
 | 
						|
                                        $is_courseMember = false;
 | 
						|
                                        $is_courseTutor = false;
 | 
						|
                                        $is_courseAdmin = false;
 | 
						|
                                        $is_sessionAdmin = false;
 | 
						|
                                        Session::erase('_courseUser');
 | 
						|
                                        break;
 | 
						|
                                }
 | 
						|
                            } else {
 | 
						|
                                //unregister user
 | 
						|
                                $is_courseMember = false;
 | 
						|
                                $is_courseTutor = false;
 | 
						|
                                $is_courseAdmin = false;
 | 
						|
                                $is_sessionAdmin = false;
 | 
						|
                                Session::erase('_courseUser');
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
 | 
						|
                    //If I'm the admin platform i'm a teacher of the course
 | 
						|
                    if ($is_platformAdmin) {
 | 
						|
                        $is_courseAdmin = true;
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            } else { // keys missing => not anymore in the course - user relation
 | 
						|
                // course
 | 
						|
                $is_courseMember = false;
 | 
						|
                $is_courseAdmin = false;
 | 
						|
                $is_courseTutor = false;
 | 
						|
                $is_courseCoach = false;
 | 
						|
                $is_sessionAdmin = false;
 | 
						|
                Session::erase('_courseUser');
 | 
						|
            }
 | 
						|
 | 
						|
            //Checking the course access
 | 
						|
            $is_allowed_in_course = false;
 | 
						|
 | 
						|
            if (isset($_course)) {
 | 
						|
                switch ($_course['visibility']) {
 | 
						|
                    case COURSE_VISIBILITY_OPEN_WORLD: //3
 | 
						|
                        $is_allowed_in_course = true;
 | 
						|
                        break;
 | 
						|
                    case COURSE_VISIBILITY_OPEN_PLATFORM : //2
 | 
						|
                        if (isset($user_id) && !api_is_anonymous($user_id)) {
 | 
						|
                            $is_allowed_in_course = true;
 | 
						|
                        }
 | 
						|
                        break;
 | 
						|
                    case COURSE_VISIBILITY_REGISTERED: //1
 | 
						|
                        if ($is_platformAdmin || $is_courseMember) {
 | 
						|
                            $is_allowed_in_course = true;
 | 
						|
                        }
 | 
						|
                        break;
 | 
						|
                    case COURSE_VISIBILITY_CLOSED: //0
 | 
						|
                        if ($is_platformAdmin || $is_courseAdmin) {
 | 
						|
                            $is_allowed_in_course = true;
 | 
						|
                        }
 | 
						|
                        break;
 | 
						|
                    case COURSE_VISIBILITY_HIDDEN: //4
 | 
						|
                        if ($is_platformAdmin) {
 | 
						|
                            $is_allowed_in_course = true;
 | 
						|
                        }
 | 
						|
                        break;
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            // check the session visibility
 | 
						|
            if ($is_allowed_in_course == true) {
 | 
						|
                //if I'm in a session
 | 
						|
 | 
						|
                if ($session_id != 0) {
 | 
						|
                    if (!$is_platformAdmin) {
 | 
						|
                        // admin and session coach are *not* affected to the invisible session mode
 | 
						|
                        // the coach is not affected because he can log in some days after the end date of a session
 | 
						|
                        $session_visibility = api_get_session_visibility($session_id);
 | 
						|
 | 
						|
                        switch ($session_visibility) {
 | 
						|
                            case SESSION_INVISIBLE:
 | 
						|
                                $is_allowed_in_course = false;
 | 
						|
                                break;
 | 
						|
                        }
 | 
						|
                        //checking date
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            // save the states
 | 
						|
            Session::write('is_courseAdmin', $is_courseAdmin);
 | 
						|
            Session::write('is_courseMember', $is_courseMember);
 | 
						|
            Session::write('is_courseTutor', $is_courseTutor);
 | 
						|
            Session::write('is_courseCoach', $is_courseCoach);
 | 
						|
            Session::write('is_allowed_in_course', $is_allowed_in_course);
 | 
						|
 | 
						|
            Session::write('is_sessionAdmin', $is_sessionAdmin);
 | 
						|
        } else { // continue with the previous values
 | 
						|
            if (isset($_SESSION ['_courseUser'])) {
 | 
						|
                $_courseUser = $_SESSION ['_courseUser'];
 | 
						|
            }
 | 
						|
 | 
						|
            $is_courseAdmin = $_SESSION ['is_courseAdmin'];
 | 
						|
            $is_courseTutor = $_SESSION ['is_courseTutor'];
 | 
						|
            $is_courseCoach = $_SESSION ['is_courseCoach'];
 | 
						|
            $is_courseMember = $_SESSION ['is_courseMember'];
 | 
						|
            $is_allowed_in_course = $_SESSION ['is_allowed_in_course'];
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *
 | 
						|
     * @global int $_cid
 | 
						|
     * @global array $_course
 | 
						|
     * @global int $_gid
 | 
						|
     *
 | 
						|
     * @param int $group_id
 | 
						|
     * @param bool $reset
 | 
						|
     */
 | 
						|
    static function init_group($group_id, $reset)
 | 
						|
    {
 | 
						|
        global $_cid;
 | 
						|
        global $_course;
 | 
						|
        global $_gid;
 | 
						|
 | 
						|
        if ($reset) { // session data refresh requested
 | 
						|
            if ($group_id && $_cid && !empty($_course['real_id'])) { // have keys to search data
 | 
						|
                $group_table = Database::get_course_table(TABLE_GROUP);
 | 
						|
                $sql = "SELECT * FROM $group_table WHERE c_id = " . $_course['real_id'] . " AND id = '$group_id'";
 | 
						|
                $result = Database::query($sql);
 | 
						|
                if (Database::num_rows($result) > 0) { // This group has recorded status related to this course
 | 
						|
                    $gpData = Database::fetch_array($result);
 | 
						|
                    $_gid = $gpData ['id'];
 | 
						|
                    Session::write('_gid', $_gid);
 | 
						|
                } else {
 | 
						|
                    Session::erase('_gid');
 | 
						|
                }
 | 
						|
            } elseif (isset($_SESSION['_gid']) or isset($_gid)) { // Keys missing => not anymore in the group - course relation
 | 
						|
                Session::erase('_gid');
 | 
						|
            }
 | 
						|
        } elseif (isset($_SESSION['_gid'])) { // continue with the previous values
 | 
						|
            $_gid = $_SESSION ['_gid'];
 | 
						|
        } else { //if no previous value, assign caracteristic undefined value
 | 
						|
            $_gid = -1;
 | 
						|
        }
 | 
						|
 | 
						|
        //set variable according to student_view_enabled choices
 | 
						|
        if (api_get_setting('student_view_enabled') == "true") {
 | 
						|
            if (isset($_GET['isStudentView'])) {
 | 
						|
                if ($_GET['isStudentView'] == 'true') {
 | 
						|
                    if (isset($_SESSION['studentview'])) {
 | 
						|
                        if (!empty($_SESSION['studentview'])) {
 | 
						|
                            // switching to studentview
 | 
						|
                            $_SESSION['studentview'] = 'studentview';
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                } elseif ($_GET['isStudentView'] == 'false') {
 | 
						|
                    if (isset($_SESSION['studentview'])) {
 | 
						|
                        if (!empty($_SESSION['studentview'])) {
 | 
						|
                            // switching to teacherview
 | 
						|
                            $_SESSION['studentview'] = 'teacherview';
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            } elseif (!empty($_SESSION['studentview'])) {
 | 
						|
                //all is fine, no change to that, obviously
 | 
						|
            } elseif (empty($_SESSION['studentview'])) {
 | 
						|
                // We are in teacherview here
 | 
						|
                $_SESSION['studentview'] = 'teacherview';
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns true if user exists in the platform when asking the password
 | 
						|
     *
 | 
						|
     * @param string $username (email or username)
 | 
						|
     * @return boolean
 | 
						|
     */
 | 
						|
    public static function get_user_accounts_by_username($username)
 | 
						|
    {
 | 
						|
        if (strpos($username,'@')){
 | 
						|
            $username = api_strtolower($username);
 | 
						|
            $email = true;
 | 
						|
        } else {
 | 
						|
            $username = api_strtolower($username);
 | 
						|
            $email = false;
 | 
						|
        }
 | 
						|
 | 
						|
		$condition = '';
 | 
						|
		if ($email) {
 | 
						|
			$condition = "LOWER(email) = '".Database::escape_string($username)."' ";
 | 
						|
		} else {
 | 
						|
            $condition = "LOWER(username) = '".Database::escape_string($username)."'";
 | 
						|
        }
 | 
						|
 | 
						|
		$tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
 | 
						|
		$query = "SELECT user_id AS uid, lastname AS lastName, firstname AS firstName, username AS loginName, password, email,
 | 
						|
                         status AS status, official_code, phone, picture_uri, creator_id
 | 
						|
				 FROM  $tbl_user
 | 
						|
				 WHERE ( $condition AND active = 1) ";
 | 
						|
		$result 	= Database::query($query);
 | 
						|
		$num_rows 	= Database::num_rows($result);
 | 
						|
        if ($result && $num_rows > 0) {
 | 
						|
            return Database::store_result($result);
 | 
						|
        }
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
}
 | 
						|
 |