boinc/client/acct_mgr.h

143 lines
4.1 KiB
C
Raw Normal View History

// This file is part of BOINC.
// http://boinc.berkeley.edu
// Copyright (C) 2008 University of California
//
// 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.
//
// BOINC is distributed in the hope that it will be useful,
// 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.
//
// You should have received a copy of the GNU Lesser General Public License
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
#ifndef _ACCT_MGR_
#define _ACCT_MGR_
#include <string>
#include <vector>
#include "miofile.h"
#include "parse.h"
#include "gui_http.h"
#include "client_types.h"
// represents info stored in acct_mgr_url.xml and acct_mgr_login.xml
struct ACCT_MGR_INFO : PROJ_AM {
// the following used to be std::string but there
// were mysterious bugs where setting it to "" didn't work
//
char login_name[256];
char password_hash[256];
// md5 of password.lowercase(login_name)
char opaque[256];
// whatever the AMS sends us
char signing_key[MAX_KEY_LEN];
char previous_host_cpid[64];
// the host CPID sent in last RPC
double next_rpc_time;
int nfailures;
bool send_gui_rpc_info;
// whether to include GUI RPC port and password hash
// in AM RPCs (used for "farm management")
bool cookie_required;
// use of cookies are required during initial signup
// NOTE: This bool gets dropped after the client has
// successfully attached to an account manager
char cookie_failure_url[256];
// if the cookies could not be detected, provide a
// link to a website to go to so the user can find
// what login name and password they have been assigned
// NOTE: This bool gets dropped after the client has
// successfully attached to an account manager
bool password_error;
inline bool using_am() {
if (!strlen(master_url)) return false;
if (!strlen(login_name)) return false;
if (!strlen(password_hash)) return false;
return true;
}
ACCT_MGR_INFO();
int parse_login_file(FILE*);
int write_info();
int init();
void clear();
bool poll();
};
// stuff after here related to RPCs to account managers
struct OPTIONAL_BOOL {
bool present;
bool value;
inline void init() {present=false;}
inline void set(bool v) {value=v; present=true;}
};
struct OPTIONAL_DOUBLE {
bool present;
double value;
inline void init() {present=false;}
inline void set(double v) {value=v; present=true;}
};
// an account entry in reply message
//
struct AM_ACCOUNT {
std::string url;
std::string authenticator;
char url_signature[MAX_SIGNATURE_LEN];
bool detach;
bool update;
- client: generalize the GPU framework so that - new GPU types can be added easily - users can specify GPUs in cc_config.xml, referred to by app_info.xml, and they will be scheduled by BOINC and passed --device N options Note: the parsing of cc_config.xml is not done yet. - RPC protocols (account manager and scheduler) can now specify GPU types in separate elements rather than embedding them in tag names e.g. <no_rsc>NVIDIA</no_rsc> rather than <no_cuda/> - client: in account manager replies, parse elements of the form <no_rsc>NAME</no_rsc> indicating the GPUs of type NAME should not be used. This allows account managers to control GPU types not hardwired into the client. Note: <no_cuda/> and <no_ati/> will continue to be supported. - scheduler RPC reply: add <no_rsc_apps>NAME</no_rsc_apps> (NAME = GPU name) to indicate that the project has no jobs for the indicated GPU type. <no_cuda_apps> etc. are still supported - client/lib: remove set_debts() GUI RPC - client/scheduler RPC remove <cuda_backoff> etc. (superceded by no_app) Exception: <ip_result> elements in sched request still have <ncudas> and <natis>. Fix this later. Implementation notes: - client/lib: change "CUDA" to "NVIDIA" in type/variable names, and in XML Continue to recognize "CUDA" for compatibility - host_info.coprocs no longer used within the client; use a global var (COPROCS coprocs) instead. COPROCS now has an array of COPROCs; GPUs types are identified by the array index. Index zero means CPU. - a bunch of other resource-specific structs (like RSC_WORK_FETCH) are now stored in arrays, with same indices as COPROCS (i.e. index 0 is CPU) - COPROCS still has COPROC_NVIDIA and COPROC_ATI structs to hold vendor-specific info - APP_VERSION now has a struct GPU_USAGE to describe its GPU usage svn path=/trunk/boinc/; revision=23253
2011-03-25 03:44:09 +00:00
bool no_rsc[MAX_RSC];
// instructions from AM not to use various resources
OPTIONAL_BOOL dont_request_more_work;
OPTIONAL_BOOL detach_when_done;
OPTIONAL_DOUBLE resource_share;
OPTIONAL_BOOL suspend;
OPTIONAL_BOOL abort_not_started;
- client: generalize the GPU framework so that - new GPU types can be added easily - users can specify GPUs in cc_config.xml, referred to by app_info.xml, and they will be scheduled by BOINC and passed --device N options Note: the parsing of cc_config.xml is not done yet. - RPC protocols (account manager and scheduler) can now specify GPU types in separate elements rather than embedding them in tag names e.g. <no_rsc>NVIDIA</no_rsc> rather than <no_cuda/> - client: in account manager replies, parse elements of the form <no_rsc>NAME</no_rsc> indicating the GPUs of type NAME should not be used. This allows account managers to control GPU types not hardwired into the client. Note: <no_cuda/> and <no_ati/> will continue to be supported. - scheduler RPC reply: add <no_rsc_apps>NAME</no_rsc_apps> (NAME = GPU name) to indicate that the project has no jobs for the indicated GPU type. <no_cuda_apps> etc. are still supported - client/lib: remove set_debts() GUI RPC - client/scheduler RPC remove <cuda_backoff> etc. (superceded by no_app) Exception: <ip_result> elements in sched request still have <ncudas> and <natis>. Fix this later. Implementation notes: - client/lib: change "CUDA" to "NVIDIA" in type/variable names, and in XML Continue to recognize "CUDA" for compatibility - host_info.coprocs no longer used within the client; use a global var (COPROCS coprocs) instead. COPROCS now has an array of COPROCs; GPUs types are identified by the array index. Index zero means CPU. - a bunch of other resource-specific structs (like RSC_WORK_FETCH) are now stored in arrays, with same indices as COPROCS (i.e. index 0 is CPU) - COPROCS still has COPROC_NVIDIA and COPROC_ATI structs to hold vendor-specific info - APP_VERSION now has a struct GPU_USAGE to describe its GPU usage svn path=/trunk/boinc/; revision=23253
2011-03-25 03:44:09 +00:00
void handle_no_rsc(const char*, bool);
int parse(XML_PARSER&);
AM_ACCOUNT() {}
~AM_ACCOUNT() {}
};
struct ACCT_MGR_OP: public GUI_HTTP_OP {
bool via_gui;
int error_num;
ACCT_MGR_INFO ami;
// a temporary copy while doing RPC.
// CLIENT_STATE::acct_mgr_info is authoratative
std::string error_str;
std::vector<AM_ACCOUNT> accounts;
double repeat_sec;
char* global_prefs_xml;
char host_venue[256];
bool got_rss_feeds;
std::vector<RSS_FEED>rss_feeds;
int do_rpc(
std::string url, std::string name, std::string password,
bool via_gui
);
int parse(FILE*);
virtual void handle_reply(int http_op_retval);
ACCT_MGR_OP(GUI_HTTP* p) {
gui_http = p;
global_prefs_xml = 0;
error_num = BOINC_SUCCESS;
}
virtual ~ACCT_MGR_OP(){}
};
#endif