12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046 |
- <?php
- /* For licensing terms, see /license.txt */
- require_once 'Course.class.php';
- require_once 'Event.class.php';
- require_once 'Link.class.php';
- require_once 'ToolIntro.class.php';
- require_once 'Document.class.php';
- require_once 'ScormDocument.class.php';
- require_once 'LinkCategory.class.php';
- require_once 'CourseDescription.class.php';
- require_once 'ForumPost.class.php';
- require_once 'ForumTopic.class.php';
- require_once 'Forum.class.php';
- require_once 'ForumCategory.class.php';
- require_once 'Quiz.class.php';
- require_once 'QuizQuestion.class.php';
- require_once 'CourseCopyLearnpath.class.php';
- require_once 'Survey.class.php';
- require_once 'SurveyQuestion.class.php';
- require_once 'Glossary.class.php';
- require_once 'CourseSession.class.php';
- require_once 'wiki.class.php';
- require_once 'Thematic.class.php';
- require_once 'Attendance.class.php';
- require_once 'Work.class.php';
- /**
- * Class which can build a course-object from a Chamilo-course.
- * @author Bart Mollet <bart.mollet@hogent.be>
- * @package chamilo.backup
- */
- class CourseBuilder
- {
- /** Course */
- public $course;
- /* With this array you can filter the tools you want to be parsed by default all tools are included*/
- public $tools_to_build = array(
- 'announcements',
- 'attendance',
- 'course_descriptions',
- 'documents',
- 'events',
- 'forum_category',
- 'forums',
- 'forum_topics',
- 'glossary',
- 'quizzes',
- 'learnpaths',
- 'links',
- 'surveys',
- 'tool_intro',
- 'thematic',
- 'wiki',
- 'works'
- );
- /* With this array you can filter wich elements of the tools are going to be added in the course obj (only works with LPs) */
- public $specific_id_list = array();
- /**
- * Create a new CourseBuilder
- */
- public function __construct($type='', $course = null)
- {
- $_course = api_get_course_info();
- if (!empty($course['official_code'])){
- $_course = $course;
- }
- $this->course = new Course();
- $this->course->code = $_course['official_code'];
- $this->course->type = $type;
- $this->course->path = api_get_path(SYS_COURSE_PATH).$_course['path'].'/';
- $this->course->backup_path = api_get_path(SYS_COURSE_PATH).$_course['path'];
- $this->course->encoding = api_get_system_encoding(); //current platform encoding
- $this->course->db_name = $_course['dbName'];
- $this->course->info = $_course;
- }
- /**
- *
- * @param type $array
- */
- function set_tools_to_build($array)
- {
- $this->tools_to_build = $array;
- }
- /**
- *
- * @param type $array
- */
- function set_tools_specific_id_list($array)
- {
- $this->specific_id_list = $array;
- }
- /**
- * Get the created course
- * @return course The course
- */
- function get_course()
- {
- return $this->course;
- }
- /**
- * Build the course-object
- *
- * @param int session_id
- * @param string course_code
- * @param bool true if you want to get the elements that exists in the course and
- * in the session, (session_id = 0 or session_id = X)
- */
- function build($session_id = 0, $course_code = '', $with_base_content = false)
- {
- $table_link = Database :: get_course_table(TABLE_LINKED_RESOURCES);
- $table_properties = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- foreach ($this->tools_to_build as $tool) {
- $function_build = 'build_'.$tool;
- $specificIdList = isset($this->specific_id_list[$tool]) ? $this->specific_id_list[$tool] : null;
- $this->$function_build($session_id, $course_code, $with_base_content, $specificIdList);
- }
- //TABLE_LINKED_RESOURCES is the "resource" course table, which is deprecated, apparently
- foreach ($this->course->resources as $type => $resources) {
- foreach ($resources as $id => $resource) {
- $sql = "SELECT * FROM ".$table_link." WHERE c_id = $course_id AND source_type = '".$resource->get_type()."' AND source_id = '".$resource->get_id()."'";
- $res = Database::query($sql);
- while ($link = Database::fetch_object($res)) {
- $this->course->resources[$type][$id]->add_linked_resource($link->resource_type, $link->resource_id);
- }
- }
- }
- // Once we've built the resouces array a bit more, try to get items
- // from the item_propry table and order them in the "resources" array
- foreach ($this->course->resources as $type => $resources) {
- foreach ($resources as $id => $resource) {
- $tool = $resource->get_tool();
- if ($tool != null) {
- $sql = "SELECT * FROM $table_properties WHERE c_id = $course_id AND TOOL = '".$tool."' AND ref='".$resource->get_id()."'";
- $res = Database::query($sql);
- $all_properties = array ();
- while ($item_property = Database::fetch_array($res)) {
- $all_properties[]= $item_property;
- }
- $this->course->resources[$type][$id]->item_properties = $all_properties;
- }
- }
- }
- return $this->course;
- }
- /**
- * Build the documents
- */
- function build_documents($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table_doc = Database::get_course_table(TABLE_DOCUMENT);
- $table_prop = Database::get_course_table(TABLE_ITEM_PROPERTY);
- //Remove chat_files and shared_folder files
- $avoid_paths = " path NOT LIKE '/shared_folder%' AND
- path NOT LIKE '/chat_files%' ";
- //$avoid_paths = " 1 = 1 ";
- if (!empty($course_code) && !empty($session_id)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- if (!empty($this->course->type) && $this->course->type=='partial') {
- $sql = "SELECT d.id, d.path, d.comment, d.title, d.filetype, d.size FROM $table_doc d, $table_prop p
- WHERE d.c_id = $course_id AND
- p.c_id = $course_id AND
- tool = '".TOOL_DOCUMENT."' AND
- p.ref = d.id AND
- p.visibility != 2 AND
- path NOT LIKE '/images/gallery%' AND
- $avoid_paths
- $session_condition
- ORDER BY path";
- } else {
- $sql = "SELECT d.id, d.path, d.comment, d.title, d.filetype, d.size FROM $table_doc d, $table_prop p
- WHERE d.c_id = $course_id AND
- p.c_id = $course_id AND
- tool = '".TOOL_DOCUMENT."' AND
- $avoid_paths AND
- p.ref = d.id AND
- p.visibility != 2 $session_condition
- ORDER BY path";
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $doc = new Document($obj->id, $obj->path, $obj->comment, $obj->title, $obj->filetype, $obj->size);
- $this->course->add_resource($doc);
- }
- } else {
- if (!empty($this->course->type) && $this->course->type=='partial')
- $sql = 'SELECT d.id, d.path, d.comment, d.title, d.filetype, d.size FROM '.$table_doc.' d, '.$table_prop.' p
- WHERE d.c_id = '.$course_id.' AND
- p.c_id = '.$course_id.' AND
- tool = \''.TOOL_DOCUMENT.'\' AND
- p.ref = d.id AND
- p.visibility != 2 AND
- path NOT LIKE \'/images/gallery%\' AND
- '.$avoid_paths.'AND
- d.session_id = 0
- ORDER BY path';
- else
- $sql = 'SELECT d.id, d.path, d.comment, d.title, d.filetype, d.size
- FROM '.$table_doc.' d, '.$table_prop.' p
- WHERE d.c_id = '.$course_id.' AND
- p.c_id = '.$course_id.' AND
- tool = \''.TOOL_DOCUMENT.'\' AND
- p.ref = d.id AND
- p.visibility != 2 AND
- '.$avoid_paths.' AND
- d.session_id = 0
- ORDER BY path';
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $doc = new Document($obj->id, $obj->path, $obj->comment, $obj->title, $obj->filetype, $obj->size);
- $this->course->add_resource($doc);
- }
- }
- }
- /**
- * Build the forums
- */
- function build_forums($session_id = 0, $course_code = null, $with_base_content = false, $id_list = array())
- {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table = Database :: get_course_table(TABLE_FORUM);
- $sql = "SELECT * FROM $table WHERE c_id = $course_id ";
- $sql .= " ORDER BY forum_title, forum_category";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $forum = new Forum($obj);
- $this->course->add_resource($forum);
- }
- }
- /**
- * Build a forum-category
- */
- function build_forum_category($session_id = 0, $course_code = null, $with_base_content = false, $id_list = array())
- {
- $table = Database :: get_course_table(TABLE_FORUM_CATEGORY);
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $sql = "SELECT * FROM $table WHERE c_id = $course_id ORDER BY cat_title";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $forum_category = new ForumCategory($obj);
- $this->course->add_resource($forum_category);
- }
- }
- /**
- * Build the forum-topics
- */
- function build_forum_topics($session_id = 0, $course_code = null, $with_base_content = false, $id_list = array())
- {
- $table = Database :: get_course_table(TABLE_FORUM_THREAD);
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $sql = "SELECT * FROM $table WHERE c_id = $course_id
- ORDER BY thread_title ";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $forum_topic = new ForumTopic($obj);
- $this->course->add_resource($forum_topic);
- $this->build_forum_posts($obj->thread_id, $obj->forum_id, true);
- }
- }
- /**
- * Build the forum-posts
- * TODO: All tree structure of posts should be built, attachments for example.
- */
- function build_forum_posts($thread_id = null, $forum_id = null, $only_first_post = false)
- {
- $table = Database :: get_course_table(TABLE_FORUM_POST);
- $course_id = api_get_course_int_id();
- $sql = "SELECT * FROM $table WHERE c_id = $course_id ";
- if (!empty($thread_id) && !empty($forum_id)) {
- $forum_id = intval($forum_id);
- $thread_id = intval($thread_id);
- $sql .= " AND thread_id = $thread_id AND forum_id = $forum_id ";
- }
- $sql .= " ORDER BY post_id ASC LIMIT 1";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $forum_post = new ForumPost($obj);
- $this->course->add_resource($forum_post);
- }
- }
- /**
- * Build the links
- */
- function build_links($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table = Database :: get_course_table(TABLE_LINK);
- $table_prop = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- if (!empty($session_id) && !empty($course_code)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $sql = "SELECT l.id, l.title, l.url, l.description, l.category_id, l.on_homepage
- FROM $table l, $table_prop p
- WHERE l.c_id = $course_id AND p.c_id = $course_id AND p.ref=l.id AND p.tool = '".TOOL_LINK."' AND p.visibility != 2 $session_condition
- ORDER BY l.display_order";
- } else {
- $sql = "SELECT l.id, l.title, l.url, l.description, l.category_id, l.on_homepage
- FROM $table l, $table_prop p
- WHERE l.c_id = $course_id AND p.c_id = $course_id AND p.ref=l.id AND p.tool = '".TOOL_LINK."' AND p.visibility != 2 AND l.session_id = 0
- ORDER BY l.display_order";
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $link = new Link($obj->id, $obj->title, $obj->url, $obj->description, $obj->category_id, $obj->on_homepage);
- $this->course->add_resource($link);
- if (!empty($course_code)) {
- $res = $this->build_link_category($obj->category_id,$course_code);
- } else {
- $res = $this->build_link_category($obj->category_id);
- }
- if($res > 0) {
- $this->course->resources[RESOURCE_LINK][$obj->id]->add_linked_resource(RESOURCE_LINKCATEGORY, $obj->category_id);
- }
- }
- }
- /**
- * Build tool intro
- */
- function build_tool_intro($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $table = Database :: get_course_table(TABLE_TOOL_INTRO);
- $course_id = api_get_course_int_id();
- $sql = "SELECT * FROM $table WHERE c_id = $course_id ";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $tool_intro = new ToolIntro($obj->id, $obj->intro_text);
- $this->course->add_resource($tool_intro);
- }
- }
- /**
- * Build a link category
- */
- function build_link_category($id, $course_code = '')
- {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $link_cat_table = Database :: get_course_table(TABLE_LINK_CATEGORY);
- $sql = "SELECT * FROM $link_cat_table WHERE c_id = $course_id AND id = $id";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $link_category = new LinkCategory($obj->id, $obj->category_title, $obj->description, $obj->display_order);
- $this->course->add_resource($link_category);
- return $id;
- }
- return 0;
- }
- /**
- * Build the Quizzes
- */
- function build_quizzes($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $course_info = api_get_course_info($course_code);
- $table_qui = Database :: get_course_table(TABLE_QUIZ_TEST);
- $table_rel = Database :: get_course_table(TABLE_QUIZ_TEST_QUESTION);
- $table_doc = Database :: get_course_table(TABLE_DOCUMENT);
- $course_id = $course_info['real_id'];
- if (!empty($course_code) && !empty($session_id)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $sql = "SELECT * FROM $table_qui WHERE c_id = $course_id AND active >=0 $session_condition"; //select only quizzes with active = 0 or 1 (not -1 which is for deleted quizzes)
- } else {
- $sql = "SELECT * FROM $table_qui WHERE c_id = $course_id AND active >=0 AND session_id = 0"; //select only quizzes with active = 0 or 1 (not -1 which is for deleted quizzes)
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- if (strlen($obj->sound) > 0) {
- $sql = "SELECT id FROM $table_doc WHERE c_id = $course_id AND path = '/audio/".$obj->sound."'";
- $res = Database::query($sql);
- $doc = Database::fetch_object($res);
- $obj->sound = $doc->id;
- }
- $exercise_obj = new Exercise($course_id);
- $exercise_obj->read($obj->iid);
- $categories = $exercise_obj->get_categories_with_name_in_exercise();
- $obj->categories = $categories;
- $quiz = new Quiz($obj);
- $sql = 'SELECT * FROM '.$table_rel.' WHERE c_id = '.$course_id.' AND exercice_id = '.$obj->iid;
- $db_result2 = Database::query($sql);
- while ($obj2 = Database::fetch_object($db_result2)) {
- $quiz->add_question($obj2->question_id, $obj2->question_order);
- }
- $this->course->add_resource($quiz);
- }
- if (!empty($course_code)) {
- $this->build_quiz_questions($course_code);
- } else {
- $this->build_quiz_questions();
- }
- }
- /**
- * Build the Quiz-Questions
- */
- function build_quiz_questions($course_code = null)
- {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table_qui = Database :: get_course_table(TABLE_QUIZ_TEST);
- $table_rel = Database :: get_course_table(TABLE_QUIZ_TEST_QUESTION);
- $table_que = Database :: get_course_table(TABLE_QUIZ_QUESTION);
- $table_ans = Database :: get_course_table(TABLE_QUIZ_ANSWER);
- // Building normal tests.
- $sql = "SELECT * FROM $table_que WHERE c_id = $course_id ";
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $categories = Testcategory::getCategoryForQuestionWithCategoryData($obj->iid, $course_id, true);
- $parent_info = array();
- if (isset($obj->parent_id) && !empty($obj->parent_id)) {
- $parent_info = (array)Question::read($obj->parent_id, $course_id);
- }
- $question = new QuizQuestion($obj->iid, $obj->question, $obj->description, $obj->ponderation, $obj->type, $obj->position, $obj->picture, $obj->level, $obj->extra, $parent_info, $categories);
- $sql = 'SELECT * FROM '.$table_ans.' WHERE question_id = '.$obj->iid;
- $db_result2 = Database::query($sql);
- while ($obj2 = Database::fetch_object($db_result2)) {
- $question->add_answer($obj2->iid, $obj2->answer, $obj2->correct, $obj2->comment, $obj2->ponderation, $obj2->position, $obj2->hotspot_coordinates, $obj2->hotspot_type);
- if ($obj->type == MULTIPLE_ANSWER_TRUE_FALSE) {
- $table_options = Database::get_course_table(TABLE_QUIZ_QUESTION_OPTION);
- $sql = 'SELECT * FROM '.$table_options.' WHERE c_id = '.$course_id.' AND question_id = '.$obj->iid;
- $db_result3 = Database::query($sql);
- while ($obj3 = Database::fetch_object($db_result3)) {
- $question_option = new QuizQuestionOption($obj3);
- $question->add_option($question_option);
- }
- }
- }
- $this->course->add_resource($question);
- }
- // Building a fictional test for collecting orphan questions.
- $build_orphan_questions = !empty($_POST['recycle_option']); // When a course is emptied this option should be activated (true).
- //1st union gets the orphan questions from deleted exercises
- //2nd union gets the orphan questions from question that were deleted in a exercise.
- $sql = " (
- SELECT q.* FROM $table_que q INNER JOIN $table_rel r
- ON (q.c_id = r.c_id AND q.iid = r.question_id)
- INNER JOIN $table_qui ex
- ON (ex.iid = r.exercice_id AND ex.c_id = r.c_id )
- WHERE ex.c_id = $course_id AND ex.active = '-1'
- )
- UNION
- (
- SELECT q.* FROM $table_que q left
- OUTER JOIN $table_rel r
- ON (q.c_id = r.c_id AND q.iid = r.question_id)
- WHERE q.c_id = $course_id AND r.question_id is null
- )
- UNION
- (
- SELECT q.* FROM $table_que q
- INNER JOIN $table_rel r
- ON (q.c_id = r.c_id AND q.iid = r.question_id)
- WHERE r.c_id = $course_id AND (r.exercice_id = '-1' OR r.exercice_id = '0')
- )
- ";
- $db_result = Database::query($sql);
- if (Database::num_rows($db_result) > 0) {
- $build_orphan_questions = true;
- $orphanQuestionIds = array();
- while ($obj = Database::fetch_object($db_result)) {
- $categories = Testcategory::getCategoryForQuestionWithCategoryData($obj->iid, $course_id, true);
- $parent_info = array();
- if (isset($obj->parent_id) && !empty($obj->parent_id)) {
- $parent_info = (array)Question::read($obj->parent_id, $course_id);
- }
- //Avoid adding the same question twice
- if (!isset($this->course->resources[$obj->iid])) {
- $question = new QuizQuestion($obj->iid, $obj->question, $obj->description, $obj->ponderation, $obj->type, $obj->position, $obj->picture,$obj->level, $obj->extra, $parent_info, $categories);
- $sql = "SELECT * FROM $table_ans WHERE c_id = $course_id AND question_id = ".$obj->iid;
- $db_result2 = Database::query($sql);
- if (Database::num_rows($db_result2)) {
- while ($obj2 = Database::fetch_object($db_result2)) {
- $question->add_answer($obj2->iid, $obj2->answer, $obj2->correct, $obj2->comment, $obj2->ponderation, $obj2->position, $obj2->hotspot_coordinates, $obj2->hotspot_type);
- }
- $orphanQuestionIds[] = $obj->iid;
- }
- $this->course->add_resource($question);
- }
- }
- }
- if ($build_orphan_questions) {
- $obj = array(
- 'iid' => -1,
- 'title' => get_lang('OrphanQuestions', ''),
- 'type' => 2
- );
- $newQuiz = new Quiz((object)$obj);
- if (!empty($orphanQuestionIds)) {
- foreach ($orphanQuestionIds as $index => $orphanId) {
- $order = $index + 1;
- $newQuiz->add_question($orphanId, $order);
- }
- }
- $this->course->add_resource($newQuiz);
- }
- }
- /**
- * Build the orphan questions
- */
- function build_quiz_orphan_questions()
- {
- $table_qui = Database :: get_course_table(TABLE_QUIZ_TEST);
- $table_rel = Database :: get_course_table(TABLE_QUIZ_TEST_QUESTION);
- $table_que = Database :: get_course_table(TABLE_QUIZ_QUESTION);
- $table_ans = Database :: get_course_table(TABLE_QUIZ_ANSWER);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT *
- FROM '.$table_que.' as questions
- LEFT JOIN '.$table_rel.' as quizz_questions
- ON questions.id=quizz_questions.question_id
- LEFT JOIN '.$table_qui.' as exercices
- ON exercice_id=exercices.id
- WHERE questions.c_id = '.$course_id.' AND
- quizz_questions.c_id = '.$course_id.' AND
- exercices.c_id = '.$course_id.' AND
- (quizz_questions.exercice_id IS NULL OR
- exercices.active = -1)';
- $db_result = Database::query($sql);
- if (Database::num_rows($db_result) > 0) {
- // This is the fictional test for collecting orphan questions.
- $orphan_questions = new Quiz(-1, get_lang('OrphanQuestions', ''), '', 0, 0, 1, '', 0);
- $this->course->add_resource($orphan_questions);
- while ($obj = Database::fetch_object($db_result)) {
- $question = new QuizQuestion($obj->iid, $obj->question, $obj->description, $obj->ponderation, $obj->type, $obj->position, $obj->picture,$obj->level,$obj->extra);
- $sql = 'SELECT * FROM '.$table_ans.' WHERE question_id = '.$obj->iid;
- $db_result2 = Database::query($sql);
- while ($obj2 = Database::fetch_object($db_result2)) {
- $question->add_answer($obj2->iid, $obj2->answer, $obj2->correct, $obj2->comment, $obj2->ponderation, $obj2->position, $obj2->hotspot_coordinates, $obj2->hotspot_type);
- }
- $this->course->add_resource($question);
- }
- }
- }
- /**
- * Build the Surveys
- */
- function build_surveys($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $table_survey = Database :: get_course_table(TABLE_SURVEY);
- $table_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table_survey.' WHERE c_id = '.$course_id.' AND session_id = 0 ';
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $survey = new Survey($obj->survey_id, $obj->code,$obj->title,
- $obj->subtitle, $obj->author, $obj->lang,
- $obj->avail_from, $obj->avail_till, $obj->is_shared,
- $obj->template, $obj->intro, $obj->surveythanks,
- $obj->creation_date, $obj->invited, $obj->answered,
- $obj->invite_mail, $obj->reminder_mail);
- $sql = 'SELECT * FROM '.$table_question.' WHERE c_id = '.$course_id.' AND survey_id = '.$obj->survey_id;
- $db_result2 = Database::query($sql);
- while ($obj2 = Database::fetch_object($db_result2)){
- $survey->add_question($obj2->question_id);
- }
- $this->course->add_resource($survey);
- }
- $this->build_survey_questions();
- }
- /**
- * Build the Survey Questions
- */
- function build_survey_questions() {
- $table_que = Database :: get_course_table(TABLE_SURVEY_QUESTION);
- $table_opt = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table_que.' WHERE c_id = '.$course_id.' ';
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)){
- $question = new SurveyQuestion($obj->question_id, $obj->survey_id,
- $obj->survey_question, $obj->survey_question_comment,
- $obj->type, $obj->display, $obj->sort,
- $obj->shared_question_id, $obj->max_value);
- $sql = 'SELECT * FROM '.$table_opt.' WHERE c_id = '.$course_id.' AND question_id = '.$obj->question_id;
- $db_result2 = Database::query($sql);
- while ($obj2 = Database::fetch_object($db_result2)) {
- $question->add_answer($obj2->option_text, $obj2->sort);
- }
- $this->course->add_resource($question);
- }
- }
- /**
- * Build the announcements
- */
- function build_announcements($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $table = Database :: get_course_table(TABLE_ANNOUNCEMENT);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table.' WHERE c_id = '.$course_id.' AND session_id = 0';
- $db_result = Database::query($sql);
- $table_attachment = Database :: get_course_table(TABLE_ANNOUNCEMENT_ATTACHMENT);
- while ($obj = Database::fetch_object($db_result)) {
- $sql = 'SELECT path, comment, filename, size FROM '.$table_attachment.' WHERE c_id = '.$course_id.' AND announcement_id = '.$obj->id.'';
- $result = Database::query($sql);
- $attachment_obj = Database::fetch_object($result);
- $att_path = $att_filename = $att_size = $atth_comment = '';
- if (!empty($attachment_obj)) {
- $att_path = $attachment_obj->path;
- $att_filename = $attachment_obj->filename;
- $att_size = $attachment_obj->size;
- $atth_comment = $attachment_obj->comment;
- }
- $announcement = new Announcement($obj->id, $obj->title, $obj->content, $obj->end_date,$obj->display_order,$obj->email_sent, $att_path, $att_filename, $att_size, $atth_comment);
- $this->course->add_resource($announcement);
- }
- }
- /**
- * Build the events
- */
- function build_events($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $table = Database :: get_course_table(TABLE_AGENDA);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table.' WHERE c_id = '.$course_id.' AND session_id = 0';
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $table_attachment = Database :: get_course_table(TABLE_AGENDA_ATTACHMENT);
- $sql = 'SELECT path, comment, filename, size FROM '.$table_attachment.' WHERE c_id = '.$course_id.' AND agenda_id = '.$obj->id.'';
- $result = Database::query($sql);
- $attachment_obj = Database::fetch_object($result);
- $att_path = $att_filename = $att_size = $atth_comment = '';
- if (!empty($attachment_obj)) {
- $att_path = $attachment_obj->path;
- $att_filename = $attachment_obj->filename;
- $att_size = $attachment_obj->size;
- $atth_comment = $attachment_obj->comment;
- }
- $event = new Event($obj->id, $obj->title, $obj->content, $obj->start_date, $obj->end_date, $att_path, $att_filename, $att_size, $atth_comment, $obj->all_day);
- $this->course->add_resource($event);
- }
- }
- /**
- * Build the course-descriptions
- */
- function build_course_descriptions($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table = Database :: get_course_table(TABLE_COURSE_DESCRIPTION);
- if (!empty($session_id) && !empty($course_code)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $sql = 'SELECT * FROM '.$table. ' WHERE c_id = '.$course_id.' '.$session_condition;
- } else {
- $table = Database :: get_course_table(TABLE_COURSE_DESCRIPTION);
- $sql = 'SELECT * FROM '.$table. ' WHERE c_id = '.$course_id.' AND session_id = 0';
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $cd = new CourseDescription($obj->id, $obj->title, $obj->content, $obj->description_type);
- $this->course->add_resource($cd);
- }
- }
- /**
- * Build the learnpaths
- */
- function build_learnpaths($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $table_main = Database::get_course_table(TABLE_LP_MAIN);
- $table_item = Database::get_course_table(TABLE_LP_ITEM);
- $table_tool = Database::get_course_table(TABLE_TOOL_LIST);
- if (!empty($session_id) && !empty($course_code)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $sql = 'SELECT * FROM '.$table_main.' WHERE c_id = '.$course_id.' '.$session_condition;
- } else {
- $sql = 'SELECT * FROM '.$table_main.' WHERE c_id = '.$course_id.' AND session_id = 0';
- }
- if (!empty($id_list)) {
- $id_list = array_map('intval', $id_list);
- $sql .=" AND id IN (".implode(', ', $id_list).") ";
- }
- $db_result = Database::query($sql);
- if ($db_result)
- while ($obj = Database::fetch_object($db_result)) {
- $items = array();
- $sql_items = "SELECT * FROM ".$table_item." WHERE c_id = '$course_id' AND lp_id = ".$obj->id;
- $db_items = Database::query($sql_items);
- while ($obj_item = Database::fetch_object($db_items)) {
- $item['id'] = $obj_item->id;
- $item['item_type'] = $obj_item->item_type;
- $item['ref'] = $obj_item->ref;
- $item['title'] = $obj_item->title;
- $item['description'] = $obj_item->description;
- $item['path'] = $obj_item->path;
- $item['min_score'] = $obj_item->min_score;
- $item['max_score'] = $obj_item->max_score;
- $item['mastery_score'] = $obj_item->mastery_score;
- $item['parent_item_id'] = $obj_item->parent_item_id;
- $item['previous_item_id'] = $obj_item->previous_item_id;
- $item['next_item_id'] = $obj_item->next_item_id;
- $item['display_order'] = $obj_item->display_order;
- $item['prerequisite'] = $obj_item->prerequisite;
- $item['parameters'] = $obj_item->parameters;
- $item['launch_data'] = $obj_item->launch_data;
- $item['audio'] = $obj_item->audio;
- $items[] = $item;
- }
- $sql_tool = "SELECT id FROM $table_tool
- WHERE c_id = $course_id AND
- (link LIKE '%lp_controller.php%lp_id=".$obj->id."%' AND image='scormbuilder.gif') AND
- visibility = '1' ";
- $db_tool = Database::query($sql_tool);
- if (Database::num_rows($db_tool)) {
- $visibility = '1';
- } else {
- $visibility = '0';
- }
- $lp = new CourseCopyLearnpath(
- $obj->id,
- $obj->lp_type,
- $obj->name,
- $obj->path,
- $obj->ref,
- $obj->description,
- $obj->content_local,
- $obj->default_encoding,
- $obj->default_view_mod,
- $obj->prevent_reinit,
- $obj->force_commit,
- $obj->content_maker,
- $obj->display_order,
- $obj->js_lib,
- $obj->content_license,
- $obj->debug,
- $visibility,
- $obj->author,
- $obj->preview_image,
- $obj->use_max_score,
- $obj->autolunch,
- $obj->created_on,
- $obj->modified_on,
- $obj->publicated_on,
- $obj->expired_on,
- $obj->session_id,
- $items);
- $this->course->add_resource($lp);
- }
- //save scorm directory (previously build_scorm_documents())
- $i = 1;
- if ($dir=@opendir($this->course->backup_path.'/scorm')) {
- while($file=readdir($dir)) {
- if(is_dir($this->course->backup_path.'/scorm/'.$file) && !in_array($file,array('.','..'))) {
- $doc = new ScormDocument($i++, '/'.$file, $file);
- $this->course->add_resource($doc);
- }
- }
- closedir($dir);
- }
- }
- /**
- * Build the glossarys
- */
- function build_glossary($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $course_info = api_get_course_info($course_code);
- $table_glossary = Database :: get_course_table(TABLE_GLOSSARY);
- $course_id = $course_info['real_id'];
- if (!empty($session_id) && !empty($course_code)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- //@todo check this queries are the same ...
- if (!empty($this->course->type) && $this->course->type=='partial') {
- $sql = 'SELECT * FROM '.$table_glossary.' g WHERE g.c_id = '.$course_id.' '.$session_condition;
- } else {
- $sql = 'SELECT * FROM '.$table_glossary.' g WHERE g.c_id = '.$course_id.' '.$session_condition;
- }
- } else {
- $table_glossary = Database :: get_course_table(TABLE_GLOSSARY);
- //@todo check this queries are the same ... ayayay
- if (!empty($this->course->type) && $this->course->type=='partial') {
- $sql = 'SELECT * FROM '.$table_glossary.' g WHERE g.c_id = '.$course_id.' AND session_id = 0';
- } else {
- $sql = 'SELECT * FROM '.$table_glossary.' g WHERE g.c_id = '.$course_id.' AND session_id = 0';
- }
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $doc = new Glossary($obj->glossary_id, $obj->name, $obj->description, $obj->display_order);
- $this->course->add_resource($doc);
- }
- }
- /*
- * build session course by jhon
- * */
- function build_session_course(){
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $list_course = CourseManager::get_course_list();
- $list = array();
- foreach($list_course as $_course) {
- $this->course = new Course();
- $this->course->code = $_course['code'];
- $this->course->type = 'partial';
- $this->course->path = api_get_path(SYS_COURSE_PATH).$_course['directory'].'/';
- $this->course->backup_path = api_get_path(SYS_COURSE_PATH).$_course['directory'];
- $this->course->encoding = api_get_system_encoding(); //current platform encoding
- //$code_course = $_course['code'];
- $courseId = $_course['real_id'];
- $sql_session = "SELECT id, name, c_id
- FROM $tbl_session_course INNER JOIN $tbl_session ON id_session = id
- WHERE c_id = '$courseId' ";
- $query_session = Database::query($sql_session);
- while ($rows_session = Database::fetch_assoc($query_session)) {
- $session = new CourseSession($rows_session['id'], $rows_session['name']);
- $this->course->add_resource($session);
- }
- $list[] = $this->course;
- }
- return $list;
- }
- function build_wiki($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $course_info = api_get_course_info($course_code);
- $tbl_wiki = Database::get_course_table(TABLE_WIKI);
- $course_id = $course_info['real_id'];
- if (!empty($session_id) && !empty($course_code)) {
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $sql = 'SELECT * FROM ' . $tbl_wiki . ' WHERE c_id = '.$course_id.' '.$session_condition;
- } else {
- $tbl_wiki = Database::get_course_table(TABLE_WIKI);
- $sql = 'SELECT * FROM ' . $tbl_wiki . ' WHERE c_id = '.$course_id.' AND session_id = 0';
- }
- $db_result = Database::query($sql);
- while ($obj = Database::fetch_object($db_result)) {
- $wiki = new Wiki($obj->id, $obj->page_id, $obj->reflink, $obj->title, $obj->content, $obj->user_id, $obj->group_id, $obj->dtime, $obj->progress, $obj->version);
- $this->course->add_resource($wiki);
- }
- }
- /**
- * Build the Surveys
- */
- function build_thematic($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $table_thematic = Database :: get_course_table(TABLE_THEMATIC);
- $table_thematic_advance = Database :: get_course_table(TABLE_THEMATIC_ADVANCE);
- $table_thematic_plan = Database :: get_course_table(TABLE_THEMATIC_PLAN);
- $session_id = intval($session_id);
- if ($with_base_content) {
- $session_condition = api_get_session_condition($session_id, true, true);
- } else {
- $session_condition = api_get_session_condition($session_id, true);
- }
- $course_id = api_get_course_int_id();
- $courseInfo = api_get_course_info();
- $sql = "SELECT * FROM $table_thematic WHERE c_id = $course_id $session_condition ";
- $db_result = Database::query($sql);
- while ($row = Database::fetch_array($db_result,'ASSOC')) {
- $thematic = new Thematic($courseInfo);
- $sql = 'SELECT * FROM '.$table_thematic_advance.' WHERE c_id = '.$course_id.' AND thematic_id = '.$row['id'];
- $result = Database::query($sql);
- while ($sub_row = Database::fetch_array($result,'ASSOC')) {
- $thematic->add_thematic_advance($sub_row);
- }
- $items = api_get_item_property_by_tool('thematic_plan', api_get_course_id(), $session_id);
- //$items_from_session = api_get_item_property_by_tool('thematic_plan', api_get_course_id(), api_get_session_id());
- $thematic_plan_id_list = array();
- if (!empty($items)) {
- foreach($items as $item) {
- $thematic_plan_id_list[] = $item['ref'];
- //$thematic_plan_complete_list[$item['ref']] = $item;
- }
- }
- //$sql = 'SELECT * FROM '.$table_thematic_plan.' WHERE c_id = '.$course_id.' AND thematic_id = '.$row['id'];
- $sql = "SELECT tp.*
- FROM $table_thematic_plan tp
- INNER JOIN $table_thematic t ON (t.id=tp.thematic_id)
- WHERE t.c_id = $course_id AND
- tp.c_id = $course_id AND
- thematic_id = {$row['id']} AND
- tp.id IN (".implode(', ', $thematic_plan_id_list).") ";
- $result = Database::query($sql);
- while ($sub_row = Database::fetch_array($result,'ASSOC')) {
- $thematic->add_thematic_plan($sub_row);
- }
- $this->course->add_resource($thematic);
- }
- }
- /**
- * Build the attendances
- */
- function build_attendance($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array()) {
- $table_attendance = Database :: get_course_table(TABLE_ATTENDANCE);
- $table_attendance_calendar = Database :: get_course_table(TABLE_ATTENDANCE_CALENDAR);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table_attendance.' WHERE c_id = '.$course_id.' AND session_id = 0 ';
- $db_result = Database::query($sql);
- while ($row = Database::fetch_array($db_result,'ASSOC')) {
- $obj = new CourseCopyAttendance($row);
- $sql = 'SELECT * FROM '.$table_attendance_calendar.' WHERE c_id = '.$course_id.' AND attendance_id = '.$row['id'];
- $result = Database::query($sql);
- while ($sub_row = Database::fetch_array($result,'ASSOC')) {
- $obj->add_attendance_calendar($sub_row);
- }
- $this->course->add_resource($obj);
- }
- }
- /**
- * Build the works (or "student publications", or "assignments")
- */
- function build_works($session_id = 0, $course_code = '', $with_base_content = false, $id_list = array())
- {
- $table_work = Database :: get_course_table(TABLE_STUDENT_PUBLICATION);
- //$table_work_assignment = Database :: get_course_table(TABLE_STUDENT_PUBLICATION_ASSIGNMENT);
- $course_id = api_get_course_int_id();
- $sql = 'SELECT * FROM '.$table_work.' WHERE c_id = '.$course_id.' AND session_id = 0 AND filetype = \'folder\' AND parent_id = 0 AND active = 1';
- $db_result = Database::query($sql);
- while ($row = Database::fetch_array($db_result,'ASSOC')) {
- $obj = new Work($row);
- $this->course->add_resource($obj);
- }
- }
- }
|