blob: c9444b2c8409235b092ccab250a15453d44edb5a [file] [log] [blame]
/** @file
A brief file description
@section license License
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef __P_SOCKS_H__
#define __P_SOCKS_H__
#include "P_EventSystem.h"
#include "I_Socks.h"
#ifdef SOCKS_WITH_TS
#include "ParentSelection.h"
#include "IPRange.h"
#endif
enum
{
//types of events for Socks auth handlers
SOCKS_AUTH_OPEN,
SOCKS_AUTH_WRITE_COMPLETE,
SOCKS_AUTH_READ_COMPLETE,
SOCKS_AUTH_FILL_WRITE_BUF
};
struct socks_conf_struct
{
int socks_needed;
int server_connect_timeout;
int socks_timeout;
unsigned char default_version;
char *user_name_n_passwd;
int user_name_n_passwd_len;
int per_server_connection_attempts;
int connection_attempts;
//the following ports are used by SocksProxy
int accept_enabled;
int accept_port;
unsigned short http_port;
#ifdef SOCKS_WITH_TS
IPRange ip_range;
#endif
#ifndef SOCKS_WITH_TS
unsigned int socks_server;
int socks_server_port;
#endif
socks_conf_struct():socks_needed(0), server_connect_timeout(0), socks_timeout(100), default_version(5),
user_name_n_passwd(NULL), user_name_n_passwd_len(0),
per_server_connection_attempts(1), connection_attempts(0), accept_enabled(0), accept_port(0), http_port(1080)
{
}
};
extern struct socks_conf_struct *g_socks_conf_stuff;
void start_SocksProxy(int port);
int loadSocksAuthInfo(int fd, socks_conf_struct * socks_stuff);
// umm.. the following typedef should take _its own_ type as one of the args
// not possible with C
// Right now just use a generic fn ptr and hide casting in an inline fn.
typedef int (*SocksAuthHandler) (int event, unsigned char *buf, void (**h_ptr) (void));
TS_INLINE int
invokeSocksAuthHandler(SocksAuthHandler & h, int arg1, unsigned char *arg2)
{
return (h) (arg1, arg2, (void (**)(void)) (&h));
}
void loadSocksConfiguration(socks_conf_struct * socks_conf_stuff);
int socks5BasicAuthHandler(int event, unsigned char *p, void (**)(void));
int socks5PasswdAuthHandler(int event, unsigned char *p, void (**)(void));
int socks5ServerAuthHandler(int event, unsigned char *p, void (**)(void));
#if defined(_IOCORE_WIN32)
class NTNetVConnection;
typedef NTNetVConnection SocksNetVC;
#else
class UnixNetVConnection;
typedef UnixNetVConnection SocksNetVC;
#endif
struct SocksEntry:public Continuation
{
MIOBuffer *buf;
IOBufferReader *reader;
SocksNetVC *netVConnection;
unsigned int ip; // ip address in the original request
int port; // port number in the original request
unsigned int server_ip;
int server_port;
int nattempts;
Action action_;
int lerrno;
Event *timeout;
unsigned char version;
bool write_done;
SocksAuthHandler auth_handler;
unsigned char socks_cmd;
#ifdef SOCKS_WITH_TS
//socks server selection:
ParentConfigParams *server_params;
HttpRequestData req_data; //We dont use any http specific fields.
ParentResult server_result;
#endif
int startEvent(int event, void *data);
int mainEvent(int event, void *data);
void findServer();
void init(ProxyMutex * m, SocksNetVC * netvc, unsigned char socks_support, unsigned char ver);
void free();
SocksEntry():Continuation(NULL), netVConnection(0),
ip(0), port(0), server_ip(0), server_port(0), nattempts(0),
lerrno(0), timeout(0), version(5), write_done(false), auth_handler(NULL), socks_cmd(NORMAL_SOCKS)
{
}
};
typedef int (SocksEntry::*SocksEntryHandler) (int, void *);
extern ClassAllocator<SocksEntry> socksAllocator;
TS_INLINE void
SocksAddrType::reset()
{
if (type != SOCKS_ATYPE_IPV4 && addr.buf) {
xfree(addr.buf);
}
addr.buf = 0;
type = SOCKS_ATYPE_NONE;
}
#endif