/* Copyright (C) 2007-2008 The Android Open Source Project ** ** This software is licensed under the terms of the GNU General Public ** License version 2, as published by the Free Software Foundation, and ** may be copied, distributed, and modified under those terms. ** ** This program 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 General Public License for more details. */ #ifndef _PROXY_COMMON_H_ #define _PROXY_COMMON_H_ #include "android/sockets.h" #ifdef _WIN32 #include <winsock2.h> #else #include <sys/select.h> #endif /* types and definitions used by all proxy connections */ typedef enum { PROXY_EVENT_NONE, PROXY_EVENT_CONNECTED, PROXY_EVENT_CONNECTION_REFUSED, PROXY_EVENT_SERVER_ERROR } ProxyEvent; /* event can't be NONE when this callback is called */ typedef void (*ProxyEventFunc)( void* opaque, int fd, ProxyEvent event ); extern void proxy_set_verbose(int mode); typedef enum { PROXY_OPTION_AUTH_USERNAME = 1, PROXY_OPTION_AUTH_PASSWORD, PROXY_OPTION_HTTP_NOCACHE = 100, PROXY_OPTION_HTTP_KEEPALIVE, PROXY_OPTION_HTTP_USER_AGENT, PROXY_OPTION_MAX } ProxyOptionType; typedef struct { ProxyOptionType type; const char* string; int string_len; } ProxyOption; /* add a new proxified socket connection to the manager's list. the event function * will be called when the connection is established or refused. * * only IPv4 is supported at the moment, since our slirp code cannot handle IPv6 * * returns 0 on success, or -1 if there is no proxy service for this type of connection */ extern int proxy_manager_add( SockAddress* address, SocketType sock_type, ProxyEventFunc ev_func, void* ev_opaque ); /* remove an on-going proxified socket connection from the manager's list. * this is only necessary when the socket connection must be canceled before * the connection accept/refusal occured */ extern void proxy_manager_del( void* ev_opaque ); /* this function is called to update the select file descriptor sets * with those of the proxified connection sockets that are currently managed */ extern void proxy_manager_select_fill( int *pcount, fd_set* read_fds, fd_set* write_fds, fd_set* err_fds); /* this function is called to act on proxified connection sockets when network events arrive */ extern void proxy_manager_poll( fd_set* read_fds, fd_set* write_fds, fd_set* err_fds ); /* this function checks that one can connect to a given proxy. It will simply try to connect() * to it, for a specified timeout, in milliseconds, then close the connection. * * returns 0 in case of success, and -1 in case of error. errno will be set to ETIMEDOUT in * case of timeout, or ECONNREFUSED if the connection is refused. */ extern int proxy_check_connection( const char* proxyname, int proxyname_len, int proxyport, int timeout_ms ); #endif /* END */