RetroShare/libretroshare/src/pqi/pqibin.h
2016-06-02 20:38:33 -04:00

243 lines
5.8 KiB
C++

/*
* "$Id: pqibin.h,v 1.2 2007-02-18 21:46:49 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 PQI_BIN_INTERFACE_HEADER
#define PQI_BIN_INTERFACE_HEADER
#include "pqi/pqi_base.h"
#include "pqi/pqihash.h"
#include <stdio.h>
//! handles writing to binary files
/*!
* This allows for handling of binary file within Rs, In particular writing
* binary data to file declared in constructor
*/
class BinFileInterface: public BinInterface
{
public:
BinFileInterface(const char *fname, int flags);
virtual ~BinFileInterface();
virtual int tick() { return 1; }
virtual int senddata(void *data, int len);
virtual int readdata(void *data, int len);
virtual int netstatus() { return 1;}
virtual int isactive() { return (buf != NULL);}
virtual bool moretoread(uint32_t /* usec */ )
{
if ((buf) && (bin_flags & BIN_FLAGS_READABLE))
{
if ((size - ftell(buf)) > 0)
{
return true;
}
}
return false;
}
virtual int close();
virtual bool cansend(uint32_t /* usec */)
{
return (bin_flags & BIN_FLAGS_WRITEABLE);
}
virtual bool bandwidthLimited() { return false; }
//! if HASHing is switched on
virtual RsFileHash gethash();
virtual uint64_t bytecount();
protected:
virtual uint64_t getFileSize();
private:
int bin_flags;
FILE *buf;
uint64_t size;
pqihash *hash;
uint64_t bcount;
};
/*!
* use this for writing encrypted data to file using user's (ownid) ssl key
* hash for encrypted data is calculated, not the unencrypted data
*/
class BinEncryptedFileInterface : public BinFileInterface
{
public:
BinEncryptedFileInterface(const char *fname, int flags);
virtual ~BinEncryptedFileInterface();
/*!
* pls note if hashing is on, it is the hash of the encrypted data that is calculated
* also note, sif data is sent more than once, in a single instance of this object, then you will need to store the
* encrypted file size for each send externally as they are encrypted with different random keys.
* @param data data to be sent
* @param len length of data in bytes
* @return -1 if failed to write data, if not number bytes sent to file is returned
*/
int senddata(void *data, int len);
/*!
* uses the hash of the encrypted data
* @param location to place data
* @param the length of data to be read
* @return -1 if failed to write data, if not number of bytes read is returned
*/
int readdata(void *data, int len);
/*!
* this releases resources held by an instance
*/
int close();
uint64_t bytecount();
bool moretoread(uint32_t usec);
private:
char* data;
bool haveData;
uint64_t sizeData;
uint64_t cpyCount;
};
//! handles writing to reading/writing to memory
/*!
* This provide a memory interface for storing/retrieving information in memory
* to be read/sent elsewhere
*/
class BinMemInterface: public BinInterface
{
public:
BinMemInterface(int defsize, int flags);
BinMemInterface(const void *data, const int size, int flags);
virtual ~BinMemInterface();
/* Extra Interfaces */
int fseek(int loc);
int memsize() { return recvsize; }
void *memptr() { return buf; }
/* file interface */
bool writetofile(const char *fname);
bool readfromfile(const char *fname);
virtual int tick() { return 1; }
virtual int senddata(void *data, int len);
virtual int readdata(void *data, int len);
virtual int netstatus() { return 1; }
virtual int isactive() { return 1; }
virtual bool moretoread(uint32_t /* usec */)
{
if ((buf) && (bin_flags & BIN_FLAGS_READABLE ))
{
if (readloc < recvsize)
{
return true;
}
}
return false;
}
virtual int close();
virtual bool cansend(uint32_t /* usec */)
{
return (bin_flags & BIN_FLAGS_WRITEABLE);
}
virtual bool bandwidthLimited() { return false; }
virtual RsFileHash gethash();
virtual uint64_t bytecount();
private:
int bin_flags;
void *buf;
int size;
int recvsize;
int readloc;
pqihash *hash;
uint64_t bcount;
};
class NetBinDummy: public NetBinInterface
{
public:
NetBinDummy(PQInterface *parent, const RsPeerId& id, uint32_t t);
virtual ~NetBinDummy() { return; }
// Net Interface
virtual int connect(const struct sockaddr_storage &raddr);
virtual int listen();
virtual int stoplistening();
virtual int disconnect();
virtual int reset();
virtual bool connect_parameter(uint32_t type, uint32_t value)
{
(void) type; /* suppress unused parameter warning */
(void) value; /* suppress unused parameter warning */
return false;
}
virtual int getConnectAddress(struct sockaddr_storage &raddr)
{
(void) raddr; /* suppress unused parameter warning */
return 0;
}
// Bin Interface.
virtual int tick();
virtual int senddata(void *data, int len);
virtual int readdata(void *data, int len);
virtual int netstatus();
virtual int isactive();
virtual bool moretoread(uint32_t usec);
virtual bool cansend(uint32_t usec);
virtual int close();
virtual RsFileHash gethash();
private:
uint32_t type;
bool dummyConnected;
bool toConnect;
uint32_t connectDelta;
time_t connectTS;
};
#endif // PQI_BINARY_INTERFACES_HEADER