has_picture) { return "id>"; } else { return ""; } } function generate_uotd_page($profile, $user) { $filename = PROFILE_PATH."uotd.html"; $descriptor = fopen($filename, "w"); if ($profile->has_picture) { fwrite($descriptor, uotd_thumbnail($profile, $user)); } $x = user_links($user); fwrite($descriptor, "The " . PROJECT . " User of the Day is $x"); fclose($descriptor); } // return the last UOTD profile, or null // function get_current_uotd() { $result = mysql_query("SELECT * FROM profile ORDER BY uotd_time DESC LIMIT 1"); $p = null; if (mysql_num_rows($result) > 0) { $p = mysql_fetch_object($result); } mysql_free_result($result); return $p; } // see if it's time to pick a new UOTD. // Either way, generate the UOTD page // function build_uotd_page() { echo date("F d Y", time())."\n"; $current_uotd = get_current_uotd(); if ($current_uotd) { $assigned = getdate($current_uotd->uotd_time); $now = getdate(time()); if ($assigned['mday'] == $now['mday']) { $user = lookup_user_id($current_uotd->userid); generate_uotd_page($current_uotd, $user); echo "Already have UOTD for today\n"; exit(); } } $result = mysql_query("SELECT * FROM profile,user WHERE profile.userid=user.id AND total_credit>0 AND verification=1 AND uotd_time IS NULL ORDER BY RAND()"); // If the number of approved profiles dips below a threshold, // email the sys admin every time we pick a new one. // if ($result && mysql_num_rows($result) < UOTD_THRESHOLD) { mail(SYS_ADMIN_EMAIL, PROJECT . ": User of the Day pool is running low!", "The pool of approved candidates for User of the Day has". " reached your assigned threshold: there are now only " . mysql_num_rows($result) . " approved users.\n\n". "To approve more candidates for User of the Day,". " go to the " . PROJECT . " administration page and click \"Unrated profile\"" ); } if ($result && mysql_num_rows($result) == 0) { // If all verified profiles have been selected as UOTD, // reshow the one that was shown least recently. // $result = mysql_query("SELECT * FROM profile,user WHERE profile.userid=user.id AND total_credit>0 AND verification=1 ORDER BY uotd_time ASC LIMIT 1"); } if (!$result || mysql_num_rows($result) == 0) { // No valid users of the day - do something. echo "No screened users found\n"; exit(); } $profile = mysql_fetch_object($result); $user = lookup_user_id($profile->userid); generate_uotd_page($profile, $user); $sql = "UPDATE profile SET uotd_time = " . time() . " WHERE userid=$user->id"; mysql_query($sql); mail($user->email_addr, "You're the " . PROJECT . " user of the day!", "Congratulations!\n\nYou've been chosen as the " . PROJECT . " user of the day! Your profile will be featured on the " . PROJECT . " website for the next 24 hours." ); echo "Chose user $user->id as UOTD\n"; } ?>