/* This file is part of the KDE libraries
Copyright (C) 2001 George Staikos
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License version 2 as published by the Free Software Foundation.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#ifndef _KSOCKS_H_
#define _KSOCKS_H_
#include
#include
#include
#include
#include
class KSocksTable;
class KSocksPrivate;
class KLibrary;
class KConfigBase;
struct sockaddr;
/**
* This class provides you with an interface to a
* SOCKS Proxy server. A SOCKS server
* is able to provide full internet access behind a firewall.
* KSocks is a singleton, there can noly be one instance at any
* given time. To obtain a reference to that instance, use
* @ref self().
*
* @short Access to a SOCKS Proxy.
*/
class KSocks {
friend class KStaticDeleter;
public:
/**
* Return an instance of class KSocks *.
* You cannot delete this object. It is a singleton class.
* @return the KSock instance
*/
static KSocks *self();
/**
* Checks whether KSocks has been started (ie someone called self())
* @return true if activated
*/
static bool activated();
/**
* Disable the use of SOCKS immediately
*/
void disableSocks();
/**
* Enable the use of SOCKS immediately if hasSocks() is true.
*/
void enableSocks();
/**
* Checks whether SOCKS is currently being used.
* @return true if SOCKS is currently being used.
*/
bool usingSocks();
/**
* Checks whether SOCKS is available for use.
* @return true if SOCKS is available for use.
*/
bool hasSocks();
/*
** REIMPLEMENTATIONS OF LIBC SOCKET FUNCTIONS
**/
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int connect (int sockfd, const sockaddr *serv_addr,
ksocklen_t addrlen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
signed long int read (int fd, void *buf, unsigned long int count);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
signed long int write (int fd, const void *buf, unsigned long int count);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int recvfrom (int s, void *buf, unsigned long int len, int flags,
sockaddr *from, ksocklen_t *fromlen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int sendto (int s, const void *msg, unsigned long int len, int flags,
const sockaddr *to, ksocklen_t tolen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int recv (int s, void *buf, unsigned long int len, int flags);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int send (int s, const void *msg, unsigned long int len, int flags);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int getsockname (int s, sockaddr *name, ksocklen_t *namelen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int getpeername (int s, sockaddr *name, ksocklen_t *namelen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int accept (int s, sockaddr *addr, ksocklen_t *addrlen);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int select (int n, fd_set *readfds, fd_set *writefds,
fd_set *exceptfds, struct timeval *timeout);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int listen (int s, int backlog);
/**
* This is the re-implementation of libc's function of the same
* name. Read the appropriate man page.
*/
int bind (int sockfd, sockaddr *my_addr,
ksocklen_t addrlen);
/**
* If you're using this, you're probably doing something wrong.
* Please don't use it.
* @internal
*/
void die();
/**
* Set this before the first call to KSocks::self() and it will fail
* to initialize SOCKS.
*/
static void disable();
/**
* Set this before the first call to KSocks::self() and it will use
* @p config to read its configuration from.
*/
static void setConfig(KConfigBase *config);
private:
KSocks(KConfigBase *config);
~KSocks();
void stopSocks();
static KSocks *_me;
static bool _disabled;
QStringList _libNames;
QStringList _libPaths;
bool _useSocks, _hasSocks;
KLibrary* _socksLib;
KSocksTable *_st;
KSocksPrivate *d;
};
#endif
Generated by: caleb on tcdevel on Tue Jan 28 12:54:04 2003, using kdoc $. |