mirror of
https://github.com/CAcertOrg/cats.git
synced 2024-11-14 01:44:03 +00:00
375 lines
13 KiB
PHP
Executable file
375 lines
13 KiB
PHP
Executable file
<?php
|
||
|
||
|
||
function getFalseAnswers($q_id) {
|
||
//Initialisierung
|
||
$number=0;
|
||
$sql_incorrectAnswers="SELECT count(q_id) as anzahl FROM answers_incorrect WHERE q_id=".intval($q_id)."";
|
||
$query_incorrectAnswers= mysql_query ($sql_incorrectAnswers) OR die(mysql_error());
|
||
while($incorrectAnswers =mysql_fetch_array($query_incorrectAnswers,MYSQL_BOTH )){
|
||
$number=$incorrectAnswers['anzahl'];
|
||
return $number;
|
||
}
|
||
}
|
||
|
||
function showBar($value){
|
||
$value= serialize($value);
|
||
$value=base64_encode ($value);
|
||
$titley=Global_15;
|
||
$titlex=Global_18;
|
||
$title='statistic';
|
||
echo " <div id=\"learnprogress\">\n";
|
||
echo "<img src='includes/graph_bib/bar.php?data=$value&titley=$titley&titlex=$titlex' alt='' />";
|
||
echo "</div>\n";
|
||
}
|
||
|
||
function showPie($value){
|
||
$value= serialize($value);
|
||
$value=base64_encode ($value);
|
||
|
||
echo " <div id=\"learnprogress\">\n";
|
||
echo "<img src='includes/graph_bib/pie.php?data=$value' alt='' />";
|
||
echo "</div>\n";
|
||
}
|
||
|
||
function showGraph($value){
|
||
$value= serialize($value);
|
||
$value=base64_encode ($value);
|
||
$titley=Global_15;
|
||
$titlex=Global_17;
|
||
$title='statistic';
|
||
echo " <div id=\"learnprogress\">\n";
|
||
echo "<img src='includes/graph_bib/curve.php?percentArray=$value&title=$title&titley=$titley' alt='' />";
|
||
echo "</div>\n";
|
||
}
|
||
|
||
function getQuestions($t_id){
|
||
$sql=" SELECT questions.q_id, count FROM questions JOIN statistics ON questions.q_id = statistics.q_id AND t_id =".intval($t_id)." AND count>0 ORDER BY count DESC";
|
||
$query=mysql_query($sql);
|
||
$i=0;
|
||
while($qu =mysql_fetch_array($query ,MYSQL_BOTH )){
|
||
$question[$i]['q_id']= $qu['q_id'];
|
||
$question[$i]['count']= $qu['count'];
|
||
$i++;
|
||
}
|
||
for($i=0;$i<count($question);$i++){
|
||
$sqlGetIncorrect="SELECT count(q_id) as anzahl FROM answers_incorrect WHERE q_id=".intval($question[$i]['q_id'])."";
|
||
$queryGetIncorrect= mysql_query ($sqlGetIncorrect)OR die(mysql_error());
|
||
while($incorrect=mysql_fetch_array($queryGetIncorrect,MYSQL_BOTH )) {
|
||
$quest[$i]['q_id']=$question[$i]['q_id'];
|
||
$quest[$i]['count']=$question[$i]['count'];
|
||
$quest[$i]['countCorrect']=$question[$i]['count']-$incorrect['anzahl'];
|
||
$quest[$i]['countIncorrect']=$incorrect['anzahl'];
|
||
if( $quest[$i]['countCorrect']!= $quest[$i]['count']){
|
||
$quest[$i]['percentagCorrect']=($quest[$i]['countCorrect']/$question[$i]['count'])*100;
|
||
$quest[$i]['percentagCorrect'] = round($quest[$i]['percentagCorrect'],2); // nur 2 Nachkommastellen anzeigen
|
||
}
|
||
else $quest[$i]['percentagCorrect']=100;
|
||
}
|
||
}
|
||
return $quest;
|
||
}
|
||
|
||
function getQuestionNames($questions){
|
||
for($i=0;$i<count($questions);$i++){
|
||
$sqlGetName="SELECT question from questions where q_id=".intval($questions[$i]['q_id'])."";
|
||
$queryGetName= mysql_query ($sqlGetName)OR die(mysql_error());
|
||
while($name=mysql_fetch_array($queryGetName,MYSQL_BOTH )) {
|
||
$questions[$i]['question']= stripslashes($name[question]);
|
||
}
|
||
}
|
||
return $questions;
|
||
}
|
||
|
||
function getTopQuestions($quest){
|
||
tableHead();
|
||
function cmp($a, $b) {
|
||
if($a["count"]>$b["count"]) return -1 ;
|
||
else return 1 ;
|
||
}
|
||
usort($quest, "cmp");
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
getData($limit,$quest);
|
||
}
|
||
|
||
function getTopQuestionValues($quest){
|
||
function cmpTopQ($a, $b) {
|
||
if($a['count']>$b['count']) return -1 ;
|
||
else return 1 ;
|
||
}
|
||
usort($quest, "cmpTopQ");
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
for($i=0;$i<$limit;$i++){
|
||
$j=$i+1;
|
||
$quest[$i][]=$quest[$i]['percentagCorrect']; // wert
|
||
}
|
||
|
||
return $quest;
|
||
}
|
||
|
||
function getStatisticInfoPie($t_id){
|
||
|
||
$sql= "SELECT percentage FROM topics WHERE t_id=".intval($t_id)."";
|
||
$query= mysql_query($sql);
|
||
$value = mysql_fetch_assoc($query);
|
||
$percentageToPass=$value['percentage'];
|
||
|
||
|
||
// durchgefallen
|
||
$sql2= "SELECT count(lp_id)as failed FROM learnprogress WHERE t_id=".intval($t_id)." and percentage <= $percentageToPass";
|
||
$query2=mysql_query($sql2);
|
||
$value2 = mysql_fetch_assoc($query2);
|
||
$failed=$value2['failed'];
|
||
if(!$failed)$failed=0;
|
||
|
||
|
||
// bestandende Tests
|
||
$sql3= "SELECT count(user_id)as passed FROM learnprogress WHERE t_id=".intval($t_id)." and percentage >= $percentageToPass ";
|
||
$query3=mysql_query($sql3);
|
||
$value3=mysql_fetch_assoc($query3);
|
||
$passed=$value3['passed'];
|
||
if(!$passed)$passed=0;
|
||
|
||
|
||
|
||
$value = array(array(Statistic_04, $passed),array(Statistic_05, $failed));
|
||
return $value;
|
||
}
|
||
|
||
|
||
function getTopTenValues($quest){
|
||
function cmp($a, $b) {
|
||
if($a["percentagCorrect"]>$b["percentagCorrect"]) return -1 ;
|
||
else return 1 ;
|
||
}
|
||
usort($quest, "cmp"); // nach percentageCorrect absteigend sortieren
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
for($i=0;$i<$limit;$i++){
|
||
$j=$i+1;
|
||
$question[$i]['q_id']=$quest[$i]['q_id']; // wert
|
||
$question[$i][]=$quest[$i]['percentagCorrect']; // wert
|
||
}
|
||
|
||
return $question;
|
||
}
|
||
|
||
|
||
function getFlopTenValues($quest){
|
||
function cmp($a, $b) {
|
||
if($a["percentagCorrect"]>$b["percentagCorrect"]) return 1 ;
|
||
else return -1 ;
|
||
}
|
||
usort($quest, "cmp");
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
for($i=0;$i<$limit;$i++){
|
||
$j=$i+1;
|
||
$question[$i]['q_id']=$quest[$i]['q_id']; // wert
|
||
$question[$i][]=$quest[$i]['percentagCorrect']; // wert
|
||
}
|
||
return $question;
|
||
}
|
||
|
||
function tableHead(){
|
||
echo "<br />";
|
||
echo"<table class='tabel table_standard '>";
|
||
echo "<tr>";
|
||
echo"<td class='th th_pos'>".Global_10."</td>";
|
||
echo"<td class='th th__pos'>".Global_06."</td>";
|
||
echo"<td class='th th_question'>".Global_08." </td>";
|
||
echo"<td class='th th_count'>".Global_11."</td>";
|
||
echo "<td class='td_statistic_header_count'>".Global_03."</td>";
|
||
echo"</tr>";
|
||
}
|
||
|
||
function getData($limit,$quest){
|
||
for($i=0;$i<$limit;$i++) {
|
||
$j=$i+1;
|
||
$qu= new Question();
|
||
$topics= new Topic();
|
||
$qu-> setID($quest[$i]['q_id']);
|
||
$qu->loadQuestion();
|
||
$qu_text=$qu->getQuestion();
|
||
echo "<tr>";
|
||
echo"<td class='td'>$j</td>";
|
||
echo"<td class='td'>".$quest[$i]['q_id']."</td>";
|
||
echo"<td class='td'>".stripslashes($qu_text)."</td>"; // array Werte ausgeben
|
||
echo"<td class='td'> ". $quest[$i]['count']."</td>";
|
||
echo"<td class='td' > ". $quest[$i]['percentagCorrect']."%</td>";
|
||
echo "</tr>";
|
||
}
|
||
}
|
||
|
||
function getTopTenCorrect($quest){
|
||
tableHead();
|
||
function cmp($a, $b) { // nach percentageCorrect sortieren
|
||
if($a["percentagCorrect"]>$b["percentagCorrect"]) return -1 ;
|
||
else return 1 ;
|
||
}
|
||
usort($quest, "cmp"); // nach percentageCorrect absteigend sortieren
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
getData($limit,$quest);
|
||
echo "</table>";
|
||
}
|
||
|
||
function getFlopTenCorrects($quest){
|
||
tableHead();
|
||
function cmp($a, $b) { // nach percentageCorrect sortieren
|
||
if($a["percentagCorrect"]>$b["percentagCorrect"]) return 1 ;
|
||
else return -1 ;
|
||
}
|
||
usort($quest, "cmp"); // nach percentageCorrectaufsteigen sortieren
|
||
if(count($quest)<10) $limit=count($quest);
|
||
else $limit=10;
|
||
getData($limit,$quest);
|
||
}
|
||
|
||
function getUserInfo(){
|
||
// registrierte Benutzer
|
||
$sql="SELECT count(CN_name) as number FROM user";
|
||
$query = mysql_query($sql);
|
||
$num = mysql_fetch_assoc($query);
|
||
$number=$num['number'];
|
||
|
||
// Admin Benutzer
|
||
$sqlAdmin="SELECT count(user_id) as numberAdmin FROM user WHERE admin='".intval(1)."'";
|
||
$queryAdmin = mysql_query($sqlAdmin) OR die(mysql_error());
|
||
if(empty($queryAdmin)) $numberAdmin=0;
|
||
else{
|
||
$numAdmin = mysql_fetch_assoc($queryAdmin);
|
||
$numberAdmin=$numAdmin['numberAdmin'];
|
||
}
|
||
// Benutzer Class I Zertifikat
|
||
$sqlRoot="SELECT count(CN_name) as numberRoot1 FROM user WHERE root='".mysql_real_escape_string("CA Cert Signing Authority")."'";
|
||
$queryRoot = mysql_query($sqlRoot);
|
||
$numRoot = mysql_fetch_assoc($queryRoot);
|
||
$numberRoot1=$numRoot['numberRoot1'];
|
||
|
||
// Benutzer Class III Zertifikat
|
||
$numberRoot3=$number-$numberRoot1;
|
||
|
||
// Benutzer Post zusendung
|
||
$sqlPost="SELECT count(CN_name) as numberPost FROM user WHERE sendCert='".mysql_real_escape_string("post")."'";
|
||
$queryPost = mysql_query($sqlPost);
|
||
$numPost = mysql_fetch_assoc($queryPost);
|
||
$numberPost=$numPost['numberPost'];
|
||
|
||
// Benutzer Email zusendung
|
||
$sqlMail="SELECT count(CN_name) as numberMail FROM user WHERE sendCert='".mysql_real_escape_string("email")."'";
|
||
$queryMail = mysql_query($sqlMail);
|
||
$numMail = mysql_fetch_assoc($queryMail);
|
||
$numberMail=$numMail['numberMail'];
|
||
|
||
// Benuter, die kein Zertifikat m<>chten
|
||
$numberNo=$number-($numberMail+$numberPost);
|
||
|
||
// Spracheinstellung der Benutzer "DE"
|
||
$sqlDE="SELECT count(CN_name) as numberDE FROM user WHERE lang='".mysql_real_escape_string("DE")."'";
|
||
$queryDE = mysql_query($sqlDE);
|
||
$numDE = mysql_fetch_assoc($queryDE);
|
||
$numberDE=$numDE['numberDE'];
|
||
|
||
// Spracheinstellung der Benutzer "FR"
|
||
$sqlFR="SELECT count(CN_name) as numberFR FROM user WHERE lang='".mysql_real_escape_string("FR")."'";
|
||
$queryFR = mysql_query($sqlFR);
|
||
$numFR = mysql_fetch_assoc($queryFR);
|
||
$numberFR=$numFR['numberFR'];
|
||
|
||
// Spracheinstellung der Benutzer "EN"
|
||
|
||
$numberEN=$number-$numberDE-$numberFR;
|
||
|
||
echo "<fieldset >";
|
||
echo "<legend class='info'> ".Statistic_06."</legend> ";
|
||
echo "<h3>".Statistic_07."</h3>";
|
||
echo "<h6><label class='left_info'>".Statistic_08."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$number."<br />";
|
||
echo "<label class='left_info'>".Statistic_09."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberAdmin."<br /></h6>";
|
||
|
||
echo "<h3>".Statistic_10."</h3>";
|
||
echo "<h6><label class='left_info'>".Statistic_11."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberRoot1."<br />";
|
||
echo "<label class='left_info'>".Statistic_12."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberRoot3."<br /></h6>";
|
||
|
||
echo "<h3>".Statistic_13."</h3>";
|
||
echo "<h6><label class='left_info'>".Statistic_14."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberDE."<br />";
|
||
echo "<label class='left_info'>".Statistic_24."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberFR."<br />";
|
||
echo "<label class='left_info'>".Statistic_15."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberEN."<br /></h6>";
|
||
|
||
echo "<h3>".Statistic_16."</h3>";
|
||
echo "<h6><label class='left_info'>".Statistic_17."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberPost."<br />";
|
||
echo "<label class='left_info'>".Statistic_18."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberMail."<br />";
|
||
echo "<label class='left_info'>".Statistic_19."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$numberNo."<br /></h6>";
|
||
|
||
echo "</fieldset>";
|
||
}
|
||
|
||
function getStatisticTest($t_id){
|
||
|
||
|
||
// min Prozentzahl ermittlen
|
||
$sqlTopic= "SELECT percentage FROM topics";
|
||
$queryTopic= mysql_query($sqlTopic);
|
||
$perc = mysql_fetch_assoc($queryTopic);
|
||
$percentage=$perc['percentage'];
|
||
|
||
// alle Daten ermitteln
|
||
$sql="SELECT DISTINCT date from learnprogress WHERE t_id='".intval($t_id)."' ORDER BY date ASC ";
|
||
$query= mysql_query($sql);
|
||
$find=mysql_num_rows($query) ;
|
||
if($find==0){
|
||
echo '<div class="h8 centered">'.Global_07."</div>";
|
||
} else {
|
||
echo "<fieldset >";
|
||
echo "<legend class='info'> ".Statistic_20."</legend> ";
|
||
|
||
while($timestamp =mysql_fetch_array($query ,MYSQL_BOTH )){
|
||
$time=$timestamp['date']; // in arra speichern
|
||
$sqlnum="SELECT count(lp_id)as number FROM learnprogress WHERE t_id='".intval($t_id)."' and date='$time'";
|
||
$querynum=mysql_query($sqlnum);
|
||
$num = mysql_fetch_assoc($querynum);
|
||
$count=$num['number'];
|
||
|
||
$sqlPassed="SELECT count(lp_id)as pass FROM learnprogress WHERE percentage >= '".intval($percentage)."' and date='$time'";
|
||
$queryPassed=mysql_query($sqlPassed);
|
||
if(empty($queryPassed)) $passed=0;
|
||
else{
|
||
$numPassed = mysql_fetch_assoc($queryPassed);
|
||
$passed=$numPassed['pass'];
|
||
}
|
||
echo "<h3>".$time."</h3>";
|
||
echo "<h6><label class='left_info'>".Statistic_22."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$count."<br /><br />";
|
||
echo "<label class='left_info'>".Statistic_23."</label>";
|
||
echo"<label class='left_point'> : </label>";
|
||
echo "".$passed."</h6><br /><br />";
|
||
}
|
||
}
|
||
|
||
echo "</fieldset>";
|
||
}
|
||
|
||
?>
|