mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-02-27 18:31:25 -05:00

Validated chunks are shared to other peers. Force check is now very simple since it just turns all chunks into "needs checking" mode and sums are asked to sources. Sources maintain a temporary cache of chunks. Since sums are requested sparsely, this should not affect the sources in terms of performance. We can still imagine precomputing and saving sha1 of chunks while hashing them. For backward compatibility reasons, the following has been setup *temporarily* in this version: - unvalidated chunks are still considered as already obtained, and are shared and saved - force check has been disabled - final file check is maintained - in case of file fail, the old checking mode will be used. All changes for next version are kept in the define 'USE_NEW_CHUNK_CHECKING_CODE' that will be made the default in a few weeks. At start, I expect most chunk to stya yellow during download, until most sources are able to provide chunk hashs. git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@5019 b45a01b8-16f6-495d-af2f-9b41ad6348cc
179 lines
4.9 KiB
C++
179 lines
4.9 KiB
C++
/*
|
|
* "$Id: pqihandler.h,v 1.10 2007-03-31 09:41:32 rmf24 Exp $"
|
|
*
|
|
* 3P/PQI network interface for RetroShare.
|
|
*
|
|
* Copyright 2004-2006 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_HANDLER_HEADER
|
|
#define MRK_PQI_HANDLER_HEADER
|
|
|
|
#include "pqi/pqi.h"
|
|
#include "pqi/pqisecurity.h"
|
|
#include "pqi/pqiqos.h"
|
|
|
|
#include "util/rsthreads.h"
|
|
|
|
#include <map>
|
|
#include <list>
|
|
|
|
class SearchModule
|
|
{
|
|
public:
|
|
std::string peerid;
|
|
PQInterface *pqi;
|
|
SecurityPolicy *sp;
|
|
};
|
|
|
|
// Presents a P3 Face to the world!
|
|
// and funnels data through to a PQInterface.
|
|
//
|
|
class pqihandler: public P3Interface, public pqiQoS
|
|
{
|
|
public:
|
|
pqihandler(SecurityPolicy *Global);
|
|
bool AddSearchModule(SearchModule *mod);
|
|
bool RemoveSearchModule(SearchModule *mod);
|
|
|
|
// P3Interface.
|
|
virtual int SearchSpecific(RsCacheRequest *ns);
|
|
virtual int SendSearchResult(RsCacheItem *);
|
|
|
|
// inputs.
|
|
virtual RsCacheRequest * RequestedSearch();
|
|
virtual RsCacheItem * GetSearchResult();
|
|
|
|
// file i/o
|
|
virtual int SendFileRequest(RsFileRequest *ns);
|
|
virtual int SendFileData(RsFileData *ns);
|
|
virtual int SendFileChunkMapRequest(RsFileChunkMapRequest *ns);
|
|
virtual int SendFileChunkMap(RsFileChunkMap *ns);
|
|
virtual int SendFileCRC32MapRequest(RsFileCRC32MapRequest *ns);
|
|
virtual int SendFileCRC32Map(RsFileCRC32Map *ns);
|
|
virtual int SendFileSingleChunkCrcRequest(RsFileSingleChunkCrcRequest *ns);
|
|
virtual int SendFileSingleChunkCrc(RsFileSingleChunkCrc *ns);
|
|
virtual RsFileRequest *GetFileRequest();
|
|
virtual RsFileData *GetFileData();
|
|
virtual RsFileChunkMapRequest *GetFileChunkMapRequest();
|
|
virtual RsFileChunkMap *GetFileChunkMap();
|
|
virtual RsFileCRC32MapRequest *GetFileCRC32MapRequest();
|
|
virtual RsFileCRC32Map *GetFileCRC32Map();
|
|
virtual RsFileSingleChunkCrcRequest *GetFileSingleChunkCrcRequest();
|
|
virtual RsFileSingleChunkCrc *GetFileSingleChunkCrc();
|
|
|
|
// Rest of P3Interface
|
|
virtual int tick();
|
|
virtual int status();
|
|
|
|
// Service Data Interface
|
|
virtual int SendRsRawItem(RsRawItem *);
|
|
virtual RsRawItem *GetRsRawItem();
|
|
|
|
// rate control.
|
|
//indiv rate is deprecated
|
|
//void setMaxIndivRate(bool in, float val);
|
|
//float getMaxIndivRate(bool in);
|
|
void setMaxRate(bool in, float val);
|
|
float getMaxRate(bool in);
|
|
|
|
void getCurrentRates(float &in, float &out);
|
|
|
|
bool drawFromQoS_queue() ;
|
|
|
|
protected:
|
|
/* check to be overloaded by those that can
|
|
* generates warnings otherwise
|
|
*/
|
|
|
|
int locked_HandleRsItem(RsItem *ns, int allowglobal,uint32_t& size);
|
|
bool queueOutRsItem(RsItem *) ;
|
|
|
|
virtual int locked_checkOutgoingRsItem(RsItem *item, int global);
|
|
int locked_GetItems();
|
|
void locked_SortnStoreItem(RsItem *item);
|
|
|
|
RsMutex coreMtx; /* MUTEX */
|
|
|
|
std::map<std::string, SearchModule *> mods;
|
|
SecurityPolicy *globsec;
|
|
|
|
// Temporary storage...
|
|
std::list<RsItem *> in_result, in_search, in_request, in_data, in_service,in_chunkmap,in_chunkmap_request,in_crc32map_request,in_crc32map,in_singlechunkcrc,in_singlechunkcrc_request;
|
|
|
|
private:
|
|
|
|
// rate control.
|
|
int UpdateRates();
|
|
void locked_StoreCurrentRates(float in, float out);
|
|
|
|
float rateIndiv_in;
|
|
float rateIndiv_out;
|
|
float rateMax_in;
|
|
float rateMax_out;
|
|
|
|
float rateTotal_in;
|
|
float rateTotal_out;
|
|
|
|
uint32_t nb_ticks ;
|
|
time_t last_m ;
|
|
float ticks_per_sec ;
|
|
};
|
|
|
|
//inline void pqihandler::setMaxIndivRate(bool in, float val)
|
|
//{
|
|
// RsStackMutex stack(coreMtx); /**************** LOCKED MUTEX ****************/
|
|
// if (in)
|
|
// rateIndiv_in = val;
|
|
// else
|
|
// rateIndiv_out = val;
|
|
// return;
|
|
//}
|
|
//
|
|
//inline float pqihandler::getMaxIndivRate(bool in)
|
|
//{
|
|
// RsStackMutex stack(coreMtx); /**************** LOCKED MUTEX ****************/
|
|
// if (in)
|
|
// return rateIndiv_in;
|
|
// else
|
|
// return rateIndiv_out;
|
|
//}
|
|
|
|
inline void pqihandler::setMaxRate(bool in, float val)
|
|
{
|
|
RsStackMutex stack(coreMtx); /**************** LOCKED MUTEX ****************/
|
|
if (in)
|
|
rateMax_in = val;
|
|
else
|
|
rateMax_out = val;
|
|
return;
|
|
}
|
|
|
|
inline float pqihandler::getMaxRate(bool in)
|
|
{
|
|
RsStackMutex stack(coreMtx); /**************** LOCKED MUTEX ****************/
|
|
if (in)
|
|
return rateMax_in;
|
|
else
|
|
return rateMax_out;
|
|
}
|
|
|
|
#endif // MRK_PQI_HANDLER_HEADER
|