2008-04-25 14:43:23 -04:00
|
|
|
#ifndef RSQBLOGITEM_H_
|
|
|
|
#define RSQBLOGITEM_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* libretroshare/src/serialiser: rsqblogitems.h
|
|
|
|
*
|
|
|
|
* RetroShare Serialiser.
|
|
|
|
*
|
|
|
|
* Copyright 2007-2008 by Chris Parker.
|
|
|
|
*
|
|
|
|
* 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 <map>
|
2008-05-05 16:21:22 -04:00
|
|
|
#include <list>
|
2008-06-19 17:34:13 -04:00
|
|
|
#include <string>
|
2008-05-05 16:21:22 -04:00
|
|
|
|
2008-04-25 14:43:23 -04:00
|
|
|
#include "serialiser/rsserviceids.h"
|
|
|
|
#include "serialiser/rsserial.h"
|
|
|
|
#include "serialiser/rstlvtypes.h"
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
|
|
|
|
const uint8_t RS_PKT_SUBTYPE_QBLOG_PROFILE = 0x01;
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* retroshare qblog msg item for storing received and sent blog message
|
|
|
|
*/
|
|
|
|
class RsQblogMsg: public RsItem
|
2008-04-25 14:43:23 -04:00
|
|
|
{
|
|
|
|
public:
|
2008-06-19 17:34:13 -04:00
|
|
|
RsQblogMsg()
|
|
|
|
:RsItem(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_QBLOG, // add msg id type
|
2008-04-25 14:43:23 -04:00
|
|
|
RS_PKT_SUBTYPE_DEFAULT)
|
|
|
|
{ return; }
|
2008-06-19 17:34:13 -04:00
|
|
|
virtual ~RsQblogMsg();
|
2008-04-25 14:43:23 -04:00
|
|
|
virtual void clear();
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
/// inherited method from RsItem
|
|
|
|
std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
|
|
|
|
|
|
|
/// use for time stamp
|
|
|
|
uint32_t timeStamp;
|
|
|
|
|
|
|
|
/// contain blog mesgs and their blog time stamp (client time)
|
|
|
|
std::wstring blogMsg;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* retroshare qblog profile item for storing received and sent profile info
|
|
|
|
* designed in an open ended way to accomodate multiple fields
|
2008-04-25 14:43:23 -04:00
|
|
|
*/
|
2008-06-19 17:34:13 -04:00
|
|
|
class RsQblogProfile: public RsItem
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
RsQblogProfile()
|
|
|
|
:RsItem(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_QBLOG, // add profile id type
|
|
|
|
RS_PKT_SUBTYPE_QBLOG_PROFILE)
|
|
|
|
{ return; }
|
|
|
|
virtual ~RsQblogProfile();
|
|
|
|
virtual void clear();
|
|
|
|
|
|
|
|
/// inherited method from RsItem
|
2008-04-25 14:43:23 -04:00
|
|
|
std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
uint32_t timeStamp;
|
2008-04-25 14:43:23 -04:00
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
/// contains various profile information set by user, this and below use an open ended format
|
|
|
|
RsTlvKeyValueSet openProfile;
|
|
|
|
|
|
|
|
/// favoirte files of the user.....
|
|
|
|
RsTlvFileSet favoriteFiles;
|
2008-05-05 16:21:22 -04:00
|
|
|
|
2008-04-25 14:43:23 -04:00
|
|
|
};
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
/*!
|
|
|
|
* to serialise rsQblogItems: method names are self explanatory
|
|
|
|
*/
|
|
|
|
class RsQblogMsgSerialiser : public RsSerialType
|
2008-04-25 14:43:23 -04:00
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
2008-06-19 17:34:13 -04:00
|
|
|
RsQblogMsgSerialiser()
|
2008-04-25 14:43:23 -04:00
|
|
|
:RsSerialType(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_QBLOG)
|
|
|
|
{ return; }
|
2008-06-19 17:34:13 -04:00
|
|
|
virtual ~RsQblogMsgSerialiser()
|
2008-04-25 14:43:23 -04:00
|
|
|
{ return; }
|
|
|
|
/**
|
|
|
|
* check size of RsItem to be serialised
|
|
|
|
* @param RsItem RsItem which is going to be serilised
|
2008-06-19 17:34:13 -04:00
|
|
|
* @return size of the RsItem in bytes
|
2008-04-25 14:43:23 -04:00
|
|
|
*/
|
|
|
|
virtual uint32_t size(RsItem *);
|
2008-06-19 17:34:13 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* serialise contents of item to data
|
|
|
|
* @param item RsItem which is going to be serilised
|
|
|
|
* @param data where contents will be serialised into
|
|
|
|
* @return size of the RsItem in bytes
|
|
|
|
*/
|
2008-04-25 14:43:23 -04:00
|
|
|
virtual bool serialise (RsItem *item, void *data, uint32_t *size);
|
2008-06-19 17:34:13 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* serialise contents of item to data
|
|
|
|
* @param data where contents will be deserialisedout of
|
|
|
|
* @return size of the RsItem in bytes
|
|
|
|
*/
|
2008-04-25 14:43:23 -04:00
|
|
|
virtual RsItem * deserialise(void *data, uint32_t *size);
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
virtual uint32_t sizeItem(RsQblogMsg *);
|
|
|
|
virtual bool serialiseItem (RsQblogMsg *item, void *data, uint32_t *size);
|
|
|
|
virtual RsQblogMsg *deserialiseItem(void *data, uint32_t *size);
|
2008-04-25 14:43:23 -04:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2008-06-19 17:34:13 -04:00
|
|
|
/*!
|
|
|
|
* to serialise rsQblogProfile items, method names are self explanatory
|
|
|
|
*/
|
|
|
|
class RsQblogProfileSerialiser : public RsSerialType
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
RsQblogProfileSerialiser()
|
|
|
|
:RsSerialType(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_QBLOG)
|
|
|
|
{ return; }
|
|
|
|
virtual ~RsQblogProfileSerialiser()
|
|
|
|
{ return; }
|
|
|
|
/**
|
|
|
|
* check size of RsItem to be serialised
|
|
|
|
* @param RsItem RsItem which is going to be serilised
|
|
|
|
* @return size of the RsItem
|
|
|
|
*/
|
|
|
|
virtual uint32_t size(RsItem *);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* serialise contents of item to data
|
|
|
|
* @param item RsItem which is going to be serilised
|
|
|
|
* @param data where contents will be serialised into
|
|
|
|
* @return size of the RsItem in bytes
|
|
|
|
*/
|
|
|
|
virtual bool serialise (RsItem *item, void *data, uint32_t *size);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* serialise contents of item to data
|
|
|
|
* @param data where contents will be deserialisedout of
|
|
|
|
* @return size of the RsItem in bytes
|
|
|
|
*/
|
|
|
|
virtual RsItem * deserialise(void *data, uint32_t *size);
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
|
|
|
|
virtual uint32_t sizeItem(RsQblogProfile *);
|
|
|
|
virtual bool serialiseItem (RsQblogProfile *item, void *data, uint32_t *size);
|
|
|
|
virtual RsQblogProfile *deserialiseItem(void *data, uint32_t *size);
|
|
|
|
|
|
|
|
};
|
2008-04-25 14:43:23 -04:00
|
|
|
|
|
|
|
#endif /*RSQBLOGITEM_H_*/
|