forked from science-ation/science-ation
Support Multiple uploads for SFIAB targets
This commit is contained in:
parent
14df5adc39
commit
a5a431605a
@ -27,7 +27,7 @@ require_once('curl.inc.php');
|
|||||||
user_auth_required('committee', 'admin');
|
user_auth_required('committee', 'admin');
|
||||||
|
|
||||||
//function get_cwsf_award_winners()
|
//function get_cwsf_award_winners()
|
||||||
function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL)
|
function get_winners($awardid, $fairs_id, $catmap_str=NULL, $divmap_str=NULL)
|
||||||
{
|
{
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
@ -65,143 +65,183 @@ function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL)
|
|||||||
'teacheremail'=>'teacheremail');
|
'teacheremail'=>'teacheremail');
|
||||||
|
|
||||||
|
|
||||||
|
$awards = array();
|
||||||
/* Get the award */
|
if($awardid == -1) {
|
||||||
$q=mysql_query("SELECT * FROM award_awards WHERE id='$awardid' AND year='{$config['FAIRYEAR']}'");
|
/* Get all for this fair */
|
||||||
if(mysql_num_rows($q)!=1) {
|
$q=mysql_query("SELECT * FROM award_awards WHERE award_source_fairs_id='$fairs_id' AND year='{$config['FAIRYEAR']}'");
|
||||||
error_("Can't find award id $awardid");
|
if(mysql_num_rows($q) == 0) {
|
||||||
return false;
|
error_("Can't find award id $awardid");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
while($a = mysql_fetch_assoc($q)) {
|
||||||
|
$awards[] = $a;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Get the award */
|
||||||
|
$q=mysql_query("SELECT * FROM award_awards WHERE id='$awardid' AND year='{$config['FAIRYEAR']}'");
|
||||||
|
if(mysql_num_rows($q)!=1) {
|
||||||
|
error_("Can't find award id $awardid");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
$award=mysql_fetch_assoc($q);
|
||||||
|
$awards[] = $award;
|
||||||
}
|
}
|
||||||
$award=mysql_fetch_assoc($q);
|
|
||||||
|
|
||||||
/* Get the fair for the div/cat mappings */
|
/* Get the fair for the div/cat mappings */
|
||||||
$q = mysql_query("SELECT * FROM fairs WHERE id='{$award['award_source_fairs_id']}'");
|
$q = mysql_query("SELECT * FROM fairs WHERE id='{$award['award_source_fairs_id']}'");
|
||||||
$fair = mysql_fetch_assoc($q);
|
$fair = mysql_fetch_assoc($q);
|
||||||
$catmap = unserialize(($catmap_str != NULL) ? $catmap_str : $fair['catmap']);
|
$catmap = unserialize($fair['catmap']);
|
||||||
$divmap = unserialize(($divmap_str != NULL) ? $divmap_str : $fair['divmap']);
|
$divmap = unserialize($fair['divmap']);
|
||||||
|
|
||||||
$winners=array( 'prizes' => array(),
|
|
||||||
'award_name' => $award['name'],
|
|
||||||
'external_identifier' => $award['external_identifier'],
|
|
||||||
'external_postback' => $award['external_postback']);
|
|
||||||
|
|
||||||
/* Get the prizes */
|
foreach($awards as $award) {
|
||||||
$q=mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='{$award['id']}'");
|
$winners=array( 'award_name' => $award['name'],
|
||||||
while($prize=mysql_fetch_assoc($q)) {
|
'external_identifier' => $award['external_identifier'],
|
||||||
$pid = $prize['id'];
|
'year' => $config['FAIRYEAR'],
|
||||||
$wq=mysql_query("SELECT projects.* FROM award_prizes
|
'prizes' => array());
|
||||||
LEFT JOIN winners ON winners.awards_prizes_id=award_prizes.id
|
|
||||||
LEFT JOIN projects ON projects.id=winners.projects_id
|
|
||||||
WHERE
|
|
||||||
awards_prizes_id='$pid' AND
|
|
||||||
winners.year='{$config['FAIRYEAR']}'");
|
|
||||||
echo mysql_error();
|
|
||||||
/* Get all projects assigned to this prize */
|
|
||||||
$prizewinners = array();
|
|
||||||
while($project=mysql_fetch_assoc($wq)) {
|
|
||||||
|
|
||||||
/* Get the students */
|
if($fair['type'] != 'sfiab') {
|
||||||
$sq=mysql_query("SELECT * FROM students WHERE registrations_id='{$project['registrations_id']}'
|
/* YSC Compatability */
|
||||||
AND year='{$config['FAIRYEAR']}'");
|
$winners['external_postback'] = $award['external_postback'];
|
||||||
$students=array();
|
|
||||||
while($s=mysql_fetch_assoc($sq)) {
|
|
||||||
|
|
||||||
/* Get the student's school */
|
|
||||||
$schoolq=mysql_query("SELECT * FROM schools WHERE id='{$s['schools_id']}'");
|
|
||||||
$schoolr=mysql_fetch_assoc($schoolq);
|
|
||||||
$school = array("xml_type"=>"school");/* for ysc compatability */
|
|
||||||
foreach($school_fields as $k=>$v)
|
|
||||||
$school[$k] = $schoolr[$v];
|
|
||||||
|
|
||||||
/* Pack up the student data too */
|
|
||||||
$student = array('xml_type'=>'student',/* for ysc compatability */
|
|
||||||
'school' => $school);
|
|
||||||
foreach($student_fields as $k=>$v)
|
|
||||||
$student[$k] = $s[$v];
|
|
||||||
|
|
||||||
$students[] = $student;
|
|
||||||
|
|
||||||
}
|
|
||||||
/* Turn our load ID into a server-side cat/div id */
|
|
||||||
$cat_id = $catmap[$project['projectcategories_id']];
|
|
||||||
$div_id = $divmap[$project['projectdivisions_id']];
|
|
||||||
|
|
||||||
/* Save the project info => students */
|
|
||||||
$prizewinners[]=array( 'xml_type' => 'project',/* for ysc compatability */
|
|
||||||
'projectid'=>$project['id'],
|
|
||||||
'projectnumber'=>$project['projectnumber'],
|
|
||||||
'title'=>$project['title'],
|
|
||||||
'abstract'=>$project['summary'],
|
|
||||||
'language'=>$project['language'],
|
|
||||||
'projectcategories_id'=>$cat_id,
|
|
||||||
'projectdivisions_id'=>$div_id,
|
|
||||||
'students'=>$students );
|
|
||||||
}
|
}
|
||||||
/* Save the prize info => projects */
|
|
||||||
$winners['prizes'][$prize['prize']] = array(
|
/* Get the prizes */
|
||||||
'xml_type'=>'prize', /* For ysc compatability */
|
$q=mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='{$award['id']}'");
|
||||||
'identifier'=>$prize['external_identifier'], /* for ysc compatability */
|
while($prize=mysql_fetch_assoc($q)) {
|
||||||
'projects'=>$prizewinners);
|
$pid = $prize['id'];
|
||||||
|
$wq=mysql_query("SELECT projects.* FROM award_prizes
|
||||||
|
LEFT JOIN winners ON winners.awards_prizes_id=award_prizes.id
|
||||||
|
LEFT JOIN projects ON projects.id=winners.projects_id
|
||||||
|
WHERE
|
||||||
|
awards_prizes_id='$pid' AND
|
||||||
|
winners.year='{$config['FAIRYEAR']}'");
|
||||||
|
echo mysql_error();
|
||||||
|
/* Get all projects assigned to this prize */
|
||||||
|
$prizewinners = array();
|
||||||
|
while($project=mysql_fetch_assoc($wq)) {
|
||||||
|
|
||||||
|
/* Get the students */
|
||||||
|
$sq=mysql_query("SELECT * FROM students WHERE registrations_id='{$project['registrations_id']}'
|
||||||
|
AND year='{$config['FAIRYEAR']}'");
|
||||||
|
$students=array();
|
||||||
|
while($s=mysql_fetch_assoc($sq)) {
|
||||||
|
|
||||||
|
/* Get the student's school */
|
||||||
|
$schoolq=mysql_query("SELECT * FROM schools WHERE id='{$s['schools_id']}'");
|
||||||
|
$schoolr=mysql_fetch_assoc($schoolq);
|
||||||
|
$school = array("xml_type"=>"school");/* for ysc compatability */
|
||||||
|
foreach($school_fields as $k=>$v)
|
||||||
|
$school[$k] = $schoolr[$v];
|
||||||
|
|
||||||
|
/* Pack up the student data too */
|
||||||
|
$student = array('xml_type'=>'student',/* for ysc compatability */
|
||||||
|
'school' => $school);
|
||||||
|
foreach($student_fields as $k=>$v)
|
||||||
|
$student[$k] = $s[$v];
|
||||||
|
|
||||||
|
$students[] = $student;
|
||||||
|
|
||||||
|
}
|
||||||
|
/* Turn our load ID into a server-side cat/div id */
|
||||||
|
$cat_id = $catmap[$project['projectcategories_id']];
|
||||||
|
$div_id = $divmap[$project['projectdivisions_id']];
|
||||||
|
|
||||||
|
/* Save the project info => students */
|
||||||
|
$prizewinners[]=array( 'xml_type' => 'project',/* for ysc compatability */
|
||||||
|
'projectid'=>$project['id'],
|
||||||
|
'projectnumber'=>$project['projectnumber'],
|
||||||
|
'title'=>$project['title'],
|
||||||
|
'abstract'=>$project['summary'],
|
||||||
|
'language'=>$project['language'],
|
||||||
|
'projectcategories_id'=>$cat_id,
|
||||||
|
'projectdivisions_id'=>$div_id,
|
||||||
|
'students'=>$students );
|
||||||
|
}
|
||||||
|
/* Save the prize info => projects */
|
||||||
|
$winners['prizes'][$prize['prize']] = array(
|
||||||
|
'xml_type'=>'prize', /* For ysc compatability */
|
||||||
|
'identifier'=>$prize['external_identifier'], /* for ysc compatability */
|
||||||
|
'projects'=>$prizewinners);
|
||||||
|
}
|
||||||
|
$all_winners[] = $winners;
|
||||||
}
|
}
|
||||||
return $winners;
|
return $all_winners;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch($_GET['action']) {
|
switch($_GET['action']) {
|
||||||
case 'award_upload':
|
case 'award_upload':
|
||||||
$award_awards_id = intval($_GET['id']);
|
$award_awards_id = intval($_GET['id']);
|
||||||
$winners = get_winners($award_awards_id);
|
$fairs_id = intval($_GET['fairs_id']);
|
||||||
|
$all_winners = get_winners($award_awards_id, $fairs_id);
|
||||||
|
|
||||||
/* Get the fair */
|
/* Get the fair */
|
||||||
$q = mysql_query("SELECT award_source_fairs_id FROM award_awards WHERE id='$award_awards_id'");
|
$q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id}'");
|
||||||
$a = mysql_fetch_assoc($q);
|
|
||||||
$q = mysql_query("SELECT * FROM fairs WHERE id='{$a['award_source_fairs_id']}'");
|
|
||||||
$fair = mysql_fetch_assoc($q);
|
$fair = mysql_fetch_assoc($q);
|
||||||
|
|
||||||
echo '<br />';
|
echo '<br />';
|
||||||
if($winners == false) {
|
/* Check that we're going to upload something */
|
||||||
echo notice(i18n('No winners selected for this award'));
|
$upload_something = false;
|
||||||
} else {
|
foreach($all_winners as $w) {
|
||||||
if($fair['type'] == 'ysc') {
|
foreach($w['prizes'] as $p) {
|
||||||
$w = array();
|
if(count($p['projects'])) {
|
||||||
foreach($winners['prizes'] as $prize_name=>$prize) {
|
$upload_something = true;
|
||||||
$w[] = $prize;
|
break;
|
||||||
}
|
}
|
||||||
$req=array("awardwinners"=>array(
|
|
||||||
"username"=>$fair['username'],
|
|
||||||
"password"=>$fair['password'],
|
|
||||||
"identifier"=>$winners['external_identifier'],
|
|
||||||
"prizes"=>$w,
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$url = $winners['external_postback'];
|
|
||||||
} else {
|
|
||||||
$req = array('award_upload' => $winners);
|
|
||||||
$req['award_upload']['year'] = $config['FAIRYEAR'];
|
|
||||||
$url = ''; /* url is ignored for type = sfiab */
|
|
||||||
}
|
|
||||||
echo i18n("Sending %1 winners to %2...", array('<b>'.$winners['award_name'].'</b>',
|
|
||||||
'<b>'.$fair['name'].'</b>'));
|
|
||||||
echo '<br />';
|
|
||||||
// echo "<pre>"; print_r($req); echo "</pre>";
|
|
||||||
|
|
||||||
$data = curl_query($fair, $req, $url);
|
|
||||||
|
|
||||||
if($data['error'] != 0) {
|
|
||||||
echo error("Server said: ".htmlspecialchars(print_r($data,true)));
|
|
||||||
} else {
|
|
||||||
if(is_array($data['notice']))
|
|
||||||
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['notice'])."</pre>");
|
|
||||||
else if(is_array($data['message']))
|
|
||||||
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['message'])."</pre>");
|
|
||||||
else if($data['message']) {
|
|
||||||
echo notice("{$fair['name']} server said: <pre>".$data['message']."</pre>");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
echo notice("{$fair['name']} server said: <pre>".htmlspecialchars(print_r($data,true))."</pre>");
|
|
||||||
echo happy(i18n("Upload completed successfully"));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($upload_something == false) {
|
||||||
|
echo notice(i18n('No winners to be uploaded'));
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($fair['type'] == 'ysc') {
|
||||||
|
if($award_awards_id == -1) {
|
||||||
|
echo "Multiple uploads not supported for YSC targets.\n";
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
/* Pull the single-award out, get_winners() will never
|
||||||
|
* return more than one award for YSC targets */
|
||||||
|
$winners = array_shift($all_winners);
|
||||||
|
$w = array();
|
||||||
|
foreach($winners['prizes'] as $prize_name=>$prize) {
|
||||||
|
$w[] = $prize;
|
||||||
|
}
|
||||||
|
$req=array("awardwinners"=>array(
|
||||||
|
"username"=>$fair['username'],
|
||||||
|
"password"=>$fair['password'],
|
||||||
|
"identifier"=>$winners['external_identifier'],
|
||||||
|
"prizes"=>$w,
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$url = $winners['external_postback'];
|
||||||
|
} else {
|
||||||
|
$req = array();
|
||||||
|
$req['awards_upload'] = $all_winners;
|
||||||
|
$url = ''; /* url is ignored for type = sfiab */
|
||||||
|
|
||||||
|
}
|
||||||
|
echo i18n("Sending winners to %1...", array('<b>'.$fair['name'].'</b>'));
|
||||||
|
echo '<br />';
|
||||||
|
// echo "<pre>"; print_r($req); echo "</pre>";
|
||||||
|
|
||||||
|
$data = curl_query($fair, $req, $url);
|
||||||
|
|
||||||
|
if($data['error'] != 0) {
|
||||||
|
echo error("Server said: ".htmlspecialchars(print_r($data,true)));
|
||||||
|
} else {
|
||||||
|
if(is_array($data['notice']))
|
||||||
|
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['notice'])."</pre>");
|
||||||
|
else if(is_array($data['message']))
|
||||||
|
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['message'])."</pre>");
|
||||||
|
else if($data['message'])
|
||||||
|
echo notice("{$fair['name']} server said: <pre>".$data['message']."</pre>");
|
||||||
|
else
|
||||||
|
echo notice("{$fair['name']} server said: <pre>".htmlspecialchars(print_r($data,true))."</pre>");
|
||||||
|
echo happy(i18n("Upload completed successfully"));
|
||||||
|
}
|
||||||
exit;
|
exit;
|
||||||
|
|
||||||
case 'catdiv_load':
|
case 'catdiv_load':
|
||||||
$fairs_id = intval($_GET['id']);
|
$fairs_id = intval($_GET['id']);
|
||||||
$q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id'");
|
$q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id'");
|
||||||
@ -277,7 +317,8 @@ case 'catdiv_save':
|
|||||||
|
|
||||||
case 'confirm_load':
|
case 'confirm_load':
|
||||||
$award_awards_id = intval($_GET['id']);
|
$award_awards_id = intval($_GET['id']);
|
||||||
$winners = get_winners($award_awards_id);
|
$fairs_id = intval($_GET['fairs_id']);
|
||||||
|
$winners = get_winners($award_awards_id, $fairs_id);
|
||||||
print_r($winners);
|
print_r($winners);
|
||||||
exit;
|
exit;
|
||||||
|
|
||||||
@ -340,7 +381,7 @@ function catdiv_load()
|
|||||||
}
|
}
|
||||||
function award_upload(id)
|
function award_upload(id)
|
||||||
{
|
{
|
||||||
$("#award_upload_status").load("<?=$_SERVER['PHP_SELF']?>?action=award_upload&id="+id);
|
$("#award_upload_status").load("<?=$_SERVER['PHP_SELF']?>?action=award_upload&id="+id+"&fairs_id="+fairs_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
function catdiv_save()
|
function catdiv_save()
|
||||||
@ -360,7 +401,7 @@ function catdiv_next()
|
|||||||
|
|
||||||
function confirm_load()
|
function confirm_load()
|
||||||
{
|
{
|
||||||
$("#confirm_data").load("<?=$_SERVER['PHP_SELF']?>?action=confirm_load&id="+award_awards_id);
|
$("#confirm_data").load("<?=$_SERVER['PHP_SELF']?>?action=confirm_load&id="+award_awards_id+"&fairs_id="+fairs_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
function confirm_upload()
|
function confirm_upload()
|
||||||
@ -465,7 +506,6 @@ $(document).ready(function() {
|
|||||||
echo "<option value=\"-1\">Loading...</option>";
|
echo "<option value=\"-1\">Loading...</option>";
|
||||||
echo '</select></td></tr>';
|
echo '</select></td></tr>';
|
||||||
}
|
}
|
||||||
/* <input type="submit" onClick="catdiv_save();return false;" value="<?=i18n("Save")?>" /></td>*/
|
|
||||||
?>
|
?>
|
||||||
</table>
|
</table>
|
||||||
<br />
|
<br />
|
||||||
@ -498,6 +538,7 @@ $(document).ready(function() {
|
|||||||
|
|
||||||
</div></div>
|
</div></div>
|
||||||
|
|
||||||
|
|
||||||
<?
|
<?
|
||||||
|
|
||||||
|
|
||||||
@ -508,6 +549,44 @@ if(!function_exists('curl_init')) {
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Fairs first */
|
||||||
|
$q = mysql_query("SELECT fairs.id, fairs.name, fairs.type, COUNT(award_awards.id) as AWARD_COUNT FROM fairs
|
||||||
|
LEFT JOIN award_awards ON award_awards.award_source_fairs_id=fairs.id
|
||||||
|
WHERE award_awards.award_source_fairs_id IS NOT NULL
|
||||||
|
AND award_awards.year='{$config['FAIRYEAR']}'
|
||||||
|
GROUP BY fairs.id
|
||||||
|
ORDER BY fairs.name ");
|
||||||
|
echo mysql_error();
|
||||||
|
|
||||||
|
?>
|
||||||
|
<h4><?=i18n('Upload all winners to a source')?>:</h4>
|
||||||
|
|
||||||
|
<table class="tableview"><thead>
|
||||||
|
<tr><th><?=i18n("Source Name")?></th>
|
||||||
|
<th><?=i18n("Number of Awards")?></th>
|
||||||
|
<th><?=i18n("Send All")?></th>
|
||||||
|
</tr></thead>
|
||||||
|
<?
|
||||||
|
|
||||||
|
while($r=mysql_fetch_object($q)) {
|
||||||
|
echo "<tr><td>{$r->name}</td>\n";
|
||||||
|
echo "<td>{$r->AWARD_COUNT}</td>";
|
||||||
|
echo "<td align=\"center\">";
|
||||||
|
if($r->type == 'sfiab')
|
||||||
|
echo "<a href=\"#\" onClick=\"popup_upload({$r->id},-1)\" >".i18n("Send All")."</a>";
|
||||||
|
else
|
||||||
|
echo "Not available yet, we're working on it!";
|
||||||
|
echo "</td></tr>";
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
</table>
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
|
||||||
|
|
||||||
|
<?
|
||||||
|
|
||||||
$q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname,
|
$q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname,
|
||||||
fairs.name as fairname, award_source_fairs_id,
|
fairs.name as fairname, award_source_fairs_id,
|
||||||
fairs.type as fairtype, award_awards.external_additional_materials
|
fairs.type as fairtype, award_awards.external_additional_materials
|
||||||
@ -519,6 +598,7 @@ $q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname,
|
|||||||
echo mysql_error();
|
echo mysql_error();
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
<h4><?=i18n('Upload individual winners to a source')?>:</h4>
|
||||||
|
|
||||||
<table class="tableview"><thead>
|
<table class="tableview"><thead>
|
||||||
<tr><th><?=i18n("Award Name")?></th>
|
<tr><th><?=i18n("Award Name")?></th>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user