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.
		
		
		
		
		
			
		
			
				
					
					
						
							84 lines
						
					
					
						
							3.0 KiB
						
					
					
				
			
		
		
	
	
							84 lines
						
					
					
						
							3.0 KiB
						
					
					
				<?php
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
/**
 | 
						|
 * Responses to AJAX calls
 | 
						|
 */
 | 
						|
require_once '../global.inc.php';
 | 
						|
$action = $_GET['a'];
 | 
						|
 | 
						|
 | 
						|
switch ($action) {
 | 
						|
    case 'access_detail':
 | 
						|
        $user_id = intval($_REQUEST['student']);
 | 
						|
        $course_code = Security::remove_XSS($_REQUEST['course']);
 | 
						|
        $type = Security::remove_XSS($_REQUEST['type']);
 | 
						|
        $range = Security::remove_XSS($_REQUEST['range']);
 | 
						|
 | 
						|
        $courseInfo = api_get_course_info($course_code);
 | 
						|
        $courseId = $courseInfo['real_id'];
 | 
						|
 | 
						|
        if ($range == 1) {
 | 
						|
            $start_date = Security::remove_XSS($_REQUEST['sd']);
 | 
						|
            $end_date = Security::remove_XSS($_REQUEST['ed']);
 | 
						|
            $sql_result = get_connections_to_course_by_date(
 | 
						|
                $user_id,
 | 
						|
                $courseId,
 | 
						|
                $start_date,
 | 
						|
                $end_date
 | 
						|
            );
 | 
						|
        } else {
 | 
						|
            $sql_result = MySpace::get_connections_to_course(
 | 
						|
                $user_id,
 | 
						|
                $courseId
 | 
						|
            );
 | 
						|
        }
 | 
						|
        $foo_print = grapher($sql_result, $start_date, $end_date, $type);
 | 
						|
        echo $foo_print;
 | 
						|
 | 
						|
        break;
 | 
						|
 | 
						|
    case 'access_detail_by_date':
 | 
						|
        $db = array('is_empty' => true);
 | 
						|
        $start_date = isset($_REQUEST['startDate']) ? $_REQUEST['startDate'] : "";
 | 
						|
        $end_date = isset($_REQUEST['endDate']) ? $_REQUEST['endDate'] : "";
 | 
						|
        $user_id = isset($_REQUEST['student']) ? $_REQUEST['student'] : "";
 | 
						|
        $course_code = isset($_REQUEST['course']) ? $_REQUEST['course'] : "";
 | 
						|
        $type = isset($_REQUEST['type']) ? $_REQUEST['type'] : "";
 | 
						|
        $courseInfo = api_get_course_info($course_code);
 | 
						|
        $courseId = $courseInfo['real_id'];
 | 
						|
 | 
						|
        $sql_result = get_connections_to_course_by_date(
 | 
						|
            $user_id,
 | 
						|
            $courseId,
 | 
						|
            $start_date,
 | 
						|
            $end_date
 | 
						|
        );
 | 
						|
 | 
						|
        if (is_array($sql_result) && count($sql_result) > 0) {
 | 
						|
            $db['is_empty'] = false;
 | 
						|
            $db['result'] = convert_to_string($sql_result);
 | 
						|
            $rst = get_stats($user_id, $course_code, $start_date, $end_date);
 | 
						|
            $foo_stats = '<strong>' . get_lang('Total') . ': </strong>' . $rst['total'] . '<br />';
 | 
						|
            $foo_stats .= '<strong>' . get_lang('Average') . ': </strong>' . $rst['avg'] . '<br />';
 | 
						|
            $foo_stats .= '<strong>' . get_lang('Quantity') . ' : </strong>' . $rst['times'] . '<br />';
 | 
						|
            $db['stats'] = $foo_stats;
 | 
						|
            $db['graph_result'] = grapher($sql_result, $start_date, $end_date, $type);
 | 
						|
        } else {
 | 
						|
            $db['result'] = Display::return_message(
 | 
						|
                get_lang('NoDataAvailable'),
 | 
						|
                'warning'
 | 
						|
            );
 | 
						|
            $db['graph_result'] = Display::return_message(
 | 
						|
                get_lang('NoDataAvailable'),
 | 
						|
                'warning'
 | 
						|
            );
 | 
						|
            $db['stats'] = Display::return_message(
 | 
						|
                get_lang('NoDataAvailable'),
 | 
						|
                'warning'
 | 
						|
            );
 | 
						|
        }
 | 
						|
        header('Cache-Control: no-cache');
 | 
						|
        echo json_encode($db);
 | 
						|
        break;
 | 
						|
}
 | 
						|
exit;
 | 
						|
 |