// 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 . #ifndef _ACCT_MGR_ #define _ACCT_MGR_ #include #include #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; 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; 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 accounts; double repeat_sec; char* global_prefs_xml; char host_venue[256]; bool got_rss_feeds; std::vectorrss_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