Copyright (C) 2009 David Grant This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ ?> array( "ysf_region_id"=>$fair['username'], "ysf_region_password"=>$fair['password'], "year"=>$year, "stats"=>$y) ); } else { $xmldata=array("sfiab"=>array( "username"=>$fair['username'], "password"=>$fair['password'], "stats"=>$stats)); } $output=""; xmlCreateRecurse($xmldata); return $output; } send_header("Fair Stats", array('Committee Main' => 'committee_main.php', 'Administration' => 'admin/index.php'), "one-click_ysf_affiliation_stats" ); echo "
"; /* SFIAB config options server side */ $server_config = array(); $server_config['fair_stats_participation'] = 'no'; $server_config['fair_stats_schools_ext'] = 'no'; $server_config['fair_stats_minorities'] = 'no'; $server_config['fair_stats_guests'] = 'no'; $server_config['fair_stats_sffbc_misc'] = 'no'; function curl_query($fair, $xml) { switch($fair['type']) { case 'sfiab': $url = $fair['url'].'/xmltransport.php'; break; case 'ysf': $url = "https://secure.ysf-fsj.ca/registration/xmlaffiliation.php"; break; } $ch = curl_init(); /// initialize a cURL session curl_setopt ($ch, CURLOPT_URL, $url); curl_setopt ($ch, CURLOPT_HEADER, 0); /// Header control curl_setopt ($ch, CURLOPT_POST, 1); /// tell it to make a POST, not a GET curl_setopt ($ch, CURLOPT_POSTFIELDS, "xml=".urlencode($xml)); /// put the query string here starting with "?" curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); /// This allows the output to be set into a variable $datastream curl_setopt ($ch, CURLOPT_POSTFIELDSIZE, 0); curl_setopt ($ch, CURLOPT_TIMEOUT, 360); curl_setopt ($ch, CURLOPT_SSLVERSION, 3); curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, false); $datastream = curl_exec ($ch); /// execute the curl session and return the output to a variable $datastream $datastream = str_replace(" standalone=\"yes\"","",$datastream); curl_close ($ch); /// close the curl session switch($fair['type']) { case 'sfiab': $d=xml_parsexml(urldecode($datastream)); $datastream = $d['sfiab'][0]; break; case 'ysf': break; } return $datastream; } if($_GET['year']) $year=intval($_GET['year']); else $year=$config['FAIRYEAR']; if($_GET['id']) $fairs_id=intval($_GET['id']); else if($_POST['id']) $fairs_id=intval($_POST['id']); else $fairs_id = -1; if($fairs_id != -1) { $q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id'"); $fair = mysql_fetch_assoc($q); } $action = $_POST['action']; if($action == 'sendstats') { foreach(array_keys($stats_data) as $k) { $stats[$k] = $_POST[$k]; } $stats['year'] = $year; $xml = stats_to_xml($fair, $stats); if(function_exists('curl_init')) { $r = curl_query($fair, $xml); if($r['error'][0] == 0) echo happy(i18n("The %1 Server said:", array($fair['name'])).' '.$r['message'][0]); else echo error(i18n("The %1 Server said:", array($fair['name'])).' '.$r['message'][0]); // $fairs_id = -1; // $year = $config['FAIRYEAR']; } else { echo error("CURL Support Missing"); echo i18n("Your PHP installation does not support CURL. You will need to login to the YSF system as the regional coodinator and upload the XML data manually"); send_footer(); exit; } } echo "
"; $q=mysql_query("SELECT * FROM fairs WHERE `type`='sfiab' OR `type`='ysf'"); echo ""; echo "\n"; while($r=mysql_fetch_object($q)) { if($year==$r->year) $sel="selected=\"selected\""; else $sel=""; echo "\n"; } echo "\n"; echo ""; echo "
"; echo "
"; echo "
"; if($fairs_id == -1) { echo i18n('Statistics will be shown below this line before being sent. Please select a fair and year first.'); /* Wait for them to select somethign before generating stats */ send_footer(); exit; } echo notice(i18n('Getting statistics request and existing stats data from server %1', array($fair['url']))); /* Query the server to see what stats we need */ $xmldata=array("sfiab"=>array( "username"=>$fair['username'], "password"=>$fair['password'], "getstats"=>array('year'=>$year))); $output=""; xmlCreateRecurse($xmldata); $xml=$output; $data = curl_query($fair, $xml); if($data['error'][0] != 0) { echo error("Server said: {$data['message'][0]}
"); send_footer(); exit; } echo notice(i18n('Server said: Success')); echo '
'; echo i18n('This server has requested the following stats:'); echo '

'; foreach($server_config as $k=>$v) { $server_config[$k] = $data['statconfig'][0][$k][0]; } /* Gather all stats, then we'll decide what to send */ $stats = array(); $stats['year'] = $year; /* Now, overwrite all the stats with what we pulled down from the server */ if(is_array($data['stats'][0])) { foreach($data['stats'][0] as $k=>$v) { $stats[$k] = $v[0]; } } // print_r($data['stats'][0]); /* And now, overwrite all the stuff we pulled down with stats we can compute */ //number of schools $q=mysql_query("SELECT COUNT(id) AS num FROM schools WHERE year='$year'"); $r=mysql_fetch_object($q); $stats['schools_total']=$r->num; //number of schools participating $q=mysql_query("SELECT DISTINCT(students.schools_id) AS sid, schools.* FROM students LEFT JOIN registrations ON students.registrations_id=registrations.id LEFT JOIN schools ON students.schools_id=schools.id WHERE students.year='$year' AND registrations.year='$year' AND (registrations.status='complete' OR registrations.status='paymentpending')"); $stats['schools_active']=mysql_num_rows($q); $stats['schools_public'] = 0; $stats['schools_private'] = 0; $stats['schools_atrisk'] = 0; $districts = array(); while($si=mysql_fetch_assoc($q)) { if($si['designate'] == 'public') $stats['schools_public']++; if($si['designate'] == 'independent') $stats['schools_private']++; if($si['atrisk'] == 'yes') $stats['schools_atrisk']++; $bd = $si['board'].'~'.$si['district']; if(!in_array($bd, $districts)) $districts[] =$bd; } $stats['schools_districts'] = count($districts); //numbers of students: $q=mysql_query("SELECT students.*,schools.* FROM students LEFT JOIN registrations ON students.registrations_id=registrations.id LEFT JOIN schools on students.schools_id=schools.id WHERE students.year='$year' AND registrations.year='$year' AND (registrations.status='complete' OR registrations.status='paymentpending')"); echo mysql_error(); $stats['students_total'] = mysql_num_rows($q); $stats['students_public'] = 0; $stats['students_private'] = 0; $stats['students_atrisk'] = 0; $grademap = array(1=>1, 2=>1, 3=>1, 4=>4, 5=>4, 6=>4, 7=>7, 8=>7, 9=>9, 10=>9, 11=>11, 12=>11, 13=>11); foreach($grademap as $k=>$g) { $stats["male_$g"] = 0; $stats["female_$g"] = 0; $stats["projects_$g"] = 0; } $unknown = array(); while($s=mysql_fetch_assoc($q)) { if(!in_array($s['sex'], array('male','female'))) $unknown[$grademap[$s['grade']]]++; else $stats["{$s['sex']}_{$grademap[$s['grade']]}"]++; if($s['designate'] == 'public') $stats['students_public']++; if($s['designate'] == 'independent') $stats['students_private']++; if($s['atrisk'] == 'yes') $stats['students_atrisk']++; } foreach($unknown as $g=>$a) { $m = round($a/2); $f = $a - $m; $stats["male_$g"] += $m; $stats["female_$g"] += $f; } //projects $q=mysql_query("SELECT MAX(students.grade) AS grade FROM students LEFT JOIN registrations ON students.registrations_id=registrations.id LEFT JOIN projects ON projects.registrations_id=registrations.id WHERE students.year='$year' AND registrations.year='$year' AND projects.year='$year' AND (registrations.status='complete' OR registrations.status='paymentpending') GROUP BY projects.id"); echo mysql_error(); while($r=mysql_fetch_assoc($q)) { $stats["projects_{$grademap[$r['grade']]}"]++; } $q=mysql_query("SELECT COUNT(id) AS num FROM users LEFT JOIN users_committee ON users_committee.users_id=users.id WHERE types LIKE '%committee%' AND year='$year' AND users_committee.committee_active='yes' AND deleted='no'"); $r = mysql_fetch_object($q); $stats['committee_members'] = $r->num; $q=mysql_query("SELECT COUNT(id) AS num FROM users LEFT JOIN users_judge ON users_judge.users_id=users.id WHERE users.year='$year' AND users.types LIKE '%judge%' AND users.deleted='no' AND users_judge.judge_complete='yes' AND users_judge.judge_active='yes'"); $r=mysql_fetch_object($q); $stats['judges'] = $r->num; /* All stats have been gathered, print them */ /* Print all blocks the server requests */ echo "
"; echo ""; $manual_stats = array(); if($server_config['fair_stats_participation'] == 'yes') { $rangemap = array(1=>'1-3', 4=>'4-6', 7=>'7-8', 9=>'9-10', 11=>'11-12'); echo ''.i18n('Fair participation').'
'; echo '
'; echo i18n("Number of students").": {$stats['students_total']}"; echo ''; echo ''; foreach($rangemap as $k=>$v) echo ""; echo ''; echo ''; foreach($rangemap as $k=>$v) echo ""; echo ''; echo ''; foreach($rangemap as $k=>$v) echo ""; echo ''; echo ''; foreach($rangemap as $k=>$v) echo ""; echo ''; echo '
'.i18n('Grade').'
$v
'.i18n('Male').'{$stats["male_$k"]}
'.i18n('Female').'{$stats["female_$k"]}
'.i18n('Projects').'{$stats["projects_$k"]}
'; echo '
'; echo i18n("Number of schools").": {$stats['schools_total']}"; echo '
'; echo i18n("Number of active schools").": {$stats['schools_active']}"; echo '
'; echo '
'; echo i18n("Number of committee members: %1 (note: this is number of committee members who logged in to SFIAB for the year, anyone who was active but didn't log in to SFIAB will NOT be counted)",array($stats['committee_members'])); echo '
'; echo i18n("Number of judges").": {$stats['judges']}"; echo '
'; echo '
'; echo '
'; } if($server_config['fair_stats_schools_ext'] == 'yes') { echo ''.i18n('Extended School/Participant data').'
'; echo '
'; echo i18n('Public schools: %1 (%2 students).',array( $stats['schools_public'], $stats['students_public'])); echo '
'; echo i18n('Private/Independent schools: %1 (%2 students).',array( $stats['schools_private'], $stats['students_private'])); echo '
'; echo i18n('At-risk/inner city schools: %1 (%2 students).',array( $stats['schools_atrisk'], $stats['students_atrisk'])); echo '
'; echo i18n('Number of school boards/distrcits: %1',array( $stats['schools_districts'])); echo '
'; echo '
'; echo '
'; } if($server_config['fair_stats_minorities'] != '') { echo ''.i18n('Data on minority groups').'
'; echo '
'; echo ''; if(strstr('firstnations',$server_config['fair_stats_minorities']) != false) { echo ''; } echo '
'.i18n('Number of First Nations students'); echo ": "; echo '
'; echo '
'; echo '
'; } if($server_config['fair_stats_guests'] == 'yes' ) { echo ''.i18n('Guests visiting the fair').'
'; echo '
'; echo ''; echo ''; echo ''; echo '
'.i18n('Number of Students that visited the fair (tours, etc.)'); echo ": "; echo '
'.i18n('Number of Public Guests that visited the fair'); echo ": "; echo '
'; echo '
'; echo '
'; } if($server_config['fair_stats_sffbc_misc'] == 'yes') { echo ''.i18n('Misc. SFFBC Questions').'
'; echo '
'; echo ''; echo ''; echo ''; echo ''; echo '
'.i18n('Number of Teachers supporting student projects'); echo ": "; echo '
'.i18n('Number of Students indicating increased interest in science & technology'); echo ": "; echo '
'.i18n('Number of Students considering careers in science & technology'); echo ": "; echo '
'; echo '
'; echo '
'; } $keys = array_keys($stats_data); foreach($keys as $k) { if($stats_data[$k]['manual'] == true) continue; echo ""; } echo ""; echo '
'; echo "
"; echo "
"; /* Format XML output, and print it, last chance for the user to edit it */ /* $xml = stats_to_xml($fair, $stats); echo '
'; echo "

".i18n("The following data will be sent to")." {$fair['name']}

"; echo "
"; echo ""; echo ""; echo ""; echo "
"; echo "
"; echo ""; echo "
"; */ echo "
";
 print_r($fair);
 print_r($server_config);
 print_r($stats);
 echo "
"; send_footer(); ?>