2008-08-06 18:36:30 +00:00
|
|
|
// This file is part of BOINC.
|
2005-01-20 23:22:22 +00:00
|
|
|
// http://boinc.berkeley.edu
|
2008-08-06 18:36:30 +00:00
|
|
|
// Copyright (C) 2008 University of California
|
2005-01-20 23:22:22 +00:00
|
|
|
//
|
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.
|
2005-01-20 23:22:22 +00:00
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
2005-01-20 23:22:22 +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/>.
|
2005-01-20 23:22:22 +00:00
|
|
|
|
2004-10-06 19:09:37 +00:00
|
|
|
#ifndef _PROXY_INFO_
|
|
|
|
#define _PROXY_INFO_
|
|
|
|
|
2012-11-07 08:08:18 +00:00
|
|
|
struct XML_PARSER;
|
2012-08-01 21:02:54 +00:00
|
|
|
class MIOFILE;
|
2004-10-06 19:09:37 +00:00
|
|
|
|
2009-09-18 16:30:25 +00:00
|
|
|
// info on whether HTTP requests need to go through a proxy
|
|
|
|
//
|
2009-08-28 17:14:37 +00:00
|
|
|
struct PROXY_INFO {
|
2009-12-05 00:51:05 +00:00
|
|
|
bool present;
|
|
|
|
// set if rest of structure is filled in
|
|
|
|
|
|
|
|
// the following is populated if user has specified an HTTP proxy
|
2009-09-18 16:30:25 +00:00
|
|
|
//
|
2004-10-06 19:09:37 +00:00
|
|
|
bool use_http_proxy;
|
2009-07-29 23:50:00 +00:00
|
|
|
bool use_http_auth;
|
2009-08-28 17:14:37 +00:00
|
|
|
char http_server_name[256];
|
|
|
|
int http_server_port;
|
|
|
|
char http_user_name[256];
|
|
|
|
char http_user_passwd[256];
|
2009-07-29 23:50:00 +00:00
|
|
|
|
2009-11-05 18:02:51 +00:00
|
|
|
// the following is populated if user has specified a SOCKS proxy.
|
|
|
|
// Only SOCKS 5 is supported.
|
2009-09-18 16:30:25 +00:00
|
|
|
//
|
2009-07-29 23:50:00 +00:00
|
|
|
bool use_socks_proxy;
|
2009-08-28 17:14:37 +00:00
|
|
|
char socks_server_name[256];
|
|
|
|
int socks_server_port;
|
|
|
|
char socks5_user_name[256];
|
|
|
|
char socks5_user_passwd[256];
|
2009-07-29 23:50:00 +00:00
|
|
|
|
2009-09-18 16:30:25 +00:00
|
|
|
// a list of hosts for which we should NOT go through a proxy
|
|
|
|
// (e.g. a company PC attached to both local and remote projects)
|
|
|
|
//
|
2009-08-28 17:14:37 +00:00
|
|
|
char noproxy_hosts[256];
|
2009-07-29 23:50:00 +00:00
|
|
|
|
2009-09-18 16:30:25 +00:00
|
|
|
// On Windows, if neither HTTP nor SOCKS proxy is specified,
|
|
|
|
// we try the "autodetect" mechanism.
|
|
|
|
// If it gets anything, the info is filled in below
|
|
|
|
//
|
2010-08-03 16:57:18 +00:00
|
|
|
bool autodetect_proxy_supported;
|
|
|
|
// if true, some mechinism for detecting proxy servers is
|
|
|
|
// supported by the client.
|
2009-09-18 16:30:25 +00:00
|
|
|
int autodetect_protocol;
|
|
|
|
// URL_PROTOCOL_SOCKS, URL_PROTOCOL_HTTP, or URL_PROTOCOL_HTTPS
|
2009-08-28 17:14:37 +00:00
|
|
|
char autodetect_server_name[256];
|
2009-09-18 16:30:25 +00:00
|
|
|
int autodetect_port;
|
2009-08-28 21:25:13 +00:00
|
|
|
bool need_autodetect_proxy_settings;
|
|
|
|
// if true, we need to detect proxy settings.
|
|
|
|
// set to true if ref web site lookup fails
|
|
|
|
bool have_autodetect_proxy_settings;
|
2009-09-18 16:30:25 +00:00
|
|
|
// whether above fields are defined
|
2009-07-29 23:50:00 +00:00
|
|
|
|
2011-08-09 21:44:14 +00:00
|
|
|
int parse(XML_PARSER&);
|
|
|
|
int parse_config(XML_PARSER&);
|
2004-10-06 19:09:37 +00:00
|
|
|
int write(MIOFILE&);
|
|
|
|
void clear();
|
|
|
|
};
|
|
|
|
|
2004-10-06 20:48:03 +00:00
|
|
|
#endif
|