Chamilo is a learning management system focused on ease of use and accessibility
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.
chamilo-lms/main/inc/lib/course.lib.php

1379 lines
47 KiB

<?php
/*
==============================================================================
Dokeos - elearning and course management software
Copyright (c) 2004-2005 Dokeos S.A.
Copyright (c) 2001 Universite catholique de Louvain (UCL)
Copyright (c) Roan Embrechts, Vrije Universiteit Brussel
Copyright (c) Bart Mollet, Hogeschool Gent
Copyright (c) Yannick Warnier, Dokeos S.A.
For a full list of contributors, see "credits.txt".
The full license can be read in "license.txt".
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
See the GNU General Public License for more details.
Contact address: Dokeos, 44 rue des palais, B-1030 Brussels, Belgium
Mail: info@dokeos.com
==============================================================================
*/
/**
==============================================================================
* This is the course library for Dokeos.
*
* All main course functions should be placed here.
* Many functions of this library deal with providing support for
* virtual/linked/combined courses (this was already used in several universities
* but not available in standard Dokeos).
*
* The implementation changed, initially a course was a real course
* if target_course_code was 0 , this was changed to NULL.
* There are probably some places left with the wrong code.
*
* @package dokeos.library
==============================================================================
*/
/*
==============================================================================
DOCUMENTATION
(list not up to date, you can auto generate documentation with phpDocumentor)
CourseManager::get_real_course_code_select_html($element_name, $has_size=true, $only_current_user_courses=true)
CourseManager::check_parameter($parameter, $error_message)
CourseManager::check_parameter_or_fail($parameter, $error_message)
CourseManager::is_existing_course_code($wanted_course_code)
CourseManager::get_real_course_list()
CourseManager::get_virtual_course_list()
GENERAL COURSE FUNCTIONS
CourseManager::get_access_settings($course_code)
CourseManager::set_course_tool_visibility($tool_table_id, $visibility)
CourseManager::get_user_in_course_status($user_id, $course_code)
CourseManager::add_user_to_course($user_id, $course_code)
CourseManager::get_virtual_course_info($real_course_code)
CourseManager::is_virtual_course_from_visual_code($visual_code)
CourseManager::is_virtual_course_from_system_code($system_code)
CourseManager::get_virtual_courses_linked_to_real_course($real_course_code)
CourseManager::get_list_of_virtual_courses_for_specific_user_and_real_course($user_id, $real_course_code)
CourseManager::has_virtual_courses_from_code($real_course_code, $user_id)
CourseManager::get_target_of_linked_course($virtual_course_code)
TITLE AND CODE FUNCTIONS
DEPRECATED CourseManager::determine_course_title($user_id, $_cid, $_course)
CourseManager::determine_course_title_from_course_info($user_id, $course_info)
CourseManager::create_combined_name($user_is_registered_in_real_course, $real_course_name, $virtual_course_list)
CourseManager::create_combined_code($user_is_registered_in_real_course, $real_course_code, $virtual_course_list)
USER FUNCTIONS
CourseManager::get_real_course_list_of_user_as_course_admin($user_id)
CourseManager::get_course_list_of_user_as_course_admin($user_id)
CourseManager::is_user_subscribed_in_course($user_id, $course_code)
CourseManager::is_user_subscribed_in_real_or_linked_course($user_id, $course_code)
CourseManager::get_user_list_from_course_code($course_code)
CourseManager::get_real_and_linked_user_list($course_code);
GROUP FUNCTIONS
CourseManager::get_group_list_of_course($course_code)
CREATION FUNCTIONS
CourseManager::attempt_create_virtual_course($real_course_code, $course_title, $wanted_course_code, $course_language, $course_category)
==============================================================================
*/
/*
==============================================================================
INIT SECTION
==============================================================================
*/
/*
-----------------------------------------------------------
Configuration files
-----------------------------------------------------------
*/
include_once (api_get_path(CONFIGURATION_PATH).'add_course.conf.php');
/*
-----------------------------------------------------------
Libraries
we assume main_api is also included...
-----------------------------------------------------------
*/
include_once (api_get_path(LIBRARY_PATH).'database.lib.php');
include_once (api_get_path(LIBRARY_PATH).'add_course.lib.inc.php');
/*
-----------------------------------------------------------
Constants
-----------------------------------------------------------
*/
//LOGIC: course visibility and registration settings
/*
COURSE VISIBILITY
MAPPING OLD SETTINGS TO NEW SETTINGS
-----------------------
NOT_VISIBLE_NO_SUBSCRIPTION_ALLOWED
--> COURSE_VISIBILITY_REGISTERED, SUBSCRIBE_NOT_ALLOWED
NOT_VISIBLE_SUBSCRIPTION_ALLOWED
--> COURSE_VISIBILITY_REGISTERED, SUBSCRIBE_ALLOWED
VISIBLE_SUBSCRIPTION_ALLOWED
--> COURSE_VISIBILITY_OPEN_PLATFORM, SUBSCRIBE_ALLOWED
VISIBLE_NO_SUBSCRIPTION_ALLOWED
--> COURSE_VISIBILITY_OPEN_PLATFORM, SUBSCRIBE_NOT_ALLOWED
*/
//OLD SETTINGS
define("NOT_VISIBLE_NO_SUBSCRIPTION_ALLOWED", 0);
define("NOT_VISIBLE_SUBSCRIPTION_ALLOWED", 1);
define("VISIBLE_SUBSCRIPTION_ALLOWED", 2);
define("VISIBLE_NO_SUBSCRIPTION_ALLOWED", 3);
//NEW SETTINGS
//these are now defined in the main_api.lib.php
/*
COURSE_VISIBILITY_CLOSED
COURSE_VISIBILITY_REGISTERED
COURSE_VISIBILITY_OPEN_PLATFORM
COURSE_VISIBILITY_OPEN_WORLD
SUBSCRIBE_ALLOWED
SUBSCRIBE_NOT_ALLOWED
UNSUBSCRIBE_ALLOWED
UNSUBSCRIBE_NOT_ALLOWED
*/
/*
-----------------------------------------------------------
Variables
-----------------------------------------------------------
*/
$TABLECOURSE = Database :: get_main_table(MAIN_COURSE_TABLE);
$TABLECOURSDOMAIN = Database :: get_main_table(MAIN_CATEGORY_TABLE);
$TABLEUSER = Database :: get_main_table(MAIN_USER_TABLE);
$TABLECOURSUSER = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$TABLEANNOUNCEMENTS = "announcement";
$coursesRepositories = $rootSys;
/*
==============================================================================
CourseManager CLASS
==============================================================================
*/
/**
* @package dokeos.library
*/
class CourseManager
{
/**
* Returns all the information of a given coursecode
* @param string $course_code, the course code
* @return an array with all the fields of the course table
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
*/
function get_course_information($course_code)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql="SELECT * FROM ".$course_table." WHERE code='".$course_code."'";
$sql_result = api_sql_query($sql, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
return $result;
}
/**
* Returns the access settings of the course:
* which visibility;
* wether subscribing is allowed;
* wether unsubscribing is allowed.
*
* @param string $course_code, the course code
* @todo for more consistency: use course_info call from database API
* @return an array with int fields "visibility", "subscribe", "unsubscribe"
*/
function get_access_settings($course_code)
{
$system_code = $course_info["sysCode"];
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql = "SELECT `visibility`, `subscribe`, `unsubscribe` from ".$course_table." where `code` = '".$course_code."'";
$sql_result = api_sql_query($sql, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
return $result;
}
/**
* Returns the status of a user in a course, which is COURSEMANAGER or STUDENT.
*
* @return int the status of the user in that course
*/
function get_user_in_course_status($user_id, $course_code)
{
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "SELECT * FROM $course_user_table WHERE `course_code` = '$course_code' AND `user_id` = '$user_id'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
return $result["status"];
}
/**
* Change the status of a user in a course, status can be COURSEMANAGER or STUDENT.
* @deprecated Function not in use
*/
function set_user_in_course_status($user_id, $course_code, $status)
{
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "UPDATE $course_user_table SET status = '$status' WHERE `course_code` = '$course_code' AND `user_id` = '$user_id'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
return $result["status"];
}
/**
* Unsubscribe one or more users from a course
* @param int|array $user_id
* @param string $course_code
*/
function unsubscribe_user($user_id, $course_code)
{
if(!is_array($user_id))
{
$user_id = array($user_id);
}
if(count($user_id) == 0)
{
return;
}
$user_ids = implode(',', $user_id);
$table_course_user = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$table_course = Database :: get_main_table(MAIN_COURSE_TABLE);
// Unsubscribe user from all groups in the course
$sql = "SELECT * FROM $table_course WHERE code = '".$course_code."'";
$res = api_sql_query($sql, __FILE__, __LINE__);
$course = mysql_fetch_object($res);
$table_group = Database :: get_course_table(GROUP_USER_TABLE, $course->db_name);
$sql = "DELETE FROM $table_group WHERE user_id IN (".$user_ids.")";
api_sql_query($sql, __FILE__, __LINE__);
// Unsubscribe user from all blogs in the course
$table_blog_user = Database::get_course_table(BLOGS_REL_USER_TABLE, $course->db_name);
$sql = "DELETE FROM ".$table_blog_user." WHERE user_id IN (".$user_ids.")";
api_sql_query($sql,__FILE__,__LINE__);
$table_blogtask_user = Database::get_course_table(BLOGS_TASKS_REL_USER, $course->db_name);
$sql = "DELETE FROM ".$table_blogtask_user." WHERE user_id IN (".$user_ids.")";
api_sql_query($sql,__FILE__,__LINE__);
// Unsubscribe user from the course
$sql = "DELETE FROM $table_course_user WHERE user_id IN (".$user_ids.") AND course_code = '".$course_code."'";
api_sql_query($sql, __FILE__, __LINE__);
}
/**
* Subscribe a user to a course. No checks are performed here to see if
* course subscription is allowed.
* @see add_user_to_course
*/
function subscribe_user($user_id, $course_code, $status = STUDENT)
{
$user_table = Database :: get_main_table(MAIN_USER_TABLE);
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$location_table = Database :: get_main_table(MAIN_LOCATION_TABLE);
$user_role_table = Database :: get_main_table(MAIN_USER_ROLE_TABLE);
$status = ($status == STUDENT || $status == COURSEMANAGER) ? $status : STUDENT;
$role_id = ($status == COURSEMANAGER) ? COURSE_ADMIN : NORMAL_COURSE_MEMBER;
if (empty ($user_id) || empty ($course_code))
{
return false;
}
else
{
// previously check if the user are already registered on the platform
$handle = api_sql_query("SELECT status FROM ".$user_table."
WHERE `user_id` = '$user_id' ");
if (mysql_num_rows($handle) == 0)
{
return false; // the user isn't registered to the platform
}
else
{
//check if user isn't already subscribed to the course
$handle = api_sql_query("SELECT * FROM ".$course_user_table."
WHERE `user_id` = '$user_id'
AND `course_code` ='$course_code'");
if (mysql_num_rows($handle) > 0)
{
return false; // the user is already subscribed to the course
}
else
{
$max_sort = api_max_sort_value('0', $user_id);
$add_course_user_entry_sql = "INSERT INTO ".$course_user_table."
SET `course_code` = '$course_code',
`user_id` = '$user_id',
`status` = '".$status."',
`sort` = '". ($max_sort +1)."'";
$result = api_sql_query($add_course_user_entry_sql);
if ($result)
{
return true;
}
else
{
return false;
}
}
}
}
}
/**
* Subscribe a user $user_id to a course $course_code.
* @author Hugues Peeters
* @author Roan Embrechts
*
* @param int $user_id the id of the user
* @param string $course_code the course code
* @param string $status (optional) The user's status in the course
*
* @return boolean true if subscription succeeds, boolean false otherwise.
* @todo script has ugly ifelseifelseifelseif structure, improve
*/
function add_user_to_course($user_id, $course_code, $status = STUDENT)
{
$user_table = Database :: get_main_table(MAIN_USER_TABLE);
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$status = ($status == STUDENT || $status == COURSEMANAGER) ? $status : STUDENT;
if (empty($user_id) || empty ($course_code))
{
return false;
}
else
{
// previously check if the user are already registered on the platform
$handle = api_sql_query("SELECT status FROM ".$user_table."
WHERE `user_id` = '$user_id' ");
if (mysql_num_rows($handle) == 0)
{
return false; // the user isn't registered to the platform
}
else
{
//check if user isn't already subscribed to the course
$handle = api_sql_query("SELECT * FROM ".$course_user_table."
WHERE `user_id` = '$user_id'
AND `course_code` ='$course_code'");
if (mysql_num_rows($handle) > 0)
{
return false; // the user is already subscribed to the course
}
else
{
// previously check if subscription is allowed for this course
$handle = api_sql_query("SELECT code, visibility FROM ".$course_table."
WHERE `code` = '$course_code'
AND `subscribe` = '".SUBSCRIBE_NOT_ALLOWED."'");
if (mysql_num_rows($handle) > 0)
{
return false; // subscription not allowed for this course
}
else
{
$max_sort = api_max_sort_value('0', $user_id);
$add_course_user_entry_sql = "INSERT INTO ".$course_user_table."
SET `course_code` = '$course_code',
`user_id` = '$user_id',
`status` = '".$status."',
`sort` = '". ($max_sort +1)."'";
$result=api_sql_query($add_course_user_entry_sql);
if ($result)
{
return true;
}
else
{
return false;
}
}
}
}
}
}
/**
* This code creates a select form element to let the user
* choose a real course to link to.
*
* A good non-display library should not use echo statements, but just return text/html
* so users of the library can choose when to display.
*
* We display the course code, but internally store the course id.
*
* @param boolean $has_size, true the select tag gets a size element, false it stays a dropdownmenu
* @param boolean $only_current_user_courses, true only the real courses of which the
* current user is course admin are displayed, false all real courses are shown.
* @param string $element_name the name of the select element
* @return a string containing html code for a form select element.
* @deprecated Function not in use
*/
function get_real_course_code_select_html($element_name, $has_size = true, $only_current_user_courses = true, $user_id)
{
if ($only_current_user_courses == true)
{
$real_course_list = CourseManager :: get_real_course_list_of_user_as_course_admin($user_id);
}
else
{
$real_course_list = CourseManager :: get_real_course_list();
}
if ($has_size == true)
{
$size_element = "size=\"".SELECT_BOX_SIZE."\"";
}
else
{
$size_element = "";
}
$html_code = "<select name=\"$element_name\" $size_element >\n";
foreach ($real_course_list as $real_course)
{
$course_code = $real_course["code"];
$html_code .= "<option value=\"".$course_code."\">";
$html_code .= $course_code;
$html_code .= "</option>\n";
}
$html_code .= "</select>\n";
return $html_code;
}
/**
* Checks wether a parameter exists.
* If it doesn't, the function displays an error message.
*
* @return true if parameter is set and not empty, false otherwise
* @todo move function to better place, main_api ?
*/
function check_parameter($parameter, $error_message)
{
if (!isset ($parameter) || empty ($parameter))
{
Display :: display_normal_message($error_message);
return false;
}
return true;
}
/**
* Lets the script die when a parameter check fails.
* @todo move function to better place, main_api ?
*/
function check_parameter_or_fail($parameter, $error_message)
{
if (!CourseManager :: check_parameter($parameter, $error_message))
die();
}
/**
* @return true if there already are one or more courses
* with the same code OR visual_code (visualcode), false otherwise
*/
function is_existing_course_code($wanted_course_code)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT COUNT(*) as number FROM ".$course_table."WHERE `code` = '$wanted_course_code' OR `visual_code` = '$wanted_course_code' ";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
if ($result["number"] > 0)
{
return true;
}
else
{
return false;
}
}
/**
* @return an array with the course info of all real courses on the platform
*/
function get_real_course_list()
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $course_table WHERE `target_course_code` IS NULL";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($result = mysql_fetch_array($sql_result))
{
$real_course_list[] = $result;
}
return $real_course_list;
}
/**
* @return an array with the course info of all virtual courses on the platform
*/
function get_virtual_course_list()
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $course_table WHERE `target_course_code` IS NOT NULL";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($result = mysql_fetch_array($sql_result))
{
$virtual_course_list[] = $result;
}
return $virtual_course_list;
}
/**
* @return an array with the course info of the real courses of which
* the current user is course admin
*/
function get_real_course_list_of_user_as_course_admin($user_id)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = " SELECT *
FROM $course_table course
LEFT JOIN $course_user_table course_user
ON course.`code` = course_user.`course_code`
WHERE course.`target_course_code` IS NULL
AND course_user.`user_id` = '$user_id'
AND course_user.`status` = '1'";
//api_display_debug_info($sql_query);
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($result = mysql_fetch_array($sql_result))
{
$result_array[] = $result;
}
return $result_array;
}
/**
* @return an array with the course info of all the courses (real and virtual) of which
* the current user is course admin
*/
function get_course_list_of_user_as_course_admin($user_id)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = " SELECT *
FROM $course_table course
LEFT JOIN $course_user_table course_user
ON course.`code` = course_user.`course_code`
WHERE course_user.`user_id` = '$user_id'
AND course_user.`status` = '1'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($result = mysql_fetch_array($sql_result))
{
$result_array[] = $result;
}
return $result_array;
}
/**
* @deprecated use determine_course_title_from_course_info($user_id,
* $course_info) instead Declares global $_course
*/
function determine_course_title($user_id, $_cid, $_course)
{
global $_course;
$real_course_code = $_course['sysCode'];
$real_course_info = Database :: get_course_info($real_course_code);
$real_course_name = $real_course_info["title"];
$real_course_visual_code = $real_course_info["visual_code"];
//is the user registered in the real course?
$table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "SELECT * FROM $table WHERE `user_id` = '$user_id' AND `course_code` = '$real_course_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
if (!isset ($result) || empty ($result))
{
$user_is_registered_in_real_course = false;
}
else
{
$user_is_registered_in_real_course = true;
}
//get a list of virtual courses linked to the current real course
//and to which the current user is subscribed
$user_subscribed_virtual_course_list = CourseManager :: get_list_of_virtual_courses_for_specific_user_and_real_course($user_id, $real_course_code);
if (count($user_subscribed_virtual_course_list) > 0)
{
$virtual_courses_exist = true;
}
else
{
$virtual_courses_exist = false;
}
//now determine course code and name
if ($user_is_registered_in_real_course && $virtual_courses_exist)
{
$_course["name"] = CourseManager :: create_combined_name($user_is_registered_in_real_course, $real_course_name, $user_subscribed_virtual_course_list);
$_course['official_code'] = CourseManager :: create_combined_code($user_is_registered_in_real_course, $real_course_visual_code, $user_subscribed_virtual_course_list);
}
else
if ($user_is_registered_in_real_course)
{
//course name remains real course name
$_course["name"] = $real_course_name;
$_course['official_code'] = $real_course_visual_code;
}
else
if ($virtual_courses_exist)
{
$_course["name"] = CourseManager :: create_combined_name($user_is_registered_in_real_course, $real_course_name, $user_subscribed_virtual_course_list);
$_course['official_code'] = CourseManager :: create_combined_code($user_is_registered_in_real_course, $real_course_visual_code, $user_subscribed_virtual_course_list);
}
else
{
//course name remains real course name
$_course["name"] = $real_course_name;
$_course['official_code'] = $real_course_visual_code;
}
$result_title = $_course["name"];
return $result_title;
}
/**
* Find out for which courses the user is registered and determine a visual course code and course title from that.
* Takes virtual courses into account
*
* Default case: the name and code stay what they are.
*
* Scenarios:
* - User is registered in real course and virtual courses; name / code become a mix of all
* - User is registered in real course only: name stays that of real course
* - User is registered in virtual course only: name becomes that of virtual course
* - user is not registered to any of the real/virtual courses: name stays that of real course
* (I'm not sure about the last case, but this seems not too bad)
*
* @author Roan Embrechts
* @param $user_id, the id of the user
* @param $course_info, an array with course info that you get using Database::get_course_info($course_system_code);
* @return an array with indices
* $return_result["title"] - the course title of the combined courses
* $return_result["code"] - the course code of the combined courses
*/
function determine_course_title_from_course_info($user_id, $course_info)
{
$real_course_id = $course_info['system_code'];
$real_course_info = Database :: get_course_info($real_course_id);
$real_course_name = $real_course_info["title"];
$real_course_visual_code = $real_course_info["visual_code"];
$real_course_real_code = $course_info['system_code'];
//is the user registered in the real course?
$table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "SELECT * FROM $table WHERE `user_id` = '$user_id' AND `course_code` = '$real_course_real_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
if (!isset ($result) || empty ($result))
{
$user_is_registered_in_real_course = false;
}
else
{
$user_is_registered_in_real_course = true;
}
//get a list of virtual courses linked to the current real course
//and to which the current user is subscribed
$user_subscribed_virtual_course_list = CourseManager :: get_list_of_virtual_courses_for_specific_user_and_real_course($user_id, $real_course_id);
if (count($user_subscribed_virtual_course_list) > 0)
{
$virtual_courses_exist = true;
}
else
{
$virtual_courses_exist = false;
}
//now determine course code and name
if ($user_is_registered_in_real_course && $virtual_courses_exist)
{
$course_info["name"] = CourseManager :: create_combined_name($user_is_registered_in_real_course, $real_course_name, $user_subscribed_virtual_course_list);
$course_info['official_code'] = CourseManager :: create_combined_code($user_is_registered_in_real_course, $real_course_visual_code, $user_subscribed_virtual_course_list);
}
else
if ($user_is_registered_in_real_course)
{
//course name remains real course name
$course_info["name"] = $real_course_name;
$course_info['official_code'] = $real_course_visual_code;
}
else
if ($virtual_courses_exist)
{
$course_info["name"] = CourseManager :: create_combined_name($user_is_registered_in_real_course, $real_course_name, $user_subscribed_virtual_course_list);
$course_info['official_code'] = CourseManager :: create_combined_code($user_is_registered_in_real_course, $real_course_visual_code, $user_subscribed_virtual_course_list);
}
else
{
//course name remains real course name
$course_info["name"] = $real_course_name;
$course_info['official_code'] = $real_course_visual_code;
}
$return_result["title"] = $course_info["name"];
$return_result["code"] = $course_info['official_code'];
return $return_result;
}
/**
* Create a course title based on all real and virtual courses the user is registered in.
* @param boolean $user_is_registered_in_real_course
* @param string $real_course_name, the title of the real course
* @param array $virtual_course_list, the list of virtual courses
*/
function create_combined_name($user_is_registered_in_real_course, $real_course_name, $virtual_course_list)
{
if ($user_is_registered_in_real_course || count($virtual_course_list) > 1)
{
$complete_course_name_before = get_lang("CombinedCourse")." "; //from course_home lang file
}
if ($user_is_registered_in_real_course)
{
//add real name to result
$complete_course_name[] = $real_course_name;
}
//add course titles of all virtual courses to the list
foreach ($virtual_course_list as $current_course)
{
$complete_course_name[] = $current_course["title"];
}
$complete_course_name = $complete_course_name_before.implode(' &amp; ', $complete_course_name);
return $complete_course_name;
}
/**
* Create a course code based on all real and virtual courses the user is registered in.
*/
function create_combined_code($user_is_registered_in_real_course, $real_course_code, $virtual_course_list)
{
$complete_course_code .= "";
if ($user_is_registered_in_real_course)
{
//add real name to result
$complete_course_code[] = $real_course_code;
}
//add course titles of all virtual courses to the list
foreach ($virtual_course_list as $current_course)
{
$complete_course_code[] = $current_course["visual_code"];
}
$complete_course_code = implode(' &amp; ', $complete_course_code);
return $complete_course_code;
}
/**
* Return course info array of virtual course
*
* Note this is different from getting information about a real course!
*
* @param $real_course_code, the id of the real course which the virtual course is linked to
*/
function get_virtual_course_info($real_course_code)
{
$table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $table WHERE `target_course_code` = '$real_course_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = array ();
while ($virtual_course = mysql_fetch_array($sql_result))
{
$result[] = $virtual_course;
}
return $result;
}
/**
* @param string $system_code, the system code of the course
* @return true if the course is a virtual course, false otherwise
*/
function is_virtual_course_from_system_code($system_code)
{
$table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $table WHERE `code` = '$system_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
$target_number = $result["target_course_code"];
if ($target_number == NULL)
{
return false; //this is not a virtual course
}
else
{
return true; //this is a virtual course
}
}
/**
* What's annoying is that you can't overload functions in PHP.
* @return true if the course is a virtual course, false otherwise
*/
function is_virtual_course_from_visual_code($visual_code)
{
$table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $table WHERE `visual_code` = '$visual_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
$target_number = $result["target_course_code"];
if ($target_number == NULL)
{
return false; //this is not a virtual course
}
else
{
return true; //this is a virtual course
}
}
/**
* @return true if the real course has virtual courses that the user is subscribed to, false otherwise
*/
function has_virtual_courses_from_code($real_course_code, $user_id)
{
$user_subscribed_virtual_course_list = CourseManager :: get_list_of_virtual_courses_for_specific_user_and_real_course($user_id, $real_course_code);
$number_of_virtual_courses = count($user_subscribed_virtual_course_list);
if (count($user_subscribed_virtual_course_list) > 0)
{
return true;
}
else
{
return false;
}
}
/**
* Return an array of arrays, listing course info of all virtual course
* linked to the real course ID $real_course_code
*
* @param $real_course_code, the id of the real course which the virtual courses are linked to
*/
function get_virtual_courses_linked_to_real_course($real_course_code)
{
$table = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql_query = "SELECT * FROM $table WHERE `target_course_code` = '$real_course_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result_array = array ();
while ($result = mysql_fetch_array($sql_result))
{
$result_array[] = $result;
}
return $result_array;
}
/**
* This function returns the course code of the real course
* to which a virtual course is linked.
*
* @param the course code of the virtual course
* @return the course code of the real course
*/
function get_target_of_linked_course($virtual_course_code)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
//get info about the virtual course
$sql_query = "SELECT * FROM $course_table WHERE `code` = '$virtual_course_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
$target_course_code = $result["target_course_code"];
return $target_course_code;
}
/*
==============================================================================
USER FUNCTIONS
==============================================================================
*/
/**
* Return course info array of virtual course
*
* @param $user_id, the id (int) of the user
* @param $course_info, array with info about the course (comes from course table)
*
* @return true if the user is registered in the course, false otherwise
*/
function is_user_subscribed_in_course($user_id, $course_code)
{
$table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "SELECT * FROM $table WHERE `user_id` = '$user_id' AND `course_code` = '$course_code'";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
if (!isset ($result) || empty ($result))
{
return false; //user is not registered in course
}
else
{
return true; //user is registered in course
}
}
/**
* Is the user subscribed in the real course or linked courses?
*
* @param $user_id, the id (int) of the user
* @param $course_info, array with info about the course (comes from course table, see database lib)
*
* @return true if the user is registered in the real course or linked courses, false otherwise
*/
function is_user_subscribed_in_real_or_linked_course($user_id, $course_code, $session_id='')
{
if($session_id==''){
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = " SELECT *
FROM $course_table course
LEFT JOIN $course_user_table course_user
ON course.`code` = course_user.`course_code`
WHERE course_user.`user_id` = '$user_id' AND ( course.`code` = '$course_code' OR `target_course_code` = '$course_code') ";
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
$result = mysql_fetch_array($sql_result);
if (!isset ($result) || empty ($result))
{
return false; //user is not registered in course
}
else
{
return true; //user is registered in course
}
}
else {
// is he subscribed to the course of the session ?
$tbl_sessions = Database::get_main_table(MAIN_SESSION_TABLE);
$tbl_sessions_course = Database::get_main_table(MAIN_SESSION_COURSE_TABLE);
$tbl_session_course_user= Database::get_main_table(MAIN_SESSION_COURSE_USER_TABLE);
$_cid = $course_info["code"];
//users
$sql = "SELECT id_user
FROM $tbl_session_course_user
WHERE id_session='".$_SESSION['id_session']."'
AND id_user='$user_id'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if(mysql_num_rows($result))
return true;
// is it a course coach ?
$sql = "SELECT id_coach
FROM $tbl_sessions_course AS session_course
WHERE id_session='".$_SESSION['id_session']."'
AND id_coach = '$user_id'
AND course_code='$_cid'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if(mysql_num_rows($result))
return true;
// is it a session coach ?
$sql = "SELECT id_coach
FROM $tbl_sessions AS session
WHERE session.id='".$_SESSION['id_session']."'
AND id_coach='$user_id'";
$result = api_sql_query($sql,__FILE__,__LINE__);
if(mysql_num_rows($result))
return true;
return false;
}
}
/**
* Return user info array of all users registered in the specified real or virtual course
* This only returns the users that are registered in this actual course, not linked courses.
*
* @param string $course_code
* @return array with user info
*/
function get_user_list_from_course_code($course_code)
{
if(api_get_setting('use_session_mode')!='true')
{
$table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$sql_query = "SELECT * FROM $table WHERE `course_code` = '$course_code' ORDER BY `status`";
}
else
{
$table = Database::get_main_table(MAIN_SESSION_COURSE_USER_TABLE);
$sql_query = "SELECT id_user as user_id FROM $table WHERE `course_code` = '$course_code' AND id_session = '".$_SESSION['id_session']."'";
}
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($course_user_info = mysql_fetch_array($sql_result))
{
$user_id = $course_user_info["user_id"];
$user_info = Database :: get_user_info_from_id($user_id);
//add extra fields from course_user table
$user_info["status"] = $course_user_info["status"];
$user_info["role"] = $course_user_info["role"];
$user_info["tutor_id"] = $course_user_info["tutor_id"];
$result_array[] = $user_info;
}
return $result_array;
}
/**
* Return user info array of all users registered in the specified course
* this includes the users of the course itsel and the users of all linked courses.
*
* @param array $course_info
* @return array with user info
*/
function get_real_and_linked_user_list($course_code)
{
//get list of virtual courses
$virtual_course_list = CourseManager :: get_virtual_courses_linked_to_real_course($course_code);
//get users from real course
$user_list = CourseManager :: get_user_list_from_course_code($course_code);
foreach ($user_list as $this_user)
{
$complete_user_list[] = $this_user;
}
//get users from linked courses
foreach ($virtual_course_list as $this_course)
{
$course_code = $this_course["code"];
$user_list = CourseManager :: get_user_list_from_course_code($course_code);
foreach ($user_list as $this_user)
{
$complete_user_list[] = $this_user;
}
}
return $complete_user_list;
}
/**
* Return an array of arrays, listing course info of all courses in the list
* linked to the real course $real_course_code, to which the user $user_id is subscribed.
*
* @param $user_id, the id (int) of the user
* @param $real_course_code, the id (char) of the real course
*
* @return array of course info arrays
*/
function get_list_of_virtual_courses_for_specific_user_and_real_course($user_id, $real_course_code)
{
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$course_user_table = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
if(api_get_setting("use_session_mode")!="true"){
$sql_query = " SELECT *
FROM $course_table course
LEFT JOIN $course_user_table course_user
ON course.`code` = course_user.`course_code`
WHERE course.`target_course_code` = '$real_course_code' AND course_user.`user_id` = '$user_id'";
}
else {
$sql_query = "SELECT course.*
FROM $course_table
INNER JOIN ".Database :: get_main_table(MAIN_SESSION_COURSE_USER_TABLE)." course_user
ON course.code = course_user.course_code
AND course_user.course_code = '$real_course_code'
AND course_user.id_user = '$user_id'
AND id_session = '".$_SESSION['id_session']."'";
}
$sql_result = api_sql_query($sql_query, __FILE__, __LINE__);
while ($result = mysql_fetch_array($sql_result))
{
$result_array[] = $result;
}
return $result_array;
}
/*
==============================================================================
GROUP FUNCTIONS
==============================================================================
*/
function get_group_list_of_course($course_code)
{
$course_info = Database :: get_course_info($course_code);
$database_name = $course_info['db_name'];
$group_table = Database :: get_course_table(GROUP_TABLE, $database_name);
$group_user_table = Database :: get_course_table(GROUP_USER_TABLE, $database_name);
$sql = "SELECT g.id, g.name, COUNT(gu.id) userNb
FROM $group_table AS g LEFT JOIN $group_user_table gu
ON g.id = gu.group_id
GROUP BY g.id
ORDER BY g.name";
$result = api_sql_query($sql, __FILE__, __LINE__) or die(mysql_error());
while ($group_data = mysql_fetch_array($result))
{
$group_list[$group_data['id']] = $group_data;
}
return $group_list;
}
/**
* Checks all parameters needed to create a virtual course.
* If they are all set, the virtual course creation procedure is called.
*
* Call this function instead of create_virtual_course
*/
function attempt_create_virtual_course($real_course_code, $course_title, $wanted_course_code, $course_language, $course_category)
{
//better: create parameter list, check the entire list, when false display errormessage
CourseManager :: check_parameter_or_fail($real_course_code, "Unspecified parameter: real course id.");
CourseManager :: check_parameter_or_fail($course_title, "Unspecified parameter: course title.");
CourseManager :: check_parameter_or_fail($wanted_course_code, "Unspecified parameter: wanted course code.");
CourseManager :: check_parameter_or_fail($course_language, "Unspecified parameter: course language.");
CourseManager :: check_parameter_or_fail($course_category, "Unspecified parameter: course category.");
$creation_success = CourseManager :: create_virtual_course($real_course_code, $course_title, $wanted_course_code, $course_language, $course_category);
return $creation_success;
}
/**
* This function creates a virtual course.
* It assumes all parameters have been checked and are not empty.
* It checks wether a course with the $wanted_course_code already exists.
*
* Users of this library should consider this function private,
* please call attempt_create_virtual_course instead of this one.
*
* NOTE:
* The virtual course 'owner' id (the first course admin) is set to the CURRENT user id.
* @return true if the course creation succeeded, false otherwise
* @todo research: expiration date of a course
*/
function create_virtual_course($real_course_code, $course_title, $wanted_course_code, $course_language, $course_category)
{
global $firstExpirationDelay;
$course_table = Database :: get_main_table(MAIN_COURSE_TABLE);
$user_id = api_get_user_id();
$real_course_info = Database :: get_course_info($real_course_code);
$real_course_code = $real_course_info["system_code"];
//check: virtual course creation fails if another course has the same
//code, real or fake.
if (CourseManager :: is_existing_course_code($wanted_course_code))
{
Display :: display_error_message($wanted_course_code." - ".get_lang("CourseCodeAlreadyExists"));
return false;
}
//add data to course table, course_rel_user
$course_sys_code = $wanted_course_code;
$course_screen_code = $wanted_course_code;
$course_repository = $real_course_info["directory"];
$course_db_name = $real_course_info["db_name"];
$responsible_teacher = $real_course_info["tutor_name"];
$faculty_shortname = $course_category;
// $course_title = $course_title;
// $course_language = $course_language;
$teacher_id = $user_id;
//HACK ----------------------------------------------------------------
$expiration_date = time() + $firstExpirationDelay;
//END HACK ------------------------------------------------------------
register_course($course_sys_code, $course_screen_code, $course_repository, $course_db_name, $responsible_teacher, $faculty_shortname, $course_title, $course_language, $teacher_id, $expiration_date);
//above was the normal course creation table update call,
//now one more thing: fill in the target_course_code field
$sql_query = "UPDATE $course_table SET `target_course_code` = '$real_course_code' WHERE `code` = '$course_sys_code' LIMIT 1 ";
api_sql_query($sql_query, __FILE__, __LINE__);
return true;
}
/**
* Delete a course
* This function deletes a whole course-area from the platform. When the
* given course is a virtual course, the database and directory will not be
* deleted.
* When the given course is a real course, also all virtual courses refering
* to the given course will be deleted.
* @param string $code The code of the course to delete
* @todo When deleting a virtual course: unsubscribe users from that virtual
* course from the groups in the real course if they are not subscribed in
* that real course.
* @todo Remove globals
*/
function delete_course($code)
{
global $_configuration, $dbGlu;
$table_course = Database :: get_main_table(MAIN_COURSE_TABLE);
$table_course_user = Database :: get_main_table(MAIN_COURSE_USER_TABLE);
$table_course_class = Database :: get_main_table(MAIN_COURSE_CLASS_TABLE);
$user_role_table = Database :: get_main_table(MAIN_USER_ROLE_TABLE);
$location_table = Database::get_main_table(MAIN_LOCATION_TABLE);
$role_right_location_table = Database::get_main_table(MAIN_ROLE_RIGHT_LOCATION_TABLE);
$sql = "SELECT * FROM $table_course WHERE code='".$code."'";
$res = api_sql_query($sql, __FILE__, __LINE__);
if (mysql_num_rows($res) == 0)
{
return;
}
CourseManager :: create_database_dump($code);
if (!CourseManager :: is_virtual_course_from_system_code($code))
{
$virtual_courses = CourseManager :: get_virtual_courses_linked_to_real_course($code);
foreach ($virtual_courses as $index => $virtual_course)
{
// Unsubscribe all classes from the virtual course
$sql = "DELETE FROM $table_course_class WHERE course_code='".$virtual_course['code']."'";
api_sql_query($sql, __FILE__, __LINE__);
// Unsubscribe all users from the virtual course
$sql = "DELETE FROM $table_course_user WHERE course_code='".$virtual_course['code']."'";
api_sql_query($sql, __FILE__, __LINE__);
// Delete the course from the database
$sql = "DELETE FROM $table_course WHERE code='".$virtual_course['code']."'";
api_sql_query($sql, __FILE__, __LINE__);
}
$sql = "SELECT * FROM $table_course WHERE code='".$code."'";
$res = api_sql_query($sql, __FILE__, __LINE__);
$course = mysql_fetch_object($res);
if (!$_configuration['single_database'])
{
$sql = "DROP DATABASE IF EXISTS ".$course->db_name;
api_sql_query($sql, __FILE__, __LINE__);
}
else
{
$db_pattern = $_configuration['table_prefix'].$course->db_name.$dbGlu;
$sql = "SHOW TABLES LIKE '$db_pattern%'";
$result = api_sql_query($sql, __FILE__, __LINE__);
while (list ($courseTable) = mysql_fetch_row($result))
{
api_sql_query("DROP TABLE `$courseTable`", __FILE__, __LINE__);
}
}
$course_dir = api_get_path(SYS_COURSE_PATH).$course->directory;
$garbage_dir = api_get_path(GARBAGE_PATH).$course->directory.'_'.time();
rename($course_dir, $garbage_dir);
}
// Unsubscribe all classes from the course
$sql = "DELETE FROM $table_course_class WHERE course_code='".$code."'";
api_sql_query($sql, __FILE__, __LINE__);
// Unsubscribe all users from the course
$sql = "DELETE FROM $table_course_user WHERE course_code='".$code."'";
api_sql_query($sql, __FILE__, __LINE__);
// Delete the course from the database
$sql = "DELETE FROM $table_course WHERE code='".$code."'";
api_sql_query($sql, __FILE__, __LINE__);
}
/**
* Creates a file called mysql_dump.sql in the course folder
* @param $course_code The code of the course
* @todo Implementation for single database
*/
function create_database_dump($course_code)
{
global $_configuration;
if ($_configuration['single_database'])
{
return;
}
$sql_dump = '';
$table_course = Database :: get_main_table(MAIN_COURSE_TABLE);
$sql = "SELECT * FROM $table_course WHERE code = '$course_code'";
$res = api_sql_query($sql, __FILE__, __LINE__);
$course = mysql_fetch_object($res);
$sql = "SHOW TABLES FROM $course->db_name";
$res = api_sql_query($sql, __FILE__, __LINE__);
while ($table = mysql_fetch_row($res))
{
$sql = "SELECT * FROM `$course->db_name`.`$table[0]`";
$res3 = api_sql_query($sql, __FILE__, __LINE__);
while ($row = mysql_fetch_assoc($res3))
{
foreach ($row as $key => $value)
{
$row[$key] = $key."='".addslashes($row[$key])."'";
}
$sql_dump .= "\nINSERT INTO $table[0] SET ".implode(', ', $row).';';
}
}
$file_name = api_get_path(SYS_COURSE_PATH).$course->directory.'/mysql_dump.sql';
$handle = fopen($file_name, 'a+');
fwrite($handle, $sql_dump);
fclose($handle);
}
} //end class CourseManager
?>