. // handler for output file requests from remote job submission. // See http://boinc.berkeley.edu/trac/wiki/RemoteJobs require_once("../inc/util.inc"); require_once("../inc/result.inc"); require_once("../inc/submit_util.inc"); // get a single output file // function get_output_file($instance_name, $file_num, $auth_str) { $result = BoincResult::lookup_name(BoincDb::escape_string($instance_name)); if (!$result) die("no job instance $instance_name"); $workunit = BoincWorkunit::lookup_id($result->workunitid); if (!$workunit) die("no job $result->workunitid"); $batch = BoincBatch::lookup_id($workunit->batch); if (!$batch) die("no batch $workunit->batch"); $user = BoincUser::lookup_id($batch->user_id); if (!$user) die("no user $batch->user_id"); $x = md5($user->authenticator.$result->name); if ($x != $auth_str) die("bad auth str"); $names = get_outfile_names($result); if ($file_num >= count($names)) { die("bad file num: $file_num > ".count($names)); } $name = $names[$file_num]; $fanout = parse_config(get_config(), ""); $upload_dir = parse_config(get_config(), ""); $path = dir_hier_path($name, $upload_dir, $fanout); if (!is_file($path)) die("no such file $path"); do_download($path); } // get all the output files of a batch (canonical instances only) // and make a zip of all of them // function get_batch_output_files($batch_id, $auth_str) { $batch = BoincBatch::lookup_id($batch_id); if (!$batch) die("no batch $batch_id"); $user = BoincUser::lookup_id($batch->user_id); if (!$user) die("no user $batch->user_id"); $x = md5($user->authenticator.$batch_id); if ($x != $auth_str) die("bad auth str"); $zip_basename = tempnam("/tmp", "boinc_batch_"); $zip_filename = $zip_basename.".zip"; $fanout = parse_config(get_config(), ""); $upload_dir = parse_config(get_config(), ""); $wus = BoincWorkunit::enum("batch=$batch_id"); foreach ($wus as $wu) { if (!$wu->canonical_resultid) continue; $result = BoincResult::lookup_id($wu->canonical_resultid); $names = get_outfile_names($result); foreach ($names as $name) { $path = dir_hier_path($name, $upload_dir, $fanout); if (is_file($path)) { system(" nice -9 zip -jq $zip_basename $path"); } } } do_download($zip_filename); unlink($zip_filename); } // get all the output files of a workunit (canonical instance only) // and make a zip of all of them // function get_wu_output_files($wu_id, $auth_str) { $wu = BoincWorkunit::lookup_id($wu_id); if (!$wu) die("no workunit $wu_id"); $batch = BoincBatch::lookup_id($wu->batch); if (!batch) die("no batch $wu->batch"); $user = BoincUser::lookup_id($batch->user_id); if (!$user) die("no user $batch->user_id"); $x = md5($user->authenticator.$wu_id); echo "user authenticator= $user->authenticator, wu_id=$wu_id
"; if ($x != $auth_str) die("bad auth str: x=$x, auth_str=$auth_str"); $zip_basename = tempnam("/tmp", "boinc_wu_".$wu->name."_"); $zip_filename = $zip_basename.".zip"; $fanout = parse_config(get_config(), ""); $upload_dir = parse_config(get_config(), ""); if (!$wu->canonical_resultid) die("no canonical result for wu $wu->name"); $result = BoincResult::lookup_id($wu->canonical_resultid); $names = get_outfile_names($result); foreach ($names as $name) { $path = dir_hier_path($name, $upload_dir, $fanout); if (is_file($path)) { system("nice -9 zip -jq $zip_basename $path"); } } do_download($zip_filename); unlink($zip_filename); unlink($zip_basename); } $auth_str = get_str('auth_str'); $instance_name = get_str('instance_name', true); $batch_id = get_int('batch_id' , true); $wu_id = get_int('wu_id'); if ($instance_name) { $file_num = get_int('file_num'); get_output_file($instance_name, $file_num, $auth_str); } else if ($batch_id) { get_batch_output_files($batch_id, $auth_str); } else if ($wu_id) { get_wu_output_files($wu_id, $auth_str); } else { echo "bad command\n"; } ?>