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"
|
2010-08-06 05:40:23 -04:00
|
|
|
#include "retroshare/rsfiles.h"
|
2008-08-09 13:03:24 -04:00
|
|
|
|
2008-06-19 18:49:23 -04:00
|
|
|
class ftFileProvider
|
|
|
|
{
|
2010-01-11 11:00:42 -05:00
|
|
|
public:
|
2011-02-19 19:59:47 -05:00
|
|
|
ftFileProvider(const std::string& path, uint64_t size, const std::string& hash);
|
2010-01-11 11:00:42 -05:00
|
|
|
virtual ~ftFileProvider();
|
2008-10-22 14:12:58 -04:00
|
|
|
|
2010-07-27 12:05:21 -04:00
|
|
|
virtual bool getFileData(const std::string& peer_id,uint64_t offset, uint32_t &chunk_size, void *data);
|
2010-01-11 11:00:42 -05:00
|
|
|
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
|
|
|
// 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-07-21 19:14:10 -04:00
|
|
|
// Provides a complete per-chunk CRC32 map to client who want to check their data.
|
|
|
|
// This is derived in ftFileCreator, but returns false, because we can't ensure that unchecked chunks
|
|
|
|
// will provide a CRC32 that is faithful to the original hash.
|
|
|
|
//
|
|
|
|
virtual bool getCRC32Map(CRC32Map& crc_map) ;
|
|
|
|
|
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-07-27 12:05:21 -04:00
|
|
|
// Removes inactive peers from the client list. Returns true if all peers have been removed.
|
|
|
|
//
|
|
|
|
bool purgeOldPeers(time_t now,uint32_t max_duration) ;
|
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)
|
|
|
|
*/
|
2010-07-27 12:05:21 -04:00
|
|
|
class PeerUploadInfo
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
PeerUploadInfo()
|
|
|
|
: req_loc(0),req_size(1), lastTS_t(0), transfer_rate(0), total_size(0), client_chunk_map_stamp(0) {}
|
|
|
|
|
|
|
|
void updateStatus(uint64_t offset,uint32_t data_size,time_t now) ;
|
2008-07-01 22:36:39 -04:00
|
|
|
|
2010-07-27 12:05:21 -04:00
|
|
|
uint64_t req_loc;
|
|
|
|
uint32_t req_size;
|
|
|
|
time_t lastTS_t; // used for estimating transfer rate.
|
|
|
|
time_t lastTS; // last update time (for purging)
|
2010-01-11 11:00:42 -05:00
|
|
|
|
2010-07-27 12:05:21 -04:00
|
|
|
// these two are used for speed estimation
|
|
|
|
float transfer_rate ;
|
|
|
|
uint32_t total_size ;
|
|
|
|
|
|
|
|
// Info about what the downloading peer already has
|
|
|
|
CompressedChunkMap client_chunk_map ;
|
|
|
|
time_t client_chunk_map_stamp ;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Contains statistics (speed, peer name, etc.) of all uploading peers for that file.
|
|
|
|
//
|
|
|
|
std::map<std::string,PeerUploadInfo> uploading_peers ;
|
2010-01-11 11:00:42 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Mutex Required for stuff below
|
|
|
|
*/
|
|
|
|
RsMutex ftcMutex;
|
2008-06-19 18:49:23 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // FT_FILE_PROVIDER_HEADER
|