*/ /** ============================================================================== * Dokeos Metadata: statistics about metadata * * @package dokeos.metadata ============================================================================== */ // PRELIMS --------------------------------------------------------------------> require('md_funcs.php'); define('EID_TYPE', 'Mix'); require('md_' . strtolower(EID_TYPE) . '.php'); // name of the language file that needs to be included $language_file = 'md_mix'; include('../inc/global.inc.php'); $this_section=SECTION_COURSES; $nameTools = get_lang('Tool'); ($nameTools && get_lang('Sorry')) or give_up( 'Language file ' . $language_file . " doesn't define 'Tool' and 'Sorry'"); $_course = api_get_course_info(); isset($_course) or give_up(get_lang('Sorry')); $is_allowed_to_edit = isset($_user['user_id']) && $is_courseMember && is_allowed_to_edit(); if (!$is_allowed_to_edit) give_up(get_lang('Denied')); $mdStore = new mdstore(FALSE); // no create from statistics require(api_get_path(LIBRARY_PATH) . 'xmd.lib.php'); require(api_get_path(LIBRARY_PATH) . 'xht.lib.php'); $htmldecode = array_flip(get_html_translation_table(HTML_SPECIALCHARS)); // STATISTICS -----------------------------------------------------------------> $noPHP_SELF = TRUE; // in breadcrumps Display::display_header($nameTools); echo '

', get_lang('Statistics'), '

', "\n"; $ckw = $_course['path'] . '/CourseKwds.js'; define('KEYWORDS_CACHE', get_course_path() . $ckw); if (!file_exists(KEYWORDS_CACHE)) { echo get_lang('NoKeywords'); Display::display_footer(); exit(); } if (!($myFile = @fopen(KEYWORDS_CACHE, 'r'))) { echo get_lang('KwCacheProblem'); Display::display_footer(); exit(); } $kwds = array(); $kwcnt = array(); $kwrefs = array(); while (($kwline = fgets($myFile))) { if (ereg('°>(.+)<°', $kwline, $regs) || ereg('">(.+)<°', $kwline, $regs)) foreach (explode(',', $regs[1]) as $kw) if (!in_array($kw = strtr(trim($kw), $htmldecode), $kwds)) $kwds []= $kw; } fclose($myFile); $result = $mdStore->mds_get_many('eid,mdxmltext', '1 = 1'); echo get_lang('TotalMDEs'), mysql_num_rows($result), "
\n"; echo count($kwds), ' ', get_lang('CourseKwds'), '
', "\n"; while ($row = mysql_fetch_array($result)) { $eid = $row['eid']; $curr = ''; $xmltext = $row['mdxmltext']; $offset = 0; if (substr($eid, 0, 6) == 'Scorm.') if (($dotpos = strpos($eid, '.', 6)) && $dotpos + 1 < strlen($eid)) $curr = substr($eid, 0, $dotpos); while (($start = strpos($xmltext, '', $offset))) if (($start = strpos($xmltext, '">', $start + 9))) { if (($stop = strpos($xmltext, ' $start) { $kw = strtr(substr($xmltext, $start, $stop-$start), $htmldecode); if (!in_array($kw, $kwds)) { if (!in_array($kw = '!' . $kw, $kwds)) $kwds []= $kw; $kwrefs[$kw] .= ' ' . ($curr ? (strpos($kwrefs[$kw], $curr) ? substr($eid, $dotpos+1) : $eid) : $eid); } $kwcnt[$kw] ++; // = $kwcnt[$kw] ? $kwcnt[$kw] + 1 : 1; $offset = $stop + 19; } else $offset = $start + 2; // lecture } else $offset = $start + 9; // xmd would be nicer but this is faster... } echo count($kwds), ' ', get_lang('KwdsInMD'), '
'; sort($kwds); $total = 0; foreach ($kwcnt as $kw => $cnt) $total += $cnt; echo $total, ' ', get_lang('KwdRefs'), "\n"; echo '

', get_lang('NonCourseKwds'), '

', "\n"; foreach ($kwds as $kw) if ($kw{0} == '!') echo '', htmlspecialchars(api_substr($kw, 1), ENT_QUOTES, $charset), ': ', $kwcnt[$kw], ': ', htmlspecialchars($kwrefs[$kw], ENT_QUOTES, $charset), "; \n"; else break; echo '

', get_lang('KwdsUse'), '

', "\n"; foreach ($kwds as $kw) if ($kw{0} != '!') if (!$kwcnt[$kw]) echo '', htmlspecialchars($kw, ENT_QUOTES, $charset), "; \n"; else echo htmlspecialchars($kw, ENT_QUOTES, $charset), ': ', $kwcnt[$kw], "; \n"; Display::display_footer(); ?>