boinc/client/acct_mgr.h

160 lines
4.5 KiB
C++

// 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 no_project_notices;
// if set, don't show notices from projects
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
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;
}
inline bool get_no_project_notices() {
if (!using_am()) return false;
return no_project_notices;
}
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() {
strcpy(url_signature, "");
detach = false;
update = false;
dont_request_more_work.init();
detach_when_done.init();
resource_share.init();
suspend.init();
abort_not_started.init();
}
~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;
via_gui = false;
error_num = BOINC_SUCCESS;
repeat_sec = 60.0;
global_prefs_xml = 0;
strcpy(host_venue, "");
got_rss_feeds = false;
}
virtual ~ACCT_MGR_OP(){}
};
#endif