2008-06-19 18:49:23 -04:00
|
|
|
/*
|
|
|
|
* libretroshare/src/ft ftFileProvider.h
|
|
|
|
*
|
|
|
|
* File Transfer for RetroShare.
|
|
|
|
*
|
|
|
|
* Copyright 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".
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FT_FILE_PROVIDER_HEADER
|
|
|
|
#define FT_FILE_PROVIDER_HEADER
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ftFileProvider.
|
|
|
|
*
|
|
|
|
*/
|
2008-07-01 22:36:39 -04:00
|
|
|
#include <iostream>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "util/rsthreads.h"
|
2008-08-09 13:03:24 -04:00
|
|
|
#include "rsiface/rsfiles.h"
|
|
|
|
|
2008-06-19 18:49:23 -04:00
|
|
|
class ftFileProvider
|
|
|
|
{
|
2010-01-11 11:00:42 -05:00
|
|
|
public:
|
|
|
|
ftFileProvider(std::string path, uint64_t size, std::string hash);
|
|
|
|
virtual ~ftFileProvider();
|
2008-10-22 14:12:58 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
virtual bool getFileData(uint64_t offset, uint32_t &chunk_size, void *data);
|
|
|
|
virtual bool FileDetails(FileInfo &info);
|
|
|
|
std::string getHash();
|
|
|
|
uint64_t getFileSize();
|
|
|
|
bool fileOk();
|
2008-08-09 13:03:24 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
void setPeerId(const std::string& id) ;
|
2009-02-04 16:35:39 -05:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
// Provides a client for the map of chunks actually present in the file. If the provider is also
|
|
|
|
// a file creator, because the file is actually being downloaded, then the map may be partially complete.
|
|
|
|
// Otherwize, a plain map is returned.
|
|
|
|
//
|
|
|
|
virtual void getAvailabilityMap(CompressedChunkMap& cmap) ;
|
2008-08-09 13:03:24 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
// a ftFileProvider feeds a distant peer. To display what the peers already has, we need to store/read this info.
|
|
|
|
void getClientMap(const std::string& peer_id,CompressedChunkMap& cmap,bool& map_is_too_old) ;
|
|
|
|
void setClientMap(const std::string& peer_id,const CompressedChunkMap& cmap) ;
|
2008-10-22 14:12:58 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
protected:
|
|
|
|
virtual int initializeFileAttrs(); /* does for both */
|
2008-06-19 18:49:23 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
uint64_t mSize;
|
|
|
|
std::string hash;
|
|
|
|
std::string file_name;
|
|
|
|
FILE *fd;
|
2009-02-04 19:01:51 -05:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
/*
|
|
|
|
* Structure to gather statistics FIXME: lastRequestor - figure out a
|
|
|
|
* way to get last requestor (peerID)
|
|
|
|
*/
|
|
|
|
std::string lastRequestor;
|
|
|
|
uint64_t req_loc;
|
|
|
|
uint32_t req_size;
|
|
|
|
time_t lastTS; // used for checking if it's alive
|
|
|
|
time_t lastTS_t; // used for estimating transfer rate.
|
2008-07-01 22:36:39 -04:00
|
|
|
|
2010-01-11 11:00:42 -05:00
|
|
|
// these two are used for speed estimation
|
|
|
|
float transfer_rate ;
|
|
|
|
uint32_t total_size ;
|
|
|
|
|
|
|
|
// Info about what the downloading peer already has
|
|
|
|
std::map<std::string,std::pair<CompressedChunkMap,time_t> > clients_chunk_maps ;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Mutex Required for stuff below
|
|
|
|
*/
|
|
|
|
RsMutex ftcMutex;
|
2008-06-19 18:49:23 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // FT_FILE_PROVIDER_HEADER
|