'index.php', 'name' => get_lang('Sessions')); set_time_limit(0); // Set this option to true to enforce strict purification for usenames. $purification_option_for_usernames = false; $inserted_in_course = array(); global $_configuration; if (isset($_POST['formSent'])) { if (isset($_FILES['import_file']['tmp_name']) && !empty($_FILES['import_file']['tmp_name'])) { $form_sent = $_POST['formSent']; $file_type = $_POST['file_type']; $send_mail = $_POST['sendMail'] ? 1 : 0; //$updatesession = $_POST['updatesession'] ? 1 : 0; $updatesession = 0; $sessions = array(); $session_counter = 0; if ($file_type == 'xml') { // XML // SimpleXML for PHP5 deals with various encodings, but how many they are, what are version issues, do we need to waste time with configuration options? // For avoiding complications we go some sort of "PHP4 way" - we convert the input xml-file into UTF-8 before passing it to the parser. // Instead of: // $root = @simplexml_load_file($_FILES['import_file']['tmp_name']); // we may use the following construct: // To ease debugging let us use: $content = file_get_contents($_FILES['import_file']['tmp_name']); $content = Text::api_utf8_encode_xml($content); $root = @simplexml_load_string($content); unset($content); if (is_object($root)) { if (count($root->Users->User) > 0) { // Creating/updating users from base node. foreach ($root->Users->User as $node_user) { $username = $username_old = trim(api_utf8_decode($node_user->Username)); if (UserManager::is_username_available($username)) { $password = api_utf8_decode($node_user->Password); if (empty($password)) { $password = api_generate_password(); } switch ($node_user->Status) { case 'student' : $status = 5; break; case 'teacher' : $status = 1; break; default : $status = 5; $error_message .= get_lang('StudentStatusWasGivenTo').' : '.$username.'
'; } $result = UserManager::create_user( api_utf8_decode($node_user->Firstname), api_utf8_decode($node_user->Lastname), $status, api_utf8_decode($node_user->Email), $username, $password, api_utf8_decode($node_user->OfficialCode), null, api_utf8_decode($node_user->Phone), null, PLATFORM_AUTH_SOURCE, null, 1, 0, null, null, $send_mail ); } else { $lastname = trim(api_utf8_decode($node_user->Lastname)); $firstname = trim(api_utf8_decode($node_user->Firstname)); $password = api_utf8_decode($node_user->Password); $email = trim(api_utf8_decode($node_user->Email)); $official_code = trim(api_utf8_decode($node_user->OfficialCode)); $phone = trim(api_utf8_decode($node_user->Phone)); $status = trim(api_utf8_decode($node_user->Status)); switch ($status) { case 'student' : $status = 5; break; case 'teacher' : $status = 1; break; default : $status = 5; $error_message .= get_lang('StudentStatusWasGivenTo').' : '.$username.'
'; } $sql = "UPDATE $tbl_user SET lastname = '".Database::escape_string($lastname)."', firstname = '".Database::escape_string($firstname)."', ".(empty($password) ? "" : "password = '".(api_get_encrypted_password($password))."',")." email = '".Database::escape_string($email)."', official_code = '".Database::escape_string($official_code)."', phone = '".Database::escape_string($phone)."', status = '".Database::escape_string($status)."' WHERE username = '".Database::escape_string($username)."'"; Database::query($sql); } } } // Creating courses from base node. if (count($root->Courses->Course) > 0) { foreach ($root->Courses->Course as $courseNode) { $params = array(); if (empty($courseNode->CourseTitle)) { $params['title'] = api_utf8_decode($courseNode->CourseCode); } else { $params['title'] = api_utf8_decode($courseNode->CourseTitle); } $params['wanted_code'] = api_utf8_decode($courseNode->CourseCode); $params['tutor_name'] = null; $params['course_category'] = null; $params['course_language'] = api_get_valid_language(api_utf8_decode($courseNode->CourseLanguage)); $params['user_id'] = api_get_user_id(); // Looking up for the teacher. $username = trim(api_utf8_decode($courseNode->CourseTeacher)); $sql = "SELECT user_id, lastname, firstname FROM $tbl_user WHERE username='$username'"; $rs = Database::query($sql); list($user_id, $lastname, $firstname) = Database::fetch_array($rs); $params['teachers'] = $user_id; CourseManager::create_course($params); } } // Creating sessions from base node. if (count($root->Session) > 0) { foreach ($root->Session as $node_session) { $course_counter = 0; $user_counter = 0; $session_name = trim(api_utf8_decode($node_session->SessionName)); $coach = UserManager::purify_username(api_utf8_decode($node_session->Coach), $purification_option_for_usernames); if (!empty($coach)) { $coach_id = UserManager::get_user_id_from_username($coach); if ($coach_id === false) { $error_message .= get_lang('UserDoesNotExist').' : '.$coach.'
'; // Forcing the coach id if user does not exist. $coach_id = api_get_user_id(); } } else { // Forcing the coach id. $coach_id = api_get_user_id(); } $date_start = trim(api_utf8_decode($node_session->DateStart)); // Just in case - encoding conversion. $date_end = trim(api_utf8_decode($node_session->DateEnd)); $visibility = trim(api_utf8_decode($node_session->Visibility)); $session_category_id = trim(api_utf8_decode($node_session->SessionCategory)); if (!$updatesession) { // Always create a session. $unique_name = false; // This MUST be initializead. $i = 0; // Change session name, verify that session doesn't exist. while (!$unique_name) { if ($i > 1) { $suffix = ' - '.$i; } $sql = 'SELECT 1 FROM '.$tbl_session.' WHERE name="'.Database::escape_string($session_name.$suffix).'"'; $rs = Database::query($sql); if (Database::result($rs, 0, 0)) { $i++; } else { $unique_name = true; $session_name .= $suffix; } } $params = array ( 'id_coach' => $coach_id, 'visibility' => $visibility, 'name' => $session_name, 'access_start_date' => $date_start, 'access_end_date' => $date_end, 'session_category_id' => $session_category_id, 'session_admin_id' => api_get_user_id(), ); $session_id = SessionManager::add($params); $session_counter++; } else { // Update the session if it is needed. $my_session_result = SessionManager::get_session_by_name($session_name); if ($my_session_result === false) { $params = array ( 'id_coach' => $coach_id, 'visibility' => $visibility, 'name' => $session_name, 'access_start_date' => $date_start, 'access_end_date' => $date_end, 'session_category_id' => $session_category_id, 'session_admin_id' => api_get_user_id(), ); $session_id = SessionManager::add($params); $session_counter++; } else { $params = array ( 'id' => $my_session_result['id'], 'id_coach' => $coach_id, 'visibility' => $visibility, 'name' => $session_name, 'access_start_date' => $date_start, 'access_end_date' => $date_end, 'session_category_id' => $session_category_id, 'session_admin_id' => api_get_user_id(), ); SessionManager::update($params); $session_id = Database::query("SELECT id FROM $tbl_session WHERE name='$session_name'"); list($session_id) = Database::fetch_array($session_id); Database::query("DELETE FROM $tbl_session_user WHERE id_session='$session_id'"); Database::query("DELETE FROM $tbl_session_course WHERE id_session='$session_id'"); Database::query("DELETE FROM $tbl_session_course_user WHERE id_session='$session_id'"); } } // Associate the session with access_url. global $_configuration; if ($_configuration['multiple_access_urls']) { $access_url_id = api_get_current_access_url_id(); UrlManager::add_session_to_url($session_id, $access_url_id); } else { // We fill by default the access_url_rel_session table. UrlManager::add_session_to_url($session_id, 1); } // Adding users to the new session. foreach ($node_session->User as $node_user) { $username = UserManager::purify_username(api_utf8_decode($node_user), $purification_option_for_usernames); $user_id = UserManager::get_user_id_from_username($username); if ($user_id !== false) { $sql = "INSERT IGNORE INTO $tbl_session_user SET id_user='$user_id', id_session = '$session_id'"; $rs_user = Database::query($sql); $user_counter++; } } // Adding courses to a session. foreach ($node_session->Course as $node_course) { $course_code = Database::escape_string(trim(api_utf8_decode($node_course->CourseCode))); // Verify that the course pointed by the course code node exists. if (CourseManager::course_exists($course_code)) { // If the course exists we continue. $course_info = CourseManager::get_course_information($course_code); $courseId = $course_info['real_id']; $session_course_relation = SessionManager::relation_session_course_exist($session_id, $courseId); if (!$session_course_relation) { $sql_course = "INSERT INTO $tbl_session_course SET c_id = '$courseId', id_session='$session_id'"; $rs_course = Database::query($sql_course); } $course_coaches = explode(',', $node_course->Coach); // Adding coachs to session course user foreach ($course_coaches as $course_coach) { $coach_id = UserManager::purify_username(api_utf8_decode($course_coach), $purification_option_for_usernames); $coach_id = UserManager::get_user_id_from_username($course_coach); if ($coach_id !== false) { $sql = "INSERT IGNORE INTO $tbl_session_course_user SET id_user='$coach_id', c_id ='$courseId', id_session = '$session_id', status = 2 "; $rs_coachs = Database::query($sql); } else { $error_message .= get_lang('UserDoesNotExist').' : '.$user.'
'; } } // Adding users. $course_counter++; $users_in_course_counter = 0; foreach ($node_course->User as $node_user) { $username = UserManager::purify_username(api_utf8_decode($node_user), $purification_option_for_usernames); $user_id = UserManager::get_user_id_from_username($username); if ($user_id !== false) { // Adding to session_rel_user table. $sql = "INSERT IGNORE INTO $tbl_session_user SET id_user='$user_id', id_session = '$session_id'"; $rs_user = Database::query($sql); $user_counter++; // Adding to session_rel_user_rel_course table. $sql = "INSERT IGNORE INTO $tbl_session_course_user SET id_user='$user_id', c_id ='$courseId', id_session = '$session_id'"; $rs_users = Database::query($sql); $users_in_course_counter++; } else { $error_message .= get_lang('UserDoesNotExist').' : '.$username.'
'; } } $update_session_course = "UPDATE $tbl_session_course SET nbr_users='$users_in_course_counter' WHERE c_id ='$courseId'"; Database::query($update_session_course); $inserted_in_course[$course_code] = $course_info['title']; } /* if (CourseManager::course_exists($course_code, true)) { // If the course exists we continue. // Also subscribe to virtual courses through check on visual code. $list = CourseManager :: get_courses_info_from_visual_code($course_code); foreach ($list as $vcourse) { if ($vcourse['code'] == $course_code) { // Ignore, this has already been inserted. } else { $sql_course = "INSERT INTO $tbl_session_course SET course_code = '".$vcourse['code']."', id_session='$session_id'"; $rs_course = Database::query($sql_course); $course_coaches = explode(",",$node_course->Coach); // adding coachs to session course user foreach ($course_coaches as $course_coach) { $coach_id = UserManager::purify_username(api_utf8_decode($course_coach), $purification_option_for_usernames); $coach_id = UserManager::get_user_id_from_username($course_coach); if ($coach_id !== false) { $sql = "INSERT IGNORE INTO $tbl_session_course_user SET id_user='$coach_id', course_code='{$vcourse['code']}', id_session = '$session_id', status = 2 "; $rs_coachs = Database::query($sql); } else { $error_message .= get_lang('UserDoesNotExist').' : '.$user.'
'; } } // adding users $course_counter++; $users_in_course_counter = 0; foreach ($node_course->User as $node_user) { $username = UserManager::purify_username(api_utf8_decode($node_user), $purification_option_for_usernames); $user_id = UserManager::get_user_id_from_username($username); if ($user_id !== false) { // Adding to session_rel_user table. $sql = "INSERT IGNORE INTO $tbl_session_user SET id_user='$user_id', id_session = '$session_id'"; $rs_user = Database::query($sql); $user_counter++; // Adding to session_rel_user_rel_course table. $sql = "INSERT IGNORE INTO $tbl_session_course_user SET id_user='$user_id', course_code='{$vcourse['code']}', id_session = '$session_id'"; $rs_users = Database::query($sql); $users_in_course_counter++; } else { $error_message .= get_lang('UserDoesNotExist').' : '.$username.'
'; } } $update_session_course = "UPDATE $tbl_session_course SET nbr_users='$users_in_course_counter' WHERE course_code='$course_code'"; Database::query($update_session_course); $inserted_in_course[$course_code] = $course_info['title']; } $inserted_in_course[$vcourse['code']] = $vcourse['title']; } } else { // Tthe course does not exist. $error_message .= get_lang('CourseDoesNotExist').' : '.$course_code.'
'; } */ } Database::query("UPDATE $tbl_session SET nbr_users='$user_counter', nbr_courses='$course_counter' WHERE id='$session_id'"); } } if (empty($root->Users->User) && empty($root->Courses->Course) && empty($root->Session)) { $error_message = get_lang('NoNeededData'); } } else { $error_message .= get_lang('XMLNotValid'); } } else { // CSV $result = SessionManager::importCSV($_FILES['import_file']['tmp_name'], $updatesession, api_get_user_id()); $error_message = $result['error_message']; $session_counter = $result['session_counter']; } if (!empty($error_message)) { $error_message = get_lang('ButProblemsOccured').' :
'.$error_message; } if (count($inserted_in_course) > 1) { $warn = get_lang('SeveralCoursesSubscribedToSessionBecauseOfSameVisualCode').': '; foreach ($inserted_in_course as $code => $title) { $warn .= ' '.$title.' ('.$code.'),'; } $warn = substr($warn, 0, -1); } if ($session_counter == 1) { header('Location: resume_session.php?id_session='.$session_id.'&warn='.urlencode($warn)); exit; } else { header('Location: session_list.php?action=show_message&message='.urlencode(get_lang('FileImported').' '.$error_message).'&warn='.urlencode($warn)); exit; } } else { $error_message = get_lang('NoInputFile'); } } // Display the header. Display::display_header($tool_name); if (count($inserted_in_course) > 1) { $msg = get_lang('SeveralCoursesSubscribedToSessionBecauseOfSameVisualCode').': '; foreach ($inserted_in_course as $code => $title) { $msg .= ' '.$title.' ('.$title.'),'; } $msg = substr($msg, 0, -1); Display::display_warning_message($msg); } echo ''; if (!empty($error_message)) { Display::display_normal_message($error_message, false); } $form = new FormValidator('import_sessions', 'post', api_get_self(), null, array('enctype' => 'multipart/form-data')); $form->addElement('hidden', 'formSent', 1); $form->addElement('file', 'import_file', get_lang('ImportFileLocation')); $form->addElement('radio', 'file_type', array(get_lang('FileType'), ''.get_lang('ExampleCSVFile').''), 'CSV', 'csv'); $form->addElement('radio', 'file_type', array(null, ''.get_lang('ExampleXMLFile').''), 'XML', 'xml'); $form->addElement('checkbox', 'sendMail', null, get_lang('SendMailToUsers')); $form->addElement('button', 'submit', get_lang('ImportSession')); $defaults = array('sendMail' => 'true','file_type' => 'csv'); $form->setDefaults($defaults); Display::display_normal_message(get_lang('TheXMLImportLetYouAddMoreInfoAndCreateResources')); $form->display(); ?>

:

SessionName;Coach;DateStart;DateEnd;Users;Courses
xxx1;xxx;xxx;xxx;username1|username2;course1[coach1][username1,username2,...]|course2[coach1][username1,username2,...]
xxx2;xxx;xxx;xxx;username1|username2;course1[coach1][username1,username2,...]|course2[coach1][username1,username2,...]

:

<?xml version="1.0" encoding=""?>
<Sessions>
    <Users>
        <User>
            <Username>username1</Username>
            <Lastname>xxx</Lastname>
            <Firstname>xxx</Firstname>
            <Password>xxx</Password>
            <Email>xxx@xx.xx</Email>
            <OfficialCode>xxx</OfficialCode>
            <Phone>xxx</Phone>
            <Status>student|teacher</Status>
        </User>
    </Users>
    <Courses>
        <Course>
            <CourseCode>xxx</CourseCode>
            <CourseTeacher>teacher_username</CourseTeacher>
            <CourseLanguage>xxx</CourseLanguage>
            <CourseTitle>xxx</CourseTitle>
            <CourseDescription>xxx</CourseDescription>
        </Course>
    </Courses>
    <Session>
        <SessionName>xxx</SessionName>
        <Coach>xxx</Coach>
        <DateStart>xxx</DateStart>
        <DateEnd>xxx</DateEnd>
        <User>xxx</User>
        <User>xxx</User>
        <Course>
            <CourseCode>coursecode1</CourseCode>
            <Coach>coach1</Coach>
        <User>username1</User>
        <User>username2</User>
        </Course>
    </Session>

    <Session>
        <SessionName>xxx</SessionName>
        <Coach>xxx</Coach>
        <DateStart>xxx</DateStart>
        <DateEnd>xxx</DateEnd>
        <User>xxx</User>
        <User>xxx</User>
        <Course>
            <CourseCode>coursecode1</CourseCode>
            <Coach>coach1</Coach>
        <User>username1</User>
        <User>username2</User>
        </Course>
    </Session>
</Sessions>