mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-11-17 22:40:06 -05:00
Commit of the new UDP Connection methods and
the rewrite of the retroshare core networking stack. This check-in commits the changes to the dht code. An interface to a second new DHT system (OpenDHT) has been added. This has a number of features that make it preferable to the KAD dht network. git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@309 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
e28c8a846f
commit
456325dc08
14 changed files with 2004 additions and 2 deletions
192
libretroshare/src/dht/opendhtmgr.cc
Normal file
192
libretroshare/src/dht/opendhtmgr.cc
Normal file
|
|
@ -0,0 +1,192 @@
|
|||
/*
|
||||
* libretroshare/src/dht: opendhtmgr.cc
|
||||
*
|
||||
* Interface with OpenDHT for RetroShare.
|
||||
*
|
||||
* Copyright 2007-2008 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".
|
||||
*
|
||||
*/
|
||||
|
||||
#include "dht/opendhtmgr.h"
|
||||
#include "dht/opendht.h"
|
||||
#include "util/rsthreads.h" /* for pthreads headers */
|
||||
|
||||
|
||||
class dhtSearchData
|
||||
{
|
||||
public:
|
||||
OpenDHTMgr *mgr;
|
||||
DHTClient *client;
|
||||
std::string key;
|
||||
};
|
||||
|
||||
|
||||
class dhtPublishData
|
||||
{
|
||||
public:
|
||||
OpenDHTMgr *mgr;
|
||||
DHTClient *client;
|
||||
std::string key;
|
||||
std::string value;
|
||||
uint32_t ttl;
|
||||
};
|
||||
|
||||
/* Thread routines */
|
||||
|
||||
extern "C" void* doDhtPublish(void* p)
|
||||
{
|
||||
dhtPublishData *data = (dhtPublishData *) p;
|
||||
if ((!data) || (!data->mgr) || (!data->client))
|
||||
{
|
||||
pthread_exit(NULL);
|
||||
}
|
||||
|
||||
/* publish it! */
|
||||
data->client->publishKey(data->key, data->value, data->ttl);
|
||||
|
||||
delete data;
|
||||
pthread_exit(NULL);
|
||||
}
|
||||
|
||||
|
||||
extern "C" void* doDhtSearch(void* p)
|
||||
{
|
||||
dhtSearchData *data = (dhtSearchData *) p;
|
||||
if ((!data) || (!data->mgr) || (!data->client))
|
||||
{
|
||||
pthread_exit(NULL);
|
||||
}
|
||||
|
||||
/* search it! */
|
||||
std::list<std::string> values;
|
||||
|
||||
if (data->client->searchKey(data->key, values))
|
||||
{
|
||||
/* callback */
|
||||
std::list<std::string>::iterator it;
|
||||
for(it = values.begin(); it != values.end(); it++)
|
||||
{
|
||||
data->mgr->resultDHT(data->key, *it);
|
||||
}
|
||||
}
|
||||
|
||||
delete data;
|
||||
pthread_exit(NULL);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
OpenDHTMgr::OpenDHTMgr(std::string ownId, pqiConnectCb* cb)
|
||||
:p3DhtMgr(ownId, cb)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
/********** OVERLOADED FROM p3DhtMgr ***************/
|
||||
bool OpenDHTMgr::init()
|
||||
{
|
||||
std::string configpath = ".";
|
||||
|
||||
/* load up DHT gateways */
|
||||
//mClient = new OpenDHTClient();
|
||||
mClient = new DHTClientDummy();
|
||||
|
||||
std::string filename = configpath;
|
||||
if (configpath.size() > 0)
|
||||
{
|
||||
filename += "/";
|
||||
}
|
||||
filename += "servers.txt";
|
||||
|
||||
return mClient -> loadServers(filename);
|
||||
}
|
||||
|
||||
bool OpenDHTMgr::shutdown()
|
||||
{
|
||||
/* do nothing */
|
||||
if (mClient)
|
||||
{
|
||||
delete mClient;
|
||||
mClient = NULL;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool OpenDHTMgr::dhtActive()
|
||||
{
|
||||
/* do nothing */
|
||||
if ((mClient) && (mClient -> dhtActive()))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
int OpenDHTMgr::status(std::ostream &out)
|
||||
{
|
||||
/* do nothing */
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/* Blocking calls (only from thread) */
|
||||
bool OpenDHTMgr::publishDHT(std::string key, std::string value, uint32_t ttl)
|
||||
{
|
||||
/* launch a publishThread */
|
||||
pthread_t tid;
|
||||
|
||||
dhtPublishData *pub = new dhtPublishData;
|
||||
pub->mgr = this;
|
||||
pub->client = mClient;
|
||||
pub->key = key;
|
||||
pub->value = value;
|
||||
pub->ttl = ttl;
|
||||
|
||||
void *data = (void *) pub;
|
||||
pthread_create(&tid, 0, &doDhtPublish, data);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool OpenDHTMgr::searchDHT(std::string key)
|
||||
{
|
||||
/* launch a publishThread */
|
||||
pthread_t tid;
|
||||
|
||||
dhtSearchData *dht = new dhtSearchData;
|
||||
dht->mgr = this;
|
||||
dht->client = mClient;
|
||||
dht->key = key;
|
||||
|
||||
void *data = (void *) dht;
|
||||
pthread_create(&tid, 0, &doDhtSearch, data);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/********** OVERLOADED FROM p3DhtMgr ***************/
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue