mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-28 00:07:09 -05:00
79998dd70c
* new classe p3zcNatAssist * moved some common ZeroConf functions / definitions around. * moved virtual tick() to parent class: pqiNetAssist * added zcNetAssist section to makefiles. (active for OSX build) * setup switch between p3zcNatAssist & upnphandler in rsinit.cc NOTE: Still to test network restart, etc, and correct exchange of external Ip Address. git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@4800 b45a01b8-16f6-495d-af2f-9b41ad6348cc
169 lines
4.5 KiB
C++
169 lines
4.5 KiB
C++
/*
|
|
* libretroshare/src/pqi: pqiassist.h
|
|
*
|
|
* 3P/PQI network interface for RetroShare.
|
|
*
|
|
* Copyright 2004-2007 by Robert Fernie.
|
|
*
|
|
* 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; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
* USA.
|
|
*
|
|
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
|
*
|
|
*/
|
|
|
|
|
|
#ifndef MRK_PQI_ASSIST_H
|
|
#define MRK_PQI_ASSIST_H
|
|
|
|
#include <string>
|
|
#include <map>
|
|
#include "pqi/pqinetwork.h"
|
|
#include "pqi/pqimonitor.h"
|
|
|
|
/**********
|
|
* This header file provides two interfaces for assisting
|
|
* the connections to friends.
|
|
*
|
|
* pqiNetAssistFirewall - which will provides interfaces
|
|
* to functionality like upnp and apple's equivalent.
|
|
*
|
|
* pqiNetAssistConnect - which will provides interfaces
|
|
* to other networks (DHT) etc that can provide information.
|
|
* These classes would be expected to use the pqiMonitor
|
|
* callback system to notify the connectionMgr.
|
|
*
|
|
***/
|
|
|
|
class pqiNetAssist
|
|
{
|
|
public:
|
|
|
|
virtual ~pqiNetAssist() { return; }
|
|
|
|
/* External Interface */
|
|
virtual void enable(bool on) = 0;
|
|
virtual void shutdown() = 0; /* blocking call */
|
|
virtual void restart() = 0;
|
|
|
|
virtual bool getEnabled() = 0;
|
|
virtual bool getActive() = 0;
|
|
|
|
virtual int tick() { return 0; } /* for internal accounting */
|
|
|
|
};
|
|
|
|
class pqiNetAssistFirewall: public pqiNetAssist
|
|
{
|
|
public:
|
|
|
|
virtual ~pqiNetAssistFirewall() { return; }
|
|
|
|
/* the address that the listening port is on */
|
|
virtual void setInternalPort(unsigned short iport_in) = 0;
|
|
virtual void setExternalPort(unsigned short eport_in) = 0;
|
|
|
|
/* as determined by uPnP */
|
|
virtual bool getInternalAddress(struct sockaddr_in &addr) = 0;
|
|
virtual bool getExternalAddress(struct sockaddr_in &addr) = 0;
|
|
|
|
};
|
|
|
|
|
|
#define PNASS_TYPE_BADPEER 0x0001
|
|
#define PNASS_REASON_UNKNOWN 0x0001
|
|
|
|
class pqiNetAssistPeerShare
|
|
{
|
|
public:
|
|
|
|
/* share Addresses for various reasons (bad peers, etc) */
|
|
virtual void updatePeer(std::string id, struct sockaddr_in addr, int type, int reason, int age) = 0;
|
|
|
|
};
|
|
|
|
|
|
/* this is for the Stunners
|
|
*
|
|
*
|
|
*/
|
|
|
|
class pqiAddrAssist
|
|
{
|
|
public:
|
|
|
|
pqiAddrAssist() { return; }
|
|
virtual ~pqiAddrAssist() { return; }
|
|
|
|
virtual bool getExternalAddr(struct sockaddr_in &remote, uint8_t &stable) = 0;
|
|
virtual void setRefreshPeriod(int32_t period) = 0;
|
|
virtual int tick() = 0; /* for internal accounting */
|
|
|
|
};
|
|
|
|
|
|
#define NETASSIST_KNOWN_PEER_OFFLINE 0x0001
|
|
#define NETASSIST_KNOWN_PEER_ONLINE 0x0002
|
|
|
|
#define NETASSIST_KNOWN_PEER_WHITELIST 0x0100
|
|
#define NETASSIST_KNOWN_PEER_FRIEND 0x0200
|
|
#define NETASSIST_KNOWN_PEER_FOF 0x0400
|
|
#define NETASSIST_KNOWN_PEER_RELAY 0x0800
|
|
#define NETASSIST_KNOWN_PEER_SELF 0x1000
|
|
|
|
#define NETASSIST_KNOWN_PEER_TYPE_MASK 0xff00
|
|
|
|
class pqiNetAssistConnect: public pqiNetAssist
|
|
{
|
|
/*
|
|
*/
|
|
public:
|
|
pqiNetAssistConnect(std::string id, pqiConnectCb *cb)
|
|
:mPeerId(id), mConnCb(cb) { return; }
|
|
|
|
/********** External DHT Interface ************************
|
|
* These Functions are the external interface
|
|
* for the DHT, and must be non-blocking and return quickly
|
|
*/
|
|
|
|
|
|
/* add / remove peers */
|
|
virtual bool findPeer(std::string id) = 0;
|
|
virtual bool dropPeer(std::string id) = 0;
|
|
|
|
/* add non-active peers (can still toggle active/non-active via above) */
|
|
virtual int addBadPeer(const struct sockaddr_in &addr, uint32_t reason, uint32_t flags, uint32_t age) = 0;
|
|
virtual int addKnownPeer(const std::string &pid, const struct sockaddr_in &addr, uint32_t flags) = 0;
|
|
|
|
virtual void ConnectionFeedback(std::string pid, int mode) = 0;
|
|
|
|
/* extract current peer status */
|
|
virtual bool getPeerStatus(std::string id,
|
|
struct sockaddr_in &laddr, struct sockaddr_in &raddr,
|
|
uint32_t &type, uint32_t &mode) = 0; // DEPRECIATE.
|
|
|
|
virtual bool setAttachMode(bool on) = 0; // FIXUP.
|
|
|
|
/***** Stats for Network / DHT *****/
|
|
virtual bool getNetworkStats(uint32_t &netsize, uint32_t &localnetsize) = 0; // DEPRECIATE.
|
|
|
|
protected:
|
|
std::string mPeerId;
|
|
pqiConnectCb *mConnCb;
|
|
};
|
|
|
|
|
|
#endif /* MRK_PQI_ASSIST_H */
|
|
|