From a0d27df91e20274b402bd19b7915066c1c3c90bf Mon Sep 17 00:00:00 2001 From: dave <dave> Date: Sun, 19 Oct 2008 21:42:57 +0000 Subject: [PATCH] - use the newer (faster) user load, and always load a full user. - delete now deprecated code because of the new user loader --- judge.inc.php | 17 +-- judge_expertise.php | 4 +- judge_main.php | 2 +- judge_other.php | 4 +- judge_special_awards.php | 2 +- user.inc.php | 237 +++++++++++++++------------------------ user_activate.php | 10 +- user_multirole.php | 2 - user_personal.php | 4 +- volunteer.inc.php | 5 +- volunteer_main.php | 2 +- volunteer_position.php | 2 +- 12 files changed, 104 insertions(+), 187 deletions(-) diff --git a/judge.inc.php b/judge.inc.php index a5278a50..cf692fc0 100644 --- a/judge.inc.php +++ b/judge.inc.php @@ -34,10 +34,6 @@ $preferencechoices=array( function judge_status_expertise(&$u) { global $config; - if($u['load_full'] == false) { - echo "ERROR: judge_status_expertise() called without a full user."; - exit; - } /* If the judging special awards are active, and the judge has * selected "I am a special awards judge", then disable @@ -64,10 +60,6 @@ function judge_status_expertise(&$u) function judge_status_other(&$u) { global $config; - if($u['load_full'] == false) { - echo "ERROR: judge_status_other() called without a full user."; - exit; - } /* They must select a language to judge in */ if(count($u['languages']) < 1) return 'incomplete'; @@ -80,10 +72,6 @@ function judge_status_other(&$u) function judge_status_special_awards(&$u) { global $config; - if($u['load_full'] == false) { - echo "ERROR: judge_status_special_awards() called without a full user."; - exit; - } /* Complete if: * - judge has selected (none) "no special award preferences" @@ -115,10 +103,7 @@ function judge_status_special_awards(&$u) function judge_status_update(&$u) { - if($u['load_full'] == false) { - echo "ERROR: judge_status_update() called without a full user."; - exit; - } + global $config; if( user_personal_info_status($u) == 'complete' && judge_status_expertise($u) == 'complete' diff --git a/judge_expertise.php b/judge_expertise.php index b21fe5cf..bfaf24db 100644 --- a/judge_expertise.php +++ b/judge_expertise.php @@ -26,7 +26,7 @@ require_once('user.inc.php'); require_once('judge.inc.php'); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); //send the header // $type = $_SESSION['users_type']; @@ -64,7 +64,7 @@ } user_save($u); message_push(notice(i18n("Preferences successfully saved"))); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($u['id']); } judge_status_update($u); diff --git a/judge_main.php b/judge_main.php index 664d0d18..d0b34f73 100644 --- a/judge_main.php +++ b/judge_main.php @@ -29,7 +29,7 @@ user_auth_required('judge'); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); if($u['judge_active'] == 'no') { message_push(notice(i18n("Your judge role is not active. If you would like to participate as a judge for the %1 %2 please click the '<b>Activate Role</b>' button in the Judge section below",array($config['FAIRYEAR'],$config['fairname'])))); diff --git a/judge_other.php b/judge_other.php index 7051e910..a51f9ffe 100644 --- a/judge_other.php +++ b/judge_other.php @@ -27,7 +27,7 @@ require_once('judge.inc.php'); require_once("questions.inc.php"); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); //send the header send_header('Other Information', @@ -52,7 +52,7 @@ user_save($u); message_push(notice(i18n("Preferences successfully saved"))); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($u['id']); } judge_status_update($u); diff --git a/judge_special_awards.php b/judge_special_awards.php index b4c6778d..09b5cf2a 100644 --- a/judge_special_awards.php +++ b/judge_special_awards.php @@ -26,7 +26,7 @@ require_once('user.inc.php'); require_once('judge.inc.php'); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); //send the header send_header('Special Awards', diff --git a/user.inc.php b/user.inc.php index e68dd546..62f31e77 100644 --- a/user.inc.php +++ b/user.inc.php @@ -46,123 +46,76 @@ function user_generate_password($pwlen=8) -function user_load_fair($u) +/* Separate user_load_type functions, these could make additional database + * calls if required */ +function user_load_fair(&$u) { - /* Double check, make sure the user is of this type */ - if(!in_array('fair', $u['types'])) return false; - - $q = mysql_query("SELECT * FROM users_fair - WHERE users_id='{$u['id']}' - "); - if(mysql_num_rows($q)!=1) return false; - - $r = mysql_fetch_object($q); - $ret = array(); - $ret['fair_active'] = $r->fair_active; - $ret['fairs_id'] = intval($r->fairs_id); - return $ret; + $u['fair_active'] = ($u['fair_active'] == 'yes') ? 'yes' : 'no'; + $u['fair_complete'] = ($u['fair_complete'] == 'yes') ? 'yes' : 'no'; + $u['fairs_id'] = intval($u['fairs_id']); + return true; } -function user_load_student($u) +function user_load_student(&$u) { - /* Double check, make sure the user is of this type */ - if(!in_array('student', $u['types'])) return false; - $ret = array(); - return $ret; +// $u['student_active'] = ($u['student_active'] == 'yes') ? 'yes' : 'no'; +// $u['student_complete'] = ($u['student_complete'] == 'yes') ? 'yes' : 'no'; + return false; } -function user_load_judge($u) +function user_load_judge(&$u) { - /* Double check, make sure the user is of this type */ - if(!in_array('judge', $u['types'])) { - echo 'ERROR: User is not a judge in user_load_judge'; - return false; - } - - $q = mysql_query("SELECT * FROM users_judge - WHERE users_id='{$u['id']}'"); - if(mysql_num_rows($q)!=1) { - echo "DATABASE ERROR: User judge record not found"; - print_r($u); - return false; - } - - $r = mysql_fetch_object($q); - $ret = array(); - $ret['judge_active'] = $r->judge_active; - $ret['judge_complete'] = $r->judge_complete; - $ret['years_school'] = intval($r->years_school); - $ret['years_regional'] = intval($r->years_regional); - $ret['years_national'] = intval($r->years_national); - $ret['willing_chair'] = ($r->willing_chair == 'yes') ? 'yes' : 'no'; - $ret['special_award_only'] = ($r->special_award_only == 'yes') ? 'yes' : 'no'; - $ret['cat_prefs'] = unserialize($r->cat_prefs); - $ret['div_prefs'] = unserialize($r->div_prefs); - $ret['divsub_prefs'] = unserialize($r->divsub_prefs); - $ret['expertise_other'] = $r->expertise_other; - $ret['languages'] = unserialize($r->languages); - $ret['highest_psd'] = $r->highest_psd; + $u['judge_active'] = ($u['judge_active'] == 'yes') ? 'yes' : 'no'; + $u['judge_complete'] = ($u['judge_complete'] == 'yes') ? 'yes' : 'no'; + $u['years_school'] = intval($u['years_school']); + $u['years_regional'] = intval($u['years_regional']); + $u['years_national'] = intval($u['years_national']); + $u['willing_chair'] = ($u['willing_chair'] == 'yes') ? 'yes' : 'no'; + $u['special_award_only'] = ($u['special_award_only'] == 'yes') ? 'yes' : 'no'; + $u['cat_prefs'] = unserialize($u['cat_prefs']); + $u['div_prefs'] = unserialize($u['div_prefs']); + $u['divsub_prefs'] = unserialize($u['divsub_prefs']); +// $u['expertise_other'] = $u['expertise_other']; + $u['languages'] = unserialize($u['languages']); +// $u['highest_psd'] = $u['highest_psd']; /* Sanity check the arrays, make sure they are arrays */ $should_be_arrays = array('cat_prefs','div_prefs', 'divsub_prefs','languages'); foreach($should_be_arrays as $k) { - if(!is_array($ret[$k])) $ret[$k] = array(); + if(!is_array($u[$k])) $u[$k] = array(); } - return $ret; + return true; } -function user_load_committee($u) +function user_load_committee(&$u) { - /* Double check, make sure the user is of this type */ - if(!in_array('committee', $u['types'])) return false; - - $q = mysql_query("SELECT * FROM users_committee - WHERE users_id='{$u['id']}'"); - if(mysql_num_rows($q)!=1) return false; - - $r = mysql_fetch_object($q); - $ret = array(); - $ret['committee_active'] = $r->committee_active; - $ret['emailprivate'] = $r->emailprivate; - $ret['ord'] = intval($r->ord); - $ret['displayemail'] = ($r->displayemail == 'yes') ? 'yes' : 'no'; - $ret['access_admin'] = ($r->access_admin == 'yes') ? 'yes' : 'no'; - $ret['access_config'] = ($r->access_config == 'yes') ? 'yes' : 'no'; - $ret['access_super'] = ($r->access_super == 'yes') ? 'yes' : 'no'; - - return $ret; + $u['committee_active'] = $u['committee_active']; + $u['emailprivate'] = $u['emailprivate']; + $u['ord'] = intval($u['ord']); + $u['displayemail'] = ($u['displayemail'] == 'yes') ? 'yes' : 'no'; + $u['access_admin'] = ($u['access_admin'] == 'yes') ? 'yes' : 'no'; + $u['access_config'] = ($u['access_config'] == 'yes') ? 'yes' : 'no'; + $u['access_super'] = ($u['access_super'] == 'yes') ? 'yes' : 'no'; + return true; } -function user_load_volunteer($u) +function user_load_volunteer(&$u) { - /* Double check, make sure the user is of this type */ - if(!in_array('volunteer', $u['types'])) return false; - - $q = mysql_query("SELECT * FROM users_volunteer - WHERE users_id='{$u['id']}'"); - if(mysql_num_rows($q)!=1) { - echo "DATABASE ERROR, loading volunteer for user {$u['id']} returned ".mysql_num_rows($q)." rows."; - return false; - } - - $r = mysql_fetch_object($q); - $ret = array(); - $ret['volunteer_active'] = $r->volunteer_active; - $ret['volunteer_complete'] = $r->volunteer_complete; - return $ret; + $u['volunteer_active'] = ($u['>volunteer_active'] == 'yes') ? 'yes' : 'no'; + $u['volunteer_complete'] = ($u['>volunteer_complete'] == 'yes') ? 'yes' : 'no'; + return true; } -function user_load($user, $load_full=false) +function user_load($user) { $id = 0; /* Sort out the type first */ if(is_array($user)){ - /* User already loaded, this is just an extended load */ + /* User already loaded*/ $id = $user['id']; $where = "id='$id'"; - $load_base = false; } else { $id = intval($user); @@ -179,59 +132,53 @@ function user_load($user, $load_full=false) // $e = stripslashes($user); // $where = "email='$e'"; } - $load_base = true; } - if($load_base) { - $query = "SELECT * FROM users - WHERE - $where - AND deleted='no' - "; - $q=mysql_query($query); + /* So, it turns out that doing one big load is faster than loading just + * from the users table then loading only the specific types the user + * has.. go figure. */ + $query = "SELECT * FROM `users` + LEFT JOIN `users_committee` ON `users_committee`.`users_id`=`users`.`id` + LEFT JOIN `users_judge` ON `users_judge`.`users_id`=`users`.`id` + LEFT JOIN `users_volunteer` ON `users_volunteer`.`users_id`=`users`.`id` + LEFT JOIN `users_fair` ON `users_fair`.`users_id`=`users`.`id` + WHERE $where + AND `users`.`deleted`='no' "; + $q=mysql_query($query); - if(mysql_num_rows($q)!=1) { - echo "Query [$query] returned ".mysql_num_rows($q)." rows\n"; + if(mysql_num_rows($q)!=1) { + echo "Query [$query] returned ".mysql_num_rows($q)." rows\n"; + return false; + } + + $ret = mysql_fetch_assoc($q); + + /* Do we need to do number conversions? */ + $ret['id'] = intval($ret['id']); + + /* Turn the type into an array, because there could be more than one */ + $ts = explode(',', $ret['types']); + $ret['types'] = $ts; /* Now we can use in_array('judge', $ret['types']) ; */ + + foreach($ret['types'] as $t) { + /* These all pass $ret by reference, and can modify + * $ret */ + $r = call_user_func("user_load_$t", $ret); + if($r != true) { + echo "user_load_$t returned false!\n"; return false; } - $ret = mysql_fetch_assoc($q); - - /* Do we need to do number conversions? */ - $ret['id'] = intval($ret['id']); - - /* Turn the type into an array, because there could be more than one */ - $ts = explode(',', $ret['types']); - $ret['types'] = $ts; /* Now we can use in_array('judge', $ret['types']) ; */ - } else { - $ret = $user; - } - - if($load_full) { - $r = true; - foreach($ret['types'] as $t) { - if($ret['load_full'] == true) continue; - /* These all pass $ret by reference, and can modify - * $ret */ - $r = call_user_func("user_load_$t", $ret); - if(!is_array($r)) { - echo "user_load_$t didn't return an array!\n"; - return false; + /* It is important that each type database doesn't + have conflicting column names */ +/* foreach($r as $k=>$v) { + if(array_key_exists($k, $ret)) { + echo "DATABASE DESIGN ERROR, duplicate user key $k"; + exit; } - - /* It is important that each type database doesn't - have conflicting column names */ - foreach($r as $k=>$v) { - if(array_key_exists($k, $ret)) { - echo "DATABASE DESIGN ERROR, duplicate user key $k"; - exit; - } - } - $ret = array_merge($ret, $r); } - $ret['load_full'] = true; - } else { - $ret['load_full'] = false; + $ret = array_merge($ret, $r); +*/ } /* Do this assignment without recursion :) */ @@ -377,11 +324,8 @@ function user_save($u) if($u['password'] != $u['orig']['password']) user_set_password($u['id'], $u['password']); - /* If this was a full load, do a full save */ - if($u['load_full'] == true) { - foreach($u['types'] as $t) { - call_user_func("user_save_$t", $u); - } + foreach($u['types'] as $t) { + call_user_func("user_save_$t", $u); } } @@ -553,7 +497,7 @@ function user_dupe($u, $new_year) $q = mysql_query("UPDATE users SET year='$new_year' WHERE id='$id'"); /* Load the new user */ - $u2 = user_load($id, false); + $u2 = user_load($id); foreach($u2['types'] as $t) { user_dupe_row("users_$t", 'users_id', $u['id'], $id); @@ -620,7 +564,7 @@ function user_create($type, $u = NULL) mysql_query("INSERT INTO users_committee(`users_id`, `committee_active`) VALUES ('$uid', 'yes')"); break; } - return user_load($uid, true); + return user_load($uid); } @@ -761,11 +705,8 @@ function user_personal_required_fields($type) return $ret; } -function user_personal_info_status($u = false) +function user_personal_info_status(&$u) { - if($u == false) { - $u = user_load($_SESSION['users_id']); - } $required = array(); foreach($u['types'] as $t) { $required = array_merge($required, @@ -780,9 +721,12 @@ function user_personal_info_status($u = false) return 'incomplete'; } } + /* FIXME: somehow call the $type _status_update() function to update + * the individual $type _complete entry? */ return 'complete'; } +/* user_{$type}_login() is called with a full $u loaded */ function user_committee_login($u) { /* Double check, make sure the user is of this type */ @@ -791,8 +735,6 @@ function user_committee_login($u) exit; } - $u = user_load($u, true); - $_SESSION['access_admin'] = $u['access_admin'];// == 'yes') ? true : false; $_SESSION['access_config'] = $u['access_config'];// == 'yes') ? true : false; $_SESSION['access_super'] = $u['access_super'];// == 'yes') ? true : false; @@ -806,7 +748,6 @@ function user_fair_login($u) exit; } - $u = user_load($u, true); $_SESSION['fairs_id'] = $u['fairs_id'];// == 'yes') ? true : false; } diff --git a/user_activate.php b/user_activate.php index 26457d0c..3c02dff4 100644 --- a/user_activate.php +++ b/user_activate.php @@ -43,11 +43,12 @@ } + $u = user_load($_SESSION['users_id']); + switch($_POST['action']) { case 'delete': //okay here we go, lets get rid of them completely, since this is what theyve asked for message_push(happy(i18n("Account successfully deleted. Goodbye"))); - $u = user_load($_SESSION['users_id'], true); user_delete($u); header('location: user_login.php?action=logout'); exit; @@ -55,19 +56,16 @@ case 'remove': /* Like delete, only we're only deleting a role, not the whole account */ message_push(happy(i18n("$action_what role successfully removed."))); - $u = user_load($_SESSION['users_id'], true); user_delete($u, $action_type); break; case 'activate': - $u = user_load($_SESSION['users_id'], true); $u["{$action_type}_active"] = 'yes'; user_save($u); message_push(happy(i18n("$action_what role for %1 successfully activated",array($config['FAIRYEAR'])))); break; case 'deactivate': - $u = user_load($_SESSION['users_id'], true); $u["{$action_type}_active"] = 'no'; user_save($u); message_push(happy(i18n("$action_what role for %1 successfully deactivated",array($config['FAIRYEAR'])))); @@ -77,9 +75,7 @@ break; } - $u = user_load($_SESSION['users_id'], true); - - + $u = user_load($u['id']); $type = $_SESSION['users_type']; $m = $user_what[$type]; diff --git a/user_multirole.php b/user_multirole.php index 0ddc00fb..3fcf2d69 100644 --- a/user_multirole.php +++ b/user_multirole.php @@ -51,8 +51,6 @@ if($action == 'add') { send_header("Select Additional Roles"); - $u = user_load($_SESSION['users_id']); - //only display the named greeting if we have their name echo i18n("Hello <b>%1</b>",array($_SESSION['name'])); echo "<br />"; diff --git a/user_personal.php b/user_personal.php index 5f18098d..02843dbc 100644 --- a/user_personal.php +++ b/user_personal.php @@ -77,12 +77,12 @@ * - on the committee * - with admin access */ user_auth_required('committee', 'admin'); - $u = user_load($eid, true); + $u = user_load($eid); } else { /* Else, force them to edit themselves */ $eid = false; - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); } diff --git a/volunteer.inc.php b/volunteer.inc.php index 8706d8e8..4da00227 100644 --- a/volunteer.inc.php +++ b/volunteer.inc.php @@ -40,10 +40,7 @@ function volunteer_status_position($u) function volunteer_status_update(&$u) { - if($u['load_full'] == false) { - echo "ERROR: volunteer_status_update() called without a full user."; - exit; - } + global $config; if( user_personal_info_status($u) == 'complete' && volunteer_status_position($u) == 'complete' ) diff --git a/volunteer_main.php b/volunteer_main.php index 88352243..1a95fd2e 100644 --- a/volunteer_main.php +++ b/volunteer_main.php @@ -30,7 +30,7 @@ user_auth_required('volunteer'); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); if($u['volunteer_active'] == 'no') { message_push(notice(i18n("Your volunteer role is not active. If you would like to participate as a volunteer for the %1 %2 please click the '<b>Activate Role</b>' button in the Volunteer section below",array($config['FAIRYEAR'],$config['fairname'])))); diff --git a/volunteer_position.php b/volunteer_position.php index b59b91ac..dacaa8f1 100644 --- a/volunteer_position.php +++ b/volunteer_position.php @@ -29,7 +29,7 @@ user_auth_required('volunteer'); - $u = user_load($_SESSION['users_id'], true); + $u = user_load($_SESSION['users_id']); if($_POST['action']=="save")