forked from science-ation/science-ation
160 lines
10 KiB
PHP
160 lines
10 KiB
PHP
<?
|
|
$mailqueries=array(
|
|
"committee_all"=>array("name"=>"Committee members (all)","query"=>
|
|
"SELECT firstname, lastname, organization, email FROM users
|
|
JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE roles.type = 'committee' AND users.deleted = 'no'
|
|
GROUP BY users.id"),
|
|
|
|
/* The WHERE clause evaluates which rows to add to the GROUP
|
|
BY, the HAVING clase evaluates which grouped rows show up. We
|
|
want to to evaluate 'deleted' AFTER the grouping, so we catch
|
|
the case where the MAX(conferences_id) has deleted='yes'. If we use WHERE
|
|
deleted='no', we'll only add non-deleted rows to the group, and
|
|
end up picking up a user active in, say 2007 and 2008, but
|
|
deleted in 2009. */
|
|
"judges_all"=>array("name"=>"Judges from all conferences (except deleted judges)","query"=>
|
|
"SELECT firstname, lastname, email, deleted, MAX(conferences_id) FROM users
|
|
JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE roles.type ='judge' GROUP BY users.accounts_id HAVING deleted='no' ORDER BY email"),
|
|
|
|
"judges_active_thisconference"=>array("name"=>"Judges active for this conference", "query"=>
|
|
"SELECT firstname, lastname, email FROM users
|
|
LEFT JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE roles.type='judge' AND conferences_id={$conference['id']} AND deleted='no' AND user_roles.active='yes' ORDER BY email"),
|
|
|
|
"judges_inactive_thisconference"=>array("name"=>"Judges in the conference that are not active", "query"=>
|
|
"SELECT firstname, lastname, email FROM users
|
|
LEFT JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE roles.type='judge' AND conferences_id={$conference['id']} AND deleted='no' AND user_roles.active='no' ORDER BY email"),
|
|
|
|
"judges_inactive_allconferences"=>array("name"=>"Judges inactive for any conference", "query"=>
|
|
"SELECT firstname, lastname, email FROM users
|
|
LEFT JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE roles.type='judge' AND deleted='no' AND user_roles.active='no' ORDER BY email"),
|
|
|
|
"judges_active_complete_thisconference"=>array("name"=>"Judges active for this conference and complete", "query"=>
|
|
"SELECT firstname, lastname, email FROM users
|
|
LEFT JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.id
|
|
WHERE roles.type = 'judge' AND conferences_id = {$conference['id']}
|
|
AND user_roles.complete='yes'
|
|
AND deleted='no'
|
|
AND user_roles.active='yes'
|
|
ORDER BY email"),
|
|
|
|
"judges_active_incomplete_thisconference"=>array("name"=>"Judges active for this conference but not complete", "query"=>
|
|
"SELECT firstname, lastname, email FROM users
|
|
LEFT JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.id
|
|
WHERE roles.type = 'judge' AND conferences_id = {$conference['id']}
|
|
AND user_roles.complete='no'
|
|
AND deleted='no'
|
|
AND user_roles.active='yes'
|
|
ORDER BY email"),
|
|
|
|
"participants_complete_thisconference"=>array("name"=>"Participants complete for this conference","query"=>
|
|
"SELECT firstname, lastname, students.email FROM students,registrations WHERE students.registrations_id=registrations.id AND registrations.conferences_id='".$conference['id']."' AND ( registrations.status='complete' OR registrations.status='paymentpending') ORDER BY students.email"),
|
|
|
|
"participants_complete_paymentpending_thisconference"=>array("name"=>"Participants complete for this conference but payment pending","query"=>
|
|
"SELECT firstname, lastname, students.email FROM students,registrations WHERE students.registrations_id=registrations.id AND registrations.conferences_id='".$conference['id']."' AND registrations.status!='complete' AND registrations.status='paymentpending' ORDER BY students.email"),
|
|
|
|
"participants_notcomplete_thisconference"=>array("name"=>"Participants not complete for this conference","query"=>
|
|
"SELECT firstname, lastname, students.email FROM students,registrations WHERE students.registrations_id=registrations.id AND registrations.conferences_id='".$conference['id']."' AND registrations.status!='complete' AND registrations.status!='new' ORDER BY students.email"),
|
|
/* // FIXME - not sure if this has a sensible equivalent when dealing with "conferences" rather than fair years
|
|
"participants_complete_lastyear"=>array("name"=>"Participants complete last year","query"=>
|
|
"SELECT firstname, lastname, students.email FROM students,registrations WHERE students.registrations_id=registrations.id AND registrations.year='".($config['FAIRYEAR']-1)."' AND ( registrations.status='complete' OR registrations.status='paymentpending') ORDER BY students.email"),
|
|
*/
|
|
"participants_complete_allconferences"=>array("name"=>"Participants complete for all conferences","query"=>
|
|
"SELECT DISTINCT firstname, lastname, students.email FROM students,registrations WHERE students.registrations_id=registrations.id AND ( registrations.status='complete' OR registrations.status='paymentpending') ORDER BY students.email"),
|
|
|
|
"participants_cwsf_thisconference"=>array("name"=>"CWSF Winners for this conference","query"=>"
|
|
SELECT DISTINCT students.firstname, students.lastname, students.email
|
|
FROM award_awards
|
|
JOIN award_prizes ON award_prizes.award_awards_id=award_awards.id
|
|
JOIN winners ON winners.awards_prizes_id=award_prizes.id
|
|
JOIN projects ON winners.projects_id=projects.id
|
|
JOIN registrations ON projects.registrations_id=registrations.id
|
|
JOIN students ON students.registrations_id=registrations.id
|
|
WHERE award_awards.cwsfaward='1' AND winners.conferences_id='".$conference['id']."'
|
|
ORDER BY students.email"),
|
|
|
|
"sponsors"=>array("name"=>"Organization sponsors","query"=>
|
|
"SELECT id, organization, email FROM sponsors WHERE email!='' ORDER BY email"),
|
|
|
|
"sponsors_primarycontacts"=>array("name"=>"Organization sponsors (primary contacts)","query"=>
|
|
"SELECT uid, MAX(users.conferences_id) AS conferences_id, sponsors.organization, users.firstname, users.lastname, users.email, deleted, users_sponsor.primary
|
|
FROM sponsors,
|
|
users_sponsor,
|
|
users
|
|
WHERE
|
|
users.id=users_sponsor.users_id
|
|
AND users_sponsor.sponsors_id=sponsors.id
|
|
AND users.types LIKE '%sponsor%'
|
|
AND users.email!=''
|
|
GROUP BY uid
|
|
HAVING deleted='no' AND users_sponsor.primary='yes'
|
|
ORDER BY users.email
|
|
"),
|
|
"sponsors_allcontacts"=>array("name"=>"Organization sponsors (all contacts)","query"=>
|
|
"SELECT DISTINCT(users.email), sponsors.organization, users.firstname, users.lastname, users.email
|
|
FROM sponsors
|
|
JOIN users_sponsor ON users_sponsor.sponsors_id = sponsors.id
|
|
JOIN users ON users.id = users_sponsor.users_id
|
|
JOIN user_roles ON user_roles.users_id = users.id
|
|
JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE
|
|
roles.type = 'sponsor'
|
|
AND users.deleted='no'
|
|
AND users.email!=''
|
|
ORDER BY users.email"),
|
|
|
|
/*
|
|
"special_award_sponsors_unconfirmed"=>array("name"=>"Special award sponsors (unconfirmed only)","query"=>
|
|
"SELECT DISTINCT(award_sponsors.id), organization, firstname, lastname, award_contacts.email FROM award_sponsors, award_awards, award_contacts WHERE award_awards.sponsors_id=award_sponsors.id AND award_contacts.award_sponsors_id=award_sponsors.id AND award_sponsors.confirmed='no' AND award_awards.award_types_id='2' AND award_contacts.year='".$config['FAIRYEAR']."'"),
|
|
|
|
"special_award_sponsors_all"=>array("name"=>"Special award sponsors (all)","query"=>
|
|
"SELECT DISTINCT(award_sponsors.id), organization, firstname, lastname, award_contacts.email FROM award_sponsors, award_awards, award_contacts WHERE award_awards.sponsors_id=award_sponsors.id AND award_contacts.award_sponsors_id=award_sponsors.id AND award_awards.award_types_id='2' AND award_contacts.year='".$config['FAIRYEAR']."'"),
|
|
|
|
*/
|
|
"school_principals"=>array("name"=>"School principals","query"=>
|
|
"SELECT school, principal AS firstname, schoolemail AS email FROM schools WHERE schools.conferences_id='".$conference['id']."' AND schoolemail!=''"),
|
|
"school_scienceheads"=>array("name"=>"School science heads","query"=>
|
|
"SELECT school, sciencehead AS firstname, scienceheademail AS email FROM schools WHERE schools.conferences_id='".$conference['id']."' AND scienceheademail!=''"),
|
|
"school_teachers_thisconference"=>array("name"=>"Teachers (as entered by students) for this conference","query"=>
|
|
"SELECT DISTINCT(teacheremail) AS email, teachername AS firstname FROM students WHERE conferences_id='".$conference['id']."' AND teacheremail!=''"),
|
|
/* // FIXME again, not sure that this has a sensible equivalent with conferences
|
|
"school_teachers_lastyear"=>array("name"=>"Teachers (as entered by students) last year","query"=>
|
|
"SELECT DISTINCT(teacheremail) AS email, teachername AS firstname FROM students WHERE year='".($config['FAIRYEAR']-1)."' AND teacheremail!=''"),
|
|
*/
|
|
"school_teachers_allconferences"=>array("name"=>"Teachers (as entered by students) all conferences","query"=>
|
|
"SELECT DISTINCT(teacheremail) AS email, teachername AS firstname FROM students WHERE teacheremail!=''"),
|
|
/* Volunteers */
|
|
"volunteers_active_complete_thisconference"=>array("name"=>"Volunteers active for this conference and complete", "query"=>
|
|
"SELECT users.id, firstname, lastname, email
|
|
FROM users LEFT JOIN user_roles ON user_roles.users_id = users.id JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE users.conferences_id = '".$conference['id']."'
|
|
AND roles.type='volunteer'
|
|
AND user_roles.complete='yes'
|
|
AND user_roles.active='yes'
|
|
AND users.deleted='no'
|
|
ORDER BY email"),
|
|
|
|
"volunteers_active_incomplete_thisconference"=>array("name"=>"Volunteers active for this conference but not complete", "query"=>
|
|
"SELECT users.id, firstname, lastname, email
|
|
FROM users LEFT JOIN user_roles ON user_roles.users_id = users.id JOIN roles ON roles.id = user_roles.roles_id
|
|
WHERE users.conferences_id = '".$conference['id']."'
|
|
AND roles.type='volunteer'
|
|
AND user_roles.complete='no'
|
|
AND user_roles.active='yes'
|
|
AND users.deleted='no'
|
|
ORDER BY email"),
|
|
|
|
);
|
|
?>
|