.html"
// Also creates a summary page listing all countries which have profiled
// members, the number of such members, and links to the created pages for
// each country.
function build_country_pages() {
$query = "SELECT * FROM profile";
$result = mysql_query($query);
$numIds = 0;
// Build a multi-dimensional array of countries,
// each element of which contains an array
// of the userids who belong to those countries.
// Format: array[country][index] = userid.
while ($profile = mysql_fetch_object($result)) {
$query2 = "SELECT * FROM user WHERE id=$profile->userid";
$result2 = mysql_query($query2);
$row2 = mysql_fetch_object($result2);
if ($row2->country) {
$countryMembers[$row2->country][] = $row2->id;
$numIds++;
} else {
$countryMembers['Other'][] = $row2->id;
}
}
mysql_free_result($result);
mysql_free_result($result2);
//echo "$numIds users have profiles AND non-null country entries.
";
$countries = array_keys($countryMembers);
sort($countries);
// Build the pages.
// TODO: Define a constant for the desired number of rows per page.
foreach ($countries as $country) {
$baseFileName = "profile_country_" . get_legal_filename($country);
$filePath = PROFILE_PATH;
build_profile_pages(
$countryMembers[$country],
"User Profiles from $country", $country, 5, 2,
$filePath, $baseFileName, "../html/"
);
}
// Build the summary page linking to the individual country pages.
build_country_summary_page($countryMembers);
//echo "
View Summary Page";
//echo "
Done";
}
// Creates pages grouping users by the first letter of their names.
function build_alpha_pages() {
global $alphabet;
$query = "SELECT * FROM profile";
$result = mysql_query($query);
$numIds = 0;
while ($row = mysql_fetch_assoc($result)) {
$query2 = "SELECT * FROM user WHERE id = " . $row['userid'];
$result2 = mysql_query($query2);
$row2 = mysql_fetch_assoc($result2);
if ($row2['name']) {
$name = ltrim($row2['name']);
$members[strtoupper($name[0])][] = $row2['id'];
$numIds++;
}
}
mysql_free_result($result);
mysql_free_result($result2);
//echo "$numIds users have profiles AND non-null country entries.
";
$letters = array_keys($members);
foreach ($letters as $letter) {
// NOTE: Array indexing is case sensitive.
$filePath = PROFILE_PATH;
if (in_array($letter, $alphabet)) {
build_profile_pages(
$members[$letter],
"User Profiles - Names beginning with $letter",
"Names beginning with $letter", 5, 2, $filePath,
"profile_$letter"
);
} else {
build_profile_pages(
$members[$letter],
"User Profiles - Names beginning with other characters",
"Names beginning with other characters", 5, 2, $filePath,
"profile_other"
);
}
}
build_alpha_summary_page($letters);
}
// A generalized function to produce some number of pages summarizing a
// set of user profiles.
function build_profile_pages($members, $pageHead, $pageTitle, $rowsPerPage, $colsPerPage, $filePath, $baseFileName) {
$numMembers = count($members);
$numPerPage = $rowsPerPage * $colsPerPage;
$numPages = ceil(count($members) / $numPerPage);
$count = 0;
for ($page = 1; $page <= $numPages; $page++) {
$filename = $filePath . $baseFileName . "_" . $page . ".html";
$descriptor = fopen($filename, "w");
$head = $pageHead . ": Page $page of $numPages";
page_head($pageHead, null, $descriptor, false);
fwrite($descriptor, "$pageTitle
\n");
fwrite($descriptor, "Last updated " . pretty_time_str(time()) . "\n");
$offset = (($page-1) * $rowsPerPage * $colsPerPage);
show_user_table($members, $offset, $numPerPage, $colsPerPage, $descriptor);
write_page_links($baseFileName, $page, $numPages, $descriptor);
page_tail(false, $descriptor);
fclose($descriptor);
}
}
function build_country_summary_page($countryMembers) {
$countries = array_keys($countryMembers);
$filename = PROFILE_PATH . "profile_country.html";
$descriptor = fopen($filename, "w");
page_head("User Profiles by Country", null, $descriptor, false);
fwrite($descriptor, "
User Profiles by Country
Last updated " . pretty_time_str(time()) . "");
fwrite($descriptor, "
\n");
fwrite($descriptor, "Country | Profiles |
\n");
foreach ($countries as $country) {
$numMembers = count($countryMembers[$country]);
$name = get_legal_filename($country);
fwrite($descriptor,
"\n$country | $numMembers | \n"
);
}
fwrite($descriptor, "
");
page_tail(false, $descriptor);
fclose($descriptor);
}
function build_alpha_summary_page($characters) {
global $alphabet;
$filename = PROFILE_PATH."profile_alpha.html";
$descriptor = fopen($filename, "w");
foreach ($alphabet as $character) {
if (in_array($character, $characters)) {
fwrite($descriptor, "$character ");
unset($characters[$character]);
} else {
fwrite($descriptor, "$character ");
}
}
// Link to the 'Other' page if necessary.
if (!empty($characters)) {
fwrite($descriptor, "Other ");
}
fclose($descriptor);
}
function generate_uod_page($profile, $user) {
$filename = PROFILE_PATH."uotd.html";
$descriptor = fopen($filename, "w");
if ($profile->has_picture) {
fwrite($descriptor,
"id>"
);
}
$x = user_links($user);
fwrite($descriptor, "The " . PROJECT . " User of the Day is $x");
fclose($descriptor);
}
// see if it's time to pick a new UOD.
// Either way, generate the UOD page
//
function build_uotd_page() {
// Check if the current UOTD has had their 24 hours of fame - if so, pick a new one.
$result = mysql_query("SELECT * FROM profile ORDER BY uotd_time DESC LIMIT 1");
if (mysql_num_rows($result) > 0) {
$current_uotd = mysql_fetch_object($result);
$assigned = getdate($current_uotd->uotd_time);
$now = getdate(time());
if ($assigned['mday'] == $now['mday']) {
$user = lookup_user_id($current_uotd->userid);
generate_uod_page($current_uotd, $user);
exit();
}
}
// TODO: Verify that adding RAND() didn't screw this up.
$result = mysql_query("SELECT * FROM profile WHERE 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\nTo approve more candidates for User of the Day, direct your web browser 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 WHERE verification = 1 ORDER BY uotd_time ASC LIMIT 1");
}
if (!$result || mysql_num_rows($result) == 0) {
// No valid users of the day - do something.
exit();
}
$profile = mysql_fetch_object($result);
$user = lookup_user_id($profile->userid);
generate_uod_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. Thanks again for supporting us- it's members like you that make distributed computing projects like ours such a success.\n\nBest regards and much thanks,\n\nThe " . PROJECT . " team."
);
}
?>