123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * This is a learning path creation and player tool in Chamilo - previously learnpath_handler.php
- *
- * @author Patrick Cool
- * @author Denes Nagy
- * @author Roan Embrechts, refactoring and code cleaning
- * @author Yannick Warnier <ywarnier@beeznest.org> - cleaning and update for new SCORM tool
- * @package chamilo.learnpath
- */
- /**
- * Code
- */
- // Prevents FF 3.6 + Adobe Reader 9 bug see BT#794 when calling a pdf file in a LP
- // The main_api.lib.php, database.lib.php and display.lib.php
- // libraries are included by default.
- require_once 'back_compat.inc.php';
- require_once 'learnpath.class.php';
- require_once 'learnpathItem.class.php';
- require_once 'learnpath_functions.inc.php';
- require_once 'resourcelinker.inc.php';
- require_once '../inc/global.inc.php';
- api_protect_course_script();
- if (isset($_GET['lp_item_id'])) {
- // Get parameter only came from lp_view.php.
- $lp_item_id = intval($_GET['lp_item_id']);
- if (isset($_SESSION['lpobject'])) {
- $oLP = unserialize($_SESSION['lpobject']);
- }
- if (is_object($oLP)) {
- $src = $oLP->get_link('http', $lp_item_id);
- }
- $url_info = parse_url($src);
- $real_url_info = parse_url(api_get_path(WEB_PATH));
- // The host must be the same.
- if ($url_info['host'] == $real_url_info['host']) {
- $url = Security::remove_XSS($src);
- header("Location: ".$url);
- exit;
- } else {
- header("Location: blank.php?error=document_not_found");
- exit;
- }
- }
- $mode = isset($_REQUEST['mode']) ? $_REQUEST['mode'] : 'fullpage';
- /* INIT SECTION */
- $_SESSION['whereami'] = 'lp/build';
- if (isset($_SESSION['oLP']) && isset($_GET['id'])) {
- $_SESSION['oLP'] -> current = intval($_GET['id']);
- }
- $this_section = SECTION_COURSES;
- $language_file = "learnpath";
- /* Header and action code */
- /* Constants and variables */
- $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
- $tbl_lp = Database::get_course_table(TABLE_LP_MAIN);
- $tbl_lp_item = Database::get_course_table(TABLE_LP_ITEM);
- $tbl_lp_view = Database::get_course_table(TABLE_LP_VIEW);
- $isStudentView = (empty($_REQUEST['isStudentView']) ? 0 : (int) $_REQUEST['isStudentView']);
- $learnpath_id = (int) $_REQUEST['lp_id'];
- // Using the resource linker as a tool for adding resources to the learning path.
- if ($action == 'add' && $type == 'learnpathitem') {
- $htmlHeadXtra[] = "<script> window.location=\"../resourcelinker/resourcelinker.php?source_id=5&action=$action&learnpath_id=$learnpath_id&chapter_id=$chapter_id&originalresource=no\"; </script>";
- }
- if ((!$is_allowed_to_edit) || ($isStudentView)) {
- error_log('New LP - User not authorized in lp_view_item.php');
- header('location:lp_controller.php?action=view&lp_id='.$learnpath_id);
- exit;
- }
- // From here on, we are admin because of the previous condition, so don't check anymore.
- $course_id = api_get_course_int_id();
- $sql_query = "SELECT * FROM $tbl_lp WHERE c_id = $course_id AND id = $learnpath_id";
- $result=Database::query($sql_query);
- $therow=Database::fetch_array($result);
- /* SHOWING THE ADMIN TOOLS */
- if (isset($_SESSION['gradebook'])) {
- $gradebook = $_SESSION['gradebook'];
- }
- if (!empty($gradebook) && $gradebook == 'view') {
- $interbreadcrumb[] = array (
- 'url' => '../gradebook/'.$_SESSION['gradebook_dest'],
- 'name' => get_lang('ToolGradebook')
- );
- }
- $interbreadcrumb[] = array('url' => 'lp_controller.php?action=list', 'name' => get_lang('LearningPaths'));
- $interbreadcrumb[] = array('url' => api_get_self()."?action=build&lp_id=$learnpath_id", 'name' => $therow['name']);
- $interbreadcrumb[] = array('url' => api_get_self()."?action=add_item&type=step&lp_id=$learnpath_id", 'name' => get_lang('NewStep'));
- // Theme calls
- $show_learn_path = true;
- if (isset($_SESSION['oLP']) && is_object($_SESSION['oLP'])) {
- $lp_theme_css = $_SESSION['oLP']->get_theme();
- }
- if ($mode == 'fullpage') {
- Display::display_header(get_lang('Item'), 'Path');
- }
- $suredel = trim(get_lang('AreYouSureToDelete'));
- ?>
- <script>
- /* <![CDATA[ */
- function stripslashes(str) {
- str=str.replace(/\\'/g,'\'');
- str=str.replace(/\\"/g,'"');
- str=str.replace(/\\\\/g,'\\');
- str=str.replace(/\\0/g,'\0');
- return str;
- }
- function confirmation(name) {
- name=stripslashes(name);
- if (confirm("<?php echo $suredel; ?> " + name + " ?")) {
- return true;
- } else {
- return false;
- }
- }
- </script>
- <?php
- $id = (isset($new_item_id)) ? $new_item_id : $_GET['id'];
- if (is_object($_SESSION['oLP'])) {
- switch ($mode) {
- case 'fullpage':
- echo $_SESSION['oLP']->build_action_menu();
- echo '<div class="row-fluid">';
- echo '<div class="span3">';
- echo $_SESSION['oLP']->return_new_tree();
- echo '</div>';
- echo '<div class="span9">';
- echo $_SESSION['oLP']->display_item($id);
- echo '</div>';
- echo '</div>';
- Display::display_footer();
- break;
- case 'preview_document':
- echo $_SESSION['oLP']->display_item($id, null, false);
- break;
- }
- }
|