123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * @package chamilo.admin
- */
- $language_file = array('admin', 'registration');
- $cidReset = true;
- //require_once '../inc/global.inc.php';
- $this_section = SECTION_PLATFORM_ADMIN;
- api_protect_admin_script(true);
- $form_sent = 0;
- $error_message = '';
- if (isset($_GET['action']) && $_GET['action'] == 'show_message') {
- $error_message = Security::remove_XSS($_GET['message']);
- }
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tool_name = get_lang('ImportSessionListXMLCSV');
- $interbreadcrumb[] = array('url' => '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 <Sessions> <Users> 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.'<br />';
- }
- $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.'<br />';
- }
- $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 <Sessions> <Courses> 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 <Sessions> 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.'<br />';
- // 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.'<br />';
- }
- }
- // 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.'<br />';
- }
- }
- $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.'<br />';
- }
- }
- // 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.'<br />';
- }
- }
- $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.'<br />';
- }
- */
- }
- 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').' :<br />'.$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 '<div class="actions">';
- echo '<a href="../admin/index.php">'.Display::return_icon('back.png', get_lang('BackTo').' '.get_lang('PlatformAdmin'),'',ICON_SIZE_MEDIUM).'</a>';
- echo '</div>';
- 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'), '<a href="example_session.csv" target="_blank">'.get_lang('ExampleCSVFile').'</a>'), 'CSV', 'csv');
- $form->addElement('radio', 'file_type', array(null, '<a href="example_session.xml" target="_blank">'.get_lang('ExampleXMLFile').'</a>'), '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();
- ?>
- <font color="gray">
- <p><?php echo get_lang('CSVMustLookLike').' ('.get_lang('MandatoryFields').')'; ?> :</p>
- <blockquote>
- <pre>
- <strong>SessionName</strong>;Coach;<strong>DateStart</strong>;<strong>DateEnd</strong>;Users;Courses
- <strong>xxx1</strong>;xxx;<strong>xxx;xxx</strong>;username1|username2;course1[coach1][username1,username2,...]|course2[coach1][username1,username2,...]
- <strong>xxx2</strong>;xxx;<strong>xxx;xxx</strong>;username1|username2;course1[coach1][username1,username2,...]|course2[coach1][username1,username2,...]
- </pre>
- </blockquote>
- <p><?php echo get_lang('XMLMustLookLike').' ('.get_lang('MandatoryFields').')'; ?> :</p>
- <blockquote>
- <pre>
- <?xml version="1.0" encoding="<?php echo api_get_system_encoding(); ?>"?>
- <Sessions>
- <Users>
- <User>
- <Username><strong>username1</strong></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><strong>xxx</strong></CourseCode>
- <CourseTeacher><strong>teacher_username</strong></CourseTeacher>
- <CourseLanguage>xxx</CourseLanguage>
- <CourseTitle>xxx</CourseTitle>
- <CourseDescription>xxx</CourseDescription>
- </Course>
- </Courses>
- <Session>
- <strong><SessionName>xxx</SessionName></strong>
- <Coach>xxx</Coach>
- <strong><DateStart>xxx</DateStart></strong>
- <strong><DateEnd>xxx</DateEnd></strong>
- <User>xxx</User>
- <User>xxx</User>
- <Course>
- <CourseCode>coursecode1</CourseCode>
- <Coach>coach1</Coach>
- <User>username1</User>
- <User>username2</User>
- </Course>
- </Session>
- <Session>
- <strong><SessionName>xxx</SessionName></strong>
- <Coach>xxx</Coach>
- <strong><DateStart>xxx</DateStart></strong>
- <strong><DateEnd>xxx</DateEnd></strong>
- <User>xxx</User>
- <User>xxx</User>
- <Course>
- <CourseCode>coursecode1</CourseCode>
- <Coach>coach1</Coach>
- <User>username1</User>
- <User>username2</User>
- </Course>
- </Session>
- </Sessions>
- </pre>
- </blockquote>
- </font>
- <?php
- /* FOOTER */
- Display::display_footer();
|