2003-07-01 20:37:09 +00:00
|
|
|
// The contents of this file are subject to the BOINC Public License
|
2002-04-30 22:22:54 +00:00
|
|
|
// Version 1.0 (the "License"); you may not use this file except in
|
|
|
|
// compliance with the License. You may obtain a copy of the License at
|
2003-07-01 20:37:09 +00:00
|
|
|
// http://boinc.berkeley.edu/license_1.0.txt
|
2003-08-15 22:39:56 +00:00
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
// Software distributed under the License is distributed on an "AS IS"
|
|
|
|
// basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing rights and limitations
|
2003-08-15 22:39:56 +00:00
|
|
|
// under the License.
|
|
|
|
//
|
|
|
|
// The Original Code is the Berkeley Open Infrastructure for Network Computing.
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
// The Initial Developer of the Original Code is the SETI@home project.
|
|
|
|
// Portions created by the SETI@home project are Copyright (C) 2002
|
2003-08-15 22:39:56 +00:00
|
|
|
// University of California at Berkeley. All Rights Reserved.
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
// Contributor(s):
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef _SERVER_TYPES_
|
|
|
|
#define _SERVER_TYPES_
|
|
|
|
|
2004-07-13 13:54:09 +00:00
|
|
|
#include <cstdio>
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <vector>
|
|
|
|
|
2003-04-07 19:06:00 +00:00
|
|
|
#include "boinc_db.h"
|
2003-06-11 18:38:08 +00:00
|
|
|
#include "result_state.h"
|
2004-05-03 02:18:35 +00:00
|
|
|
#include "md5_file.h"
|
2002-12-09 23:06:17 +00:00
|
|
|
|
2004-09-10 00:41:48 +00:00
|
|
|
// summary of a client's request for work
|
|
|
|
//
|
|
|
|
struct WORK_REQ {
|
|
|
|
bool infeasible_only;
|
|
|
|
double seconds_to_fill;
|
|
|
|
double disk_available;
|
|
|
|
int nresults;
|
|
|
|
int core_client_version;
|
|
|
|
|
|
|
|
// the following flags are set whenever a result is infeasible;
|
|
|
|
// used to construct explanatory message to user
|
|
|
|
//
|
|
|
|
bool insufficient_disk;
|
|
|
|
bool insufficient_mem;
|
|
|
|
bool insufficient_speed;
|
|
|
|
bool no_app_version;
|
|
|
|
bool homogeneous_redundancy_reject;
|
|
|
|
bool outdated_core;
|
|
|
|
bool daily_result_quota_exceeded;
|
|
|
|
|
|
|
|
bool work_needed(struct SCHEDULER_REPLY&);
|
|
|
|
void update_for_result(double seconds_filled);
|
|
|
|
};
|
|
|
|
|
|
|
|
// a description of a sticky file on host.
|
|
|
|
//
|
|
|
|
struct FILE_INFO {
|
|
|
|
char name[256];
|
2004-09-10 21:02:11 +00:00
|
|
|
|
|
|
|
int parse(FILE*);
|
2004-09-10 00:41:48 +00:00
|
|
|
};
|
|
|
|
|
2004-06-24 21:00:13 +00:00
|
|
|
struct MSG_FROM_HOST_DESC {
|
2004-07-06 04:10:51 +00:00
|
|
|
char variety[256];
|
2004-09-10 00:41:48 +00:00
|
|
|
std::string msg_text;
|
2004-01-08 00:27:59 +00:00
|
|
|
int parse(FILE*);
|
|
|
|
};
|
|
|
|
|
2004-01-26 19:29:39 +00:00
|
|
|
// an app version from an anonymous-platform client
|
|
|
|
//
|
|
|
|
struct CLIENT_APP_VERSION {
|
|
|
|
char app_name[256];
|
|
|
|
int version_num;
|
|
|
|
|
|
|
|
int parse(FILE*);
|
|
|
|
};
|
|
|
|
|
2004-03-23 03:59:32 +00:00
|
|
|
// subset of global prefs used by scheduler
|
|
|
|
//
|
|
|
|
struct GLOBAL_PREFS {
|
|
|
|
double disk_max_used_gb;
|
|
|
|
double disk_max_used_pct;
|
|
|
|
double disk_min_free_gb;
|
|
|
|
|
2004-03-31 06:07:17 +00:00
|
|
|
void parse(char* buf, char* venue);
|
2004-03-23 03:59:32 +00:00
|
|
|
};
|
|
|
|
|
2004-09-13 18:05:54 +00:00
|
|
|
struct GUI_URLS {
|
|
|
|
char* text;
|
|
|
|
void init();
|
2004-09-27 19:44:40 +00:00
|
|
|
void get_gui_urls(USER& user, HOST& host, TEAM& team, char*);
|
2004-09-13 18:05:54 +00:00
|
|
|
};
|
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
struct SCHEDULER_REQUEST {
|
|
|
|
char authenticator[256];
|
|
|
|
char platform_name[256];
|
2004-04-30 18:26:20 +00:00
|
|
|
char cross_project_id[256];
|
2002-04-30 22:22:54 +00:00
|
|
|
int hostid; // zero if first RPC
|
2002-12-02 04:29:40 +00:00
|
|
|
int core_client_major_version;
|
|
|
|
int core_client_minor_version;
|
2002-04-30 22:22:54 +00:00
|
|
|
int rpc_seqno;
|
2004-12-06 22:41:19 +00:00
|
|
|
double work_req_seconds;
|
2004-07-06 21:51:49 +00:00
|
|
|
double resource_share_fraction;
|
2004-07-22 18:56:54 +00:00
|
|
|
double estimated_delay;
|
2003-12-07 18:58:08 +00:00
|
|
|
char global_prefs_xml[LARGE_BLOB_SIZE];
|
2004-05-13 18:18:22 +00:00
|
|
|
char code_sign_key[4096];
|
2004-08-14 00:37:38 +00:00
|
|
|
|
|
|
|
// ROMW: Added these back in since we have 3.x clients who still want
|
|
|
|
// want to send us the older style for determining disk usage.
|
|
|
|
// TODO: Remove the two lines below when the 4.x way of doing things
|
|
|
|
// is completely implemented.
|
|
|
|
double total_disk_usage;
|
|
|
|
double project_disk_usage;
|
|
|
|
|
2004-08-16 11:31:59 +00:00
|
|
|
#if 0
|
2004-08-05 22:14:23 +00:00
|
|
|
double project_disk_free;
|
|
|
|
double potentially_free_offender;
|
|
|
|
double potentially_free_self;
|
2004-08-16 11:31:59 +00:00
|
|
|
#endif
|
2004-08-14 00:37:38 +00:00
|
|
|
|
2004-01-26 19:29:39 +00:00
|
|
|
bool anonymous_platform;
|
2004-09-10 00:41:48 +00:00
|
|
|
std::vector<CLIENT_APP_VERSION> client_app_versions;
|
2004-03-23 03:59:32 +00:00
|
|
|
GLOBAL_PREFS global_prefs;
|
2004-05-03 02:18:35 +00:00
|
|
|
char global_prefs_source_email_hash[MD5_LEN];
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2004-05-13 04:48:19 +00:00
|
|
|
HOST host; // request message is parsed into here.
|
|
|
|
// does NOT contain the full host record.
|
2004-09-10 00:41:48 +00:00
|
|
|
std::vector<RESULT> results;
|
|
|
|
std::vector<MSG_FROM_HOST_DESC> msgs_from_host;
|
|
|
|
std::vector<FILE_INFO> file_infos; // sticky files reported by host
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
SCHEDULER_REQUEST();
|
|
|
|
~SCHEDULER_REQUEST();
|
|
|
|
int parse(FILE*);
|
2004-01-26 19:29:39 +00:00
|
|
|
bool has_version(APP& app);
|
2002-04-30 22:22:54 +00:00
|
|
|
};
|
|
|
|
|
2002-09-22 23:27:14 +00:00
|
|
|
// NOTE: if any field requires initialization,
|
|
|
|
// you must do it in the constructor. Nothing is zeroed by default.
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
struct SCHEDULER_REPLY {
|
|
|
|
int request_delay; // don't request again until this time elapses
|
2002-05-17 22:33:57 +00:00
|
|
|
char message[1024];
|
|
|
|
char message_priority[256];
|
2004-10-01 22:00:39 +00:00
|
|
|
int hostid;
|
|
|
|
// nonzero only if a new host record was created.
|
|
|
|
// this tells client to reset rpc_seqno
|
2002-09-27 20:36:03 +00:00
|
|
|
bool send_global_prefs; // whether to send global preferences
|
2002-12-02 04:29:40 +00:00
|
|
|
bool nucleus_only; // send only message
|
2003-08-15 22:39:56 +00:00
|
|
|
bool probable_user_browser;
|
2002-05-29 23:25:21 +00:00
|
|
|
USER user;
|
2004-05-03 02:18:35 +00:00
|
|
|
char email_hash[MD5_LEN];
|
2004-05-13 04:48:19 +00:00
|
|
|
HOST host; // after validation, contains full host rec
|
2003-02-24 21:31:36 +00:00
|
|
|
TEAM team;
|
2004-09-10 00:41:48 +00:00
|
|
|
std::vector<APP> apps;
|
|
|
|
std::vector<APP_VERSION> app_versions;
|
|
|
|
std::vector<WORKUNIT>wus;
|
|
|
|
std::vector<RESULT>results;
|
|
|
|
std::vector<RESULT>result_acks;
|
|
|
|
std::vector<MSG_TO_HOST>msgs_to_host;
|
|
|
|
std::vector<FILE_INFO>file_deletes;
|
2004-05-13 18:18:22 +00:00
|
|
|
char code_sign_key[4096];
|
|
|
|
char code_sign_key_signature[4096];
|
2004-06-24 21:00:13 +00:00
|
|
|
bool send_msg_ack;
|
2004-05-03 02:18:35 +00:00
|
|
|
bool update_user_record;
|
2004-08-05 22:14:23 +00:00
|
|
|
bool deletion_policy_priority;
|
|
|
|
bool deletion_policy_expire;
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
SCHEDULER_REPLY();
|
|
|
|
~SCHEDULER_REPLY();
|
|
|
|
int write(FILE*);
|
|
|
|
void insert_app_unique(APP&);
|
|
|
|
void insert_app_version_unique(APP_VERSION&);
|
|
|
|
void insert_workunit_unique(WORKUNIT&);
|
|
|
|
void insert_result(RESULT&);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|