/******************************************************************************* * libretroshare/src/pqi: pqisslproxy.h * * * * libretroshare: retroshare core library * * * * Copyright 2004-2013 by Robert Fernie. * * * * This program 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. * * * * 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 Lesser General Public License for more details. * * * * You should have received a copy of the GNU Lesser General Public License * * along with this program. If not, see . * * * *******************************************************************************/ #ifndef MRK_PQI_SSL_PROXY_HEADER #define MRK_PQI_SSL_PROXY_HEADER // operating system specific network header. #include "pqi/pqinetwork.h" #include "pqi/pqiproxy.h" #include #include #include "pqi/pqissl.h" /* pqisslproxy uses SOCKS5 proxy to hidden your own address and connect to peers. * It uses the Domain Name interface of SOCKS5, as opposed to an IP address. */ /* This provides a NetBinInterface, which is * primarily inherited from pqissl. * fns declared here are different -> all others are identical. */ class pqisslproxy: public pqissl, public pqiproxyconnection { public: pqisslproxy(pqissllistener *l, PQInterface *parent, p3LinkMgr *lm); virtual ~pqisslproxy(); // NetInterface. Is the same. // BinInterface. Is the same. virtual bool connect_parameter(uint32_t type, const std::string &value); virtual bool connect_parameter(uint32_t type, uint32_t value); protected: //Initiate is the same - except it uses the Proxy Address rather than the Peer Address. // minor tweaks to setup data state. virtual int Initiate_Connection(); // The real overloading is done in Basic Connection Complete. // Instead of just checking for an open socket, we need to communicate with the SOCKS5 proxy. virtual int Basic_Connection_Complete(); }; #endif // MRK_PQI_SSL_PROXY_HEADER