"); if(!mysql_select_db($db_name)) { echo "Unable to select database - please try again later"; exit(); } return 0; } 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 result_server_state_select() { echo " \n"; } function result_outcome_select() { echo " \n"; } function result_client_state_select() { echo " \n"; } function result_sort_select() { echo " "; } function table_title($table) { switch($table) { case "platform": return "Platforms"; case "app": return "Applications"; case "app_version": return "Application Versions"; case "host": return "Hosts"; case "workunit": return "Workunits"; case "result": return "Results"; case "team": return "Teams"; case "user": return "Users"; default: return "????"; } } function show_platform($platform) { start_table(); row("ID", $platform->id); row("Created", time_str($platform->create_time)); row("Name", $platform->name); row("User friendly name", $platform->user_friendly_name); row("","id>App versions for this platform"); end_table(); } function show_app($app) { start_table(); row("ID", $app->id); row("Created", time_str($app->create_time)); row("Name", $app->name); row("","id>App Versions for this application"); row("","id>Workunits for this application"); end_table(); } function show_app_version($app_version, $hide_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 (!$hide_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 host_short_header() { echo "
".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", "canonical_resultid>".$wu->canonical_resultid.""); row("Canonical credit", $wu->canonical_credit); row("Timeout check time", time_str($wu->timeout_check_time)); row("Delay bound", $wu->delay_bound); row("Error mask", wu_error_mask_str($wu->error_mask)); row("File delete state", file_delete_state_str($wu->file_delete_state)); row("Assimilation state", assimilate_state_str($wu->assimilate_state)); row("","id>Show associated results"); row("","Grep logs"); end_table(); echo "
"; } function result_server_state_string($s) { switch($s) { case 1: return "Inactive"; case 2: return "Unsent"; case 4: return "In Progress"; case 5: return "Over"; } return "Unknown"; } function result_outcome_string($s) { switch($s) { case 1: return "Success"; case 2: return "Couldn't send"; case 3: return "Client error"; case 4: return "No reply"; case 5: return "Didn't need"; } return "Unknown"; } function result_client_state_string($s) { switch($s) { case 0: return "New"; case 1: return "Downloading"; case 2: return "Downloaded"; case 3: return "Computing"; case 4: return "Uploading"; case 5: return "Done"; } return "Unknown"; } function validate_state_str($s) { switch($s) { case 0: return "Initial"; case 1: return "Valid"; case 2: return "Invalid"; } return "Unknown"; } function client_version_string($client_version_num) { if (!$client_version_num) { return '---'; } else { return sprintf("%.2f", $client_version_num/100); } } function outcome_color($s) { switch($s) { case 1: return '33cc33'; // "Success" case 3: return 'ff3333'; // "Client error" } return 'white'; } function show_result($result, $hide_xml_docs, $hide_stderr, $hide_times) { start_table(); if (!$hide_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("Server state", result_server_state_string($result->server_state)); row("Outcome", result_outcome_string($result->outcome)); row("Client state", result_client_state_string($result->client_state)); row("Host ID", "hostid>" . host_name_by_id($result->hostid) . ""); row("Report deadline", time_str($result->report_deadline)); row("CPU time", $result->cpu_time); if (!$hide_xml_docs) { row("XML doc in", "
".htmlspecialchars($result->xml_doc_in).""); row("XML doc out", "
".htmlspecialchars($result->xml_doc_out).""); } if (!$hide_stderr) { row("stderr out", "
".htmlspecialchars($result->stderr_out).""); } row("Batch", $result->batch); row("File delete state", file_delete_state_str($result->file_delete_state)); row("Validate state", validate_state_str($result->validate_state)); row("claimed credit", $result->claimed_credit); row("Granted credit", $result->granted_credit); row("Client version", client_version_string($result->client_version_num)); row("","Grep logs"); end_table(); echo "
"; } function result_short_header() { echo "
" . 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($hostid) { $result = mysql_query("select * from host where id = $hostid"); $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 . ")"; } ?>