- 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 require_once '../inc/global.inc.php'; require_once 'learnpath.class.php'; require_once 'learnpathItem.class.php'; require_once 'learnpath_functions.inc.php'; require_once 'resourcelinker.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[] = ""; } 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')); ?> build_action_menu(); echo '