2008-08-06 18:36:30 +00:00
|
|
|
// This file is part of BOINC.
|
2008-01-14 17:17:44 +00:00
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
2008-01-14 17:17:44 +00:00
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
2008-01-14 17:17:44 +00:00
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU Lesser General Public License for more details.
|
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2008-01-14 17:17:44 +00:00
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
|
|
|
|
#include "filesys.h"
|
|
|
|
#include "parse.h"
|
|
|
|
|
|
|
|
#include "sched_msgs.h"
|
|
|
|
|
|
|
|
#include "time_stats_log.h"
|
|
|
|
|
|
|
|
static char* stats_buf = 0;
|
|
|
|
|
|
|
|
// Got a <time_stats_log> flag in scheduler request.
|
|
|
|
// Copy the contents to a malloced buffer;
|
|
|
|
// don't write them to disk yet, since we haven't authenticated the host
|
|
|
|
//
|
|
|
|
|
|
|
|
void handle_time_stats_log(FILE* fin) {
|
|
|
|
dup_element_contents(fin, "</time_stats_log>", &stats_buf);
|
|
|
|
}
|
|
|
|
|
|
|
|
// The host has been authenticated, so write the stats.
|
|
|
|
// Use a directory hierarchy since there may be many hosts
|
|
|
|
//
|
|
|
|
void write_time_stats_log(SCHEDULER_REPLY& reply) {
|
|
|
|
char dirname[256], filename[256];
|
|
|
|
|
|
|
|
int hostid = reply.host.id;
|
|
|
|
int dirnum = hostid % 1000;
|
|
|
|
sprintf(dirname, "../time_stats_log/%d", dirnum);
|
|
|
|
if (!is_dir(dirname)) {
|
|
|
|
int retval = boinc_mkdir(dirname);
|
|
|
|
if (retval) {
|
2008-02-21 21:00:58 +00:00
|
|
|
log_messages.printf(MSG_CRITICAL,
|
2008-01-14 17:17:44 +00:00
|
|
|
"Can't make time stats log dir %s: %d\n", dirname, retval
|
|
|
|
);
|
|
|
|
perror("mkdir");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
sprintf(filename, "../time_stats_log/%d/%d", dirnum, hostid);
|
2008-09-09 19:10:42 +00:00
|
|
|
#ifndef _USING_FCGI_
|
2008-01-14 17:17:44 +00:00
|
|
|
FILE* f = fopen(filename, "w");
|
2008-09-09 19:10:42 +00:00
|
|
|
#else
|
|
|
|
FCGI_FILE *f = FCGI::fopen(filename, "w");
|
|
|
|
#endif
|
2008-01-14 17:17:44 +00:00
|
|
|
if (!f) {
|
2008-02-21 21:00:58 +00:00
|
|
|
log_messages.printf(MSG_CRITICAL,
|
2008-01-14 17:17:44 +00:00
|
|
|
"Can't create time stats file %s\n", filename
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
fputs(stats_buf, f);
|
|
|
|
fclose(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool have_time_stats_log(SCHEDULER_REPLY& reply) {
|
|
|
|
char filename[256];
|
|
|
|
|
|
|
|
int hostid = reply.host.id;
|
|
|
|
int dirnum = hostid % 1000;
|
|
|
|
sprintf(filename, "../time_stats_log/%d/%d", dirnum, hostid);
|
|
|
|
return is_file(filename);
|
|
|
|
}
|