"); mysql_select_db($db_name); } function lookup_user_auth($auth) { $result = mysql_query("select * from user where authenticator='$auth'"); if ($result) { $user = mysql_fetch_object($result); mysql_free_result($result); return $user; } else { return 0; } } function print_query_count($query, $nres, $start) { $result = mysql_query($query); $res = mysql_fetch_object($result); if ($res->cnt < ($nres+$start)) { $nres = $res->cnt-$start; } printf( "

\n" . "$res->cnt database entries match the query. Displaying $start to " . ($start+$nres) . "." . "

\n" ); } function show_platform($platform) { start_table(); row("ID", $platform->id); row("Created", time_str($platform->create_time)); row("Platform Name", $platform->name); row("","id>Application Versions for Platform $platform->name "); end_table(); } function show_app($app) { start_table(); row("ID", $app->id); row("Created", time_str($app->create_time)); row("Application Name", $app->name); row("","id>Application Versions for Application $app->name"); row("","id>Workunits for this Application"); end_table(); } function show_app_version($app_version,$show_xml_docs) { start_table(); row("ID", $app_version->id); row("Created", time_str($app_version->create_time)); row("Application", "appid>" . app_name_by_id($app_version->appid) . ""); row("Version num", $app_version->version_num); row("Platform", "platformid>" . platform_name_by_id($app_version->platformid) . "" ); if ($show_xml_docs) { row("XML doc", "

".htmlspecialchars($app_version->xml_doc)."
"); } row("Min_core_version", $app_version->min_core_version); row("Max_core_version", $app_version->max_core_version); row("Message", $app_version->message); row("Deprecated", $app_version->deprecated); end_table(); } function show_host($host) { start_table(); row("Created", time_str($host->create_time)); row("Total credit", $host->total_credit); row("Average credit", $host->expavg_credit); row("Average update time", time_str($host->expavg_time)); row("IP address", "$host->last_ip_addr
(same the last $host->nsame_ip_addr times)"); row("Domain name", $host->domain_name); $x = $host->timezone/3600; row("Time zone", "UTC - $x hours"); row("CPU", "$host->p_vendor $host->p_model"); row("Number of CPUs", $host->p_ncpus); row("Operating System", "$host->os_name $host->os_version"); $x = $host->m_nbytes/(1024*1024); $y = round($x, 2); row("Memory", "$y MB"); $x = $host->m_cache/1024; $y = round($x, 2); row("Cache", "$y KB"); $x = $host->m_swap/(1024*1024); $y = round($x, 2); row("Swap Space", "$y MB"); $x = $host->d_total/(1024*1024*1024); $y = round($x, 2); row("Total Disk Space", "$y GB"); $x = $host->d_free/(1024*1024*1024); $y = round($x, 2); row("Free Disk Space", "$y GB"); row("Avg network bandwidth (upstream)", "$host->n_bwup bytes/sec"); row("Avg network bandwidth (downstream)", "$host->n_bwdown bytes/sec"); row("Number of RPCs", $host->rpc_seqno); row("Last RPC", time_str($host->rpc_time)); row("% of time client on", 100*$host->on_frac." %"); row("% of time host connected", 100*$host->connected_frac." %"); row("% of time user active", 100*$host->active_frac." %"); end_table(); } function retry_state_str($s) { switch($s) { case 0: return "Default"; case 1: return "Send failed"; case 2: return "Too many errors (may have bug)"; case 3: return "Too many done (may be nondeterministic)"; } return "unknown"; } function show_workunit($wu,$show_xml_doc) { start_table(); row("Created", time_str($wu->create_time)); row("Name", $wu->name); if ($show_xml_doc) { row("XML doc", "
".htmlspecialchars($wu->xml_doc)."
"); } row("Application", "appid>" . app_name_by_id($wu->appid) . ""); row("Batch", $wu->batch); row("FP Operations", $wu->rsc_fpops); row("Integer Operations", $wu->rsc_iops); row("Memory Requirement", $wu->rsc_memory); row("Disk Requirement", $wu->rsc_disk); row("Need validate?", $wu->need_validate?"yes":"no"); row("Canonical resultid", $wu->canonical_resultid); row("Canonical credit", $wu->canonical_credit); row("Retry check time", time_str($wu->retry_check_time)); row("Retry state", retry_state_str($wu->state)); row("Delay bound", $wu->delay_bound); row("","id>Show associated results"); end_table(); echo "

"; } function res_state_string($s) { switch($s) { case 1: return "Inactive"; case 2: return "Unsent"; case 3: return "In Progress"; case 4: return "Done"; case 5: return "Timeout"; case 6: return "Error"; } return "unknown"; } function validate_state_str($s) { switch($s) { case 0: return "Initial"; case 1: return "Need check"; case 2: return "Valid"; case 3: return "Invalid"; } return "unknown"; } function show_result($result,$show_xml_docs,$show_stderr,$show_times) { start_table(); if ($show_times) { row("created", time_str($result->create_time)); row("sent", time_str($result->sent_time)); row("received", time_str($result->received_time)); } row("Name", $result->name); row("Workunit", "workunitid>" . wu_name_by_id($result->workunitid) . "" ); row("state", res_state_string($result->state)); row("Deadline", time_str($result->report_deadline)); row("Host ID", "hostid>" . host_name_by_id($result->hostid) . ""); row("Exit Status", $result->exit_status); row("CPU time", $result->cpu_time); if ($show_xml_docs) { row("XML doc in", "

".htmlspecialchars($result->xml_doc_in)."
"); row("XML doc out", "
".htmlspecialchars($result->xml_doc_out)."
"); } if ($show_stderr) { row("stderr out", "
".htmlspecialchars($result->stderr_out)."
"); } row("batch", $result->batch); row("project state", $result->project_state); row("Validate state", validate_state_str($result->validate_state)); row("claimed credit", $result->claimed_credit); row("granted credit", $result->granted_credit); end_table(); echo "

"; } function show_user($user) { start_table(); row("created", time_str($user->create_time)); row("total credit", $user->total_credit); row("recent averaged credit:", $user->expavg_credit); row("name", $user->name); row("email address", $user->email_addr); row("country", $user->country); row("postal code", $user->postal_code); row("total credit", $user->total_credit); row("average credit", $user->expavg_credit); row("last average time", time_str($user->expavg_time)); end_table(); } function team_type_string($s) { switch ($s) { case 1: return "Small Company"; case 2: return "Medium Company"; case 3: return "Large Company"; case 4: return "Club"; case 5: return "Primary School"; case 6: return "Secondary School"; case 7: return "Junior College"; case 8: return "University or Department"; case 9: return "Government Agency"; default: return "Unknown"; } } function show_team($team) { start_table(); row("ID", $team->id); row("Team Founder", "userid>" . user_name_by_id($team->userid) . ""); row("Name", $team->name); row("Name (HTML Formatted)", "

" . htmlspecialchars($team->name_html) . "
" ); row("Url", "url>" . $team->url . ""); row("Type", team_type_string($team->type)); row("Description", $team->description); row("", "id>List All Members"); end_table(); } function team_name_by_id($team_id) { $result = mysql_query("select * from team where id = $team_id"); $team = mysql_fetch_object($result); return $team->name; } function user_name_by_id($user_id) { $result = mysql_query("select * from user where id = $user_id"); $user = mysql_fetch_object($result); return $user->name; } function app_name_by_id($app_id) { $result = mysql_query("select * from app where id = $app_id"); $app = mysql_fetch_object($result); return $app->name; } function wu_name_by_id($wu_id) { $result = mysql_query("select * from workunit where id = $wu_id"); $wu = mysql_fetch_object($result); return $wu->name; } function platform_name_by_id($plat_id) { $result = mysql_query("select * from platform where id = $plat_id"); $plat = mysql_fetch_object($result); return $plat->name; } function host_name_by_id($host_id) { $result = mysql_query("select * from host where id = $host_id"); $host = mysql_fetch_object($result); if (!strlen($host->domain_name) && !strlen($host->last_ip_addr)) return "(blank)"; else return $host->domain_name . " (" . $host->last_ip_addr . ")"; } ?>