2014-11-08 09:55:29 -05:00
|
|
|
/*
|
|
|
|
* libretroshare/src/chat: distantchat.h
|
|
|
|
*
|
|
|
|
* Services for RetroShare.
|
|
|
|
*
|
|
|
|
* Copyright 2014 by Cyril Soler
|
|
|
|
*
|
|
|
|
* 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 "csoler@users.sourceforge.net".
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <turtle/turtleclientservice.h>
|
2014-11-11 11:10:54 -05:00
|
|
|
#include <chat/rschatitems.h>
|
|
|
|
#include <retroshare/rsmsgs.h>
|
|
|
|
|
2015-03-14 10:33:23 -04:00
|
|
|
class RsGixs ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
|
|
|
static const uint32_t DISTANT_CHAT_AES_KEY_SIZE = 16 ;
|
|
|
|
|
|
|
|
class DistantChatService: public RsTurtleClientService
|
|
|
|
{
|
2014-11-17 16:56:41 -05:00
|
|
|
public:
|
2015-03-14 10:33:23 -04:00
|
|
|
DistantChatService(RsGixs *pids)
|
|
|
|
: mGixs(pids), mDistantChatMtx("distant chat")
|
2014-11-17 16:56:41 -05:00
|
|
|
{
|
|
|
|
mTurtle = NULL ;
|
|
|
|
}
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
void flush() ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
virtual void connectToTurtleRouter(p3turtle *) ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// Creates the invite if the public key of the distant peer is available.
|
|
|
|
// Om success, stores the invite in the map above, so that we can respond to tunnel requests.
|
|
|
|
//
|
2014-11-18 10:55:31 -05:00
|
|
|
bool initiateDistantChatConnexion(const RsGxsId& to_gxs_id,const RsGxsId &from_gxs_id, uint32_t &error_code) ;
|
2014-11-17 16:56:41 -05:00
|
|
|
bool closeDistantChatConnexion(const RsGxsId& pid) ;
|
2015-02-08 16:06:36 -05:00
|
|
|
virtual bool getDistantChatStatus(const RsGxsId &gxs_id,uint32_t &status, RsGxsId *from_gxs_id=NULL) ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// derived in p3ChatService
|
|
|
|
virtual void handleIncomingItem(RsItem *) = 0;
|
|
|
|
virtual bool handleRecvChatMsgItem(RsChatMsgItem *ci)=0 ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
bool handleOutgoingItem(RsChatItem *) ;
|
|
|
|
bool handleRecvItem(RsChatItem *) ;
|
|
|
|
void handleRecvChatStatusItem(RsChatStatusItem *cs) ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
private:
|
|
|
|
class DistantChatPeerInfo
|
|
|
|
{
|
|
|
|
public:
|
2015-06-14 16:13:12 -04:00
|
|
|
DistantChatPeerInfo() : last_contact(0), last_keep_alive_sent(0), status(0), direction(0)
|
|
|
|
{
|
2015-06-15 05:04:26 -04:00
|
|
|
memset(aes_key, 0, DISTANT_CHAT_AES_KEY_SIZE);
|
2015-06-14 16:13:12 -04:00
|
|
|
}
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-12-07 16:51:30 -05:00
|
|
|
time_t last_contact ; // used to keep track of working connexion
|
|
|
|
time_t last_keep_alive_sent ; // last time we sent a keep alive packet.
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
unsigned char aes_key[DISTANT_CHAT_AES_KEY_SIZE] ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-20 18:18:14 -05:00
|
|
|
uint32_t status ; // info: do we have a tunnel ?
|
2014-11-17 16:56:41 -05:00
|
|
|
RsPeerId virtual_peer_id; // given by the turtle router. Identifies the tunnel.
|
|
|
|
RsGxsId own_gxs_id ; // gxs id we're using to talk.
|
|
|
|
RsTurtleGenericTunnelItem::Direction direction ; // specifiec wether we are client(managing the tunnel) or server.
|
|
|
|
};
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-20 18:18:14 -05:00
|
|
|
class DistantChatDHInfo
|
|
|
|
{
|
|
|
|
public:
|
2015-06-14 16:13:12 -04:00
|
|
|
DistantChatDHInfo() : dh(0), direction(0), status(0) {}
|
|
|
|
|
2014-11-20 18:18:14 -05:00
|
|
|
DH *dh ;
|
|
|
|
RsGxsId gxs_id ;
|
|
|
|
RsTurtleGenericTunnelItem::Direction direction ;
|
2015-02-14 15:55:05 -05:00
|
|
|
uint32_t status ;
|
|
|
|
TurtleFileHash hash ;
|
2014-11-20 18:18:14 -05:00
|
|
|
};
|
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// This maps contains the current peers to talk to with distant chat.
|
|
|
|
//
|
2014-11-20 18:18:14 -05:00
|
|
|
std::map<RsGxsId, DistantChatPeerInfo> _distant_chat_contacts ; // current peers we can talk to
|
|
|
|
std::map<RsPeerId,DistantChatDHInfo> _distant_chat_virtual_peer_ids ; // current virtual peers. Used to figure out tunnels, etc.
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// List of items to be sent asap. Used to store items that we cannot pass directly to
|
|
|
|
// sendTurtleData(), because of Mutex protection.
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
std::list<RsChatItem*> pendingDistantChatItems ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// Overloaded from RsTurtleClientService
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
virtual bool handleTunnelRequest(const RsFileHash &hash,const RsPeerId& peer_id) ;
|
|
|
|
virtual void receiveTurtleData(RsTurtleGenericTunnelItem *item,const RsFileHash& hash,const RsPeerId& virtual_peer_id,RsTurtleGenericTunnelItem::Direction direction) ;
|
|
|
|
void addVirtualPeer(const TurtleFileHash&, const TurtleVirtualPeerId&,RsTurtleGenericTunnelItem::Direction dir) ;
|
|
|
|
void removeVirtualPeer(const TurtleFileHash&, const TurtleVirtualPeerId&) ;
|
2014-11-20 18:18:14 -05:00
|
|
|
void markDistantChatAsClosed(const RsGxsId &gxs_id) ;
|
|
|
|
void startClientDistantChatConnection(const RsGxsId &to_gxs_id,const RsGxsId& from_gxs_id) ;
|
2015-02-14 15:55:05 -05:00
|
|
|
void locked_restartDHSession(const RsPeerId &virtual_peer_id, const RsGxsId &own_gxs_id) ;
|
|
|
|
|
2014-11-20 18:18:14 -05:00
|
|
|
//bool getHashFromVirtualPeerId(const TurtleVirtualPeerId& pid,RsFileHash& hash) ;
|
|
|
|
|
2015-02-14 15:55:05 -05:00
|
|
|
static TurtleFileHash hashFromGxsId(const RsGxsId& destination) ;
|
|
|
|
static RsGxsId gxsIdFromHash(const TurtleFileHash& sum) ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
void handleRecvDHPublicKey(RsChatDHPublicKeyItem *item) ;
|
2014-11-20 18:18:14 -05:00
|
|
|
bool locked_sendDHPublicKey(const DH *dh, const RsGxsId &own_gxs_id, const RsPeerId &virtual_peer_id) ;
|
|
|
|
bool locked_initDHSessionKey(DH *&dh);
|
2014-11-17 16:56:41 -05:00
|
|
|
DistantChatPeerId virtualPeerIdFromHash(const TurtleFileHash& hash ) ; // ... and to a hash for p3turtle
|
2014-11-08 09:55:29 -05:00
|
|
|
|
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
// Utility functions
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
void sendTurtleData(RsChatItem *) ;
|
2015-02-14 15:55:05 -05:00
|
|
|
void sendEncryptedTurtleData(const uint8_t *buff,uint32_t rssize,const RsGxsId &gxs_id) ;
|
|
|
|
bool handleEncryptedData(const uint8_t *data_bytes,uint32_t data_size,const TurtleFileHash& hash,const RsPeerId& virtual_peer_id) ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
static TurtleFileHash hashFromVirtualPeerId(const DistantChatPeerId& peerId) ; // converts IDs so that we can talk to RsPeerId from outside
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
p3turtle *mTurtle ;
|
2015-03-14 10:33:23 -04:00
|
|
|
RsGixs *mGixs ;
|
2014-11-08 09:55:29 -05:00
|
|
|
|
2014-11-17 16:56:41 -05:00
|
|
|
RsMutex mDistantChatMtx ;
|
2014-11-08 09:55:29 -05:00
|
|
|
};
|