mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-19 20:01:48 -05:00
304 lines
12 KiB
C++
304 lines
12 KiB
C++
#pragma once
|
|
|
|
/*
|
|
* libretroshare/src/serialiser: rstlvbase.h
|
|
*
|
|
* RetroShare Serialiser.
|
|
*
|
|
* Copyright 2007-2008 by Robert Fernie, Horatio, 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".
|
|
*
|
|
*/
|
|
|
|
|
|
/*******************************************************************
|
|
* These are the general TLV (un)packing routines.
|
|
*
|
|
* Data is Serialised into the following format
|
|
*
|
|
* -----------------------------------------
|
|
* | TLV TYPE (2 bytes) | TLV LEN (4 bytes)|
|
|
* -----------------------------------------
|
|
* | |
|
|
* | Data .... |
|
|
* | |
|
|
* -----------------------------------------
|
|
*
|
|
* Originally TLV TYPE = 2 bytes, and TLV LEN = 2 bytes.
|
|
* However with HTML and WSTRINGS the 64K Limit becomes limiting.
|
|
* The TLV LEN = 4 bytes now!
|
|
*
|
|
* Size is the total size of the TLV Field (including the 4 byte header)
|
|
*
|
|
* Like the lowlevel packing routines. They are usually
|
|
* created in pairs - one to pack the data, the other to unpack.
|
|
*
|
|
* GetTlvXXX(void *data, uint32_t size, uint32_t *offset, XXX *out);
|
|
* SetTlvXXX(void *data, uint32_t size, uint32_t *offset, XXX *in);
|
|
*
|
|
*
|
|
* data - the base pointer to the serialised data.
|
|
* size - size of the memory pointed to by data.
|
|
* *offset - where we want to (un)pack the data.
|
|
* This is incremented by the datasize.
|
|
*
|
|
* *in / *out - the data to (un)pack.
|
|
*
|
|
******************************************************************/
|
|
|
|
#include <inttypes.h>
|
|
#include <string>
|
|
#include "util/rsnet.h"
|
|
|
|
|
|
/* 0b 0000 0000 0001 XXXX UInt8 */
|
|
/* 0b 0000 0000 0010 XXXX UInt16 */
|
|
/* 0b 0000 0000 0011 XXXX UInt32 */
|
|
/* 0b 0000 0000 0100 XXXX UInt64 */
|
|
/* 0b 0000 0000 0101 XXXX String */
|
|
/* 0b 0000 0000 0110 XXXX Wide String */
|
|
/* 0b 0000 0000 0111 XXXX Hashes */
|
|
/* 0b 0000 0000 1000 XXXX IP:Port V4 */
|
|
|
|
/******* BINARY TYPES *****************/
|
|
/* 0b 0000 0001 0000 XXXX CERT */
|
|
/* 0b 0000 0001 0001 XXXX Priv Key */
|
|
/* 0b 0000 0001 0010 XXXX Pub Key */
|
|
/* 0b 0000 0001 0011 XXXX Signature */
|
|
|
|
/******* COMPOUND TYPES ***************/
|
|
/* 0b 0001 XXXX XXXX XXXX Compound */
|
|
/* 0b 0001 0000 0000 XXXX FILE */
|
|
/* 0b 0001 0000 0001 XXXX KEY VALUE */
|
|
/* 0b 0001 0000 0010 XXXX PEERS */
|
|
/* 0b 0001 0000 0011 XXXX SERVICES */
|
|
|
|
/******* BIG LEN TYPES ***************/
|
|
|
|
/* 0b 1000 XXXX XXXX XXXX BIG LEN */
|
|
/* 0b 1000 0000 0001 XXXX STRINGS */
|
|
/* 0b 1000 0000 0010 XXXX WSTRINGS */
|
|
/* 0b 1000 0000 0011 XXXX BINARY */
|
|
|
|
/* 0b 1001 XXXX XXXX XXXX Compound */
|
|
|
|
|
|
/* TLV HEADER SIZE (Reference) *******************************/
|
|
const uint32_t TLV_HEADER_TYPE_SIZE = 2;
|
|
const uint32_t TLV_HEADER_LEN_SIZE = 4;
|
|
const uint32_t TLV_HEADER_SIZE = TLV_HEADER_TYPE_SIZE + TLV_HEADER_LEN_SIZE;
|
|
/* TLV HEADER SIZE (Reference) *******************************/
|
|
|
|
const uint16_t TLV_TYPE_UINT32_SIZE = 0x0030;
|
|
const uint16_t TLV_TYPE_UINT32_POP = 0x0031;
|
|
const uint16_t TLV_TYPE_UINT32_AGE = 0x0032;
|
|
const uint16_t TLV_TYPE_UINT32_OFFSET = 0x0033;
|
|
const uint16_t TLV_TYPE_UINT32_SERID = 0x0034;
|
|
const uint16_t TLV_TYPE_UINT32_BW = 0x0035;
|
|
const uint16_t TLV_TYPE_UINT32_PARAM = 0x0030;
|
|
|
|
const uint16_t TLV_TYPE_UINT64_SIZE = 0x0040;
|
|
const uint16_t TLV_TYPE_UINT64_OFFSET = 0x0041;
|
|
|
|
const uint16_t TLV_TYPE_STR_PEERID = 0x0050;
|
|
const uint16_t TLV_TYPE_STR_NAME = 0x0051;
|
|
const uint16_t TLV_TYPE_STR_PATH = 0x0052;
|
|
const uint16_t TLV_TYPE_STR_KEY = 0x0053;
|
|
const uint16_t TLV_TYPE_STR_VALUE = 0x0054;
|
|
const uint16_t TLV_TYPE_STR_COMMENT = 0x0055;
|
|
const uint16_t TLV_TYPE_STR_TITLE = 0x0056;
|
|
const uint16_t TLV_TYPE_STR_MSG = 0x0057;
|
|
const uint16_t TLV_TYPE_STR_SUBJECT = 0x0058;
|
|
const uint16_t TLV_TYPE_STR_LINK = 0x0059;
|
|
const uint16_t TLV_TYPE_STR_GENID = 0x005a;
|
|
const uint16_t TLV_TYPE_STR_GPGID = 0x005b; /* depreciated */
|
|
const uint16_t TLV_TYPE_STR_PGPID = 0x005b; /* same as GPG */
|
|
const uint16_t TLV_TYPE_STR_LOCATION = 0x005c;
|
|
const uint16_t TLV_TYPE_STR_CERT_GPG = 0x005d;
|
|
const uint16_t TLV_TYPE_STR_PGPCERT = 0x005d; /* same as CERT_GPG */
|
|
const uint16_t TLV_TYPE_STR_CERT_SSL = 0x005e;
|
|
const uint16_t TLV_TYPE_STR_VERSION = 0x005f;
|
|
const uint16_t TLV_TYPE_STR_PARAM = 0x0054; /* same as VALUE ---- TO FIX */
|
|
|
|
/* Hashs are always strings */
|
|
const uint16_t TLV_TYPE_STR_HASH_SHA1 = 0x0070;
|
|
const uint16_t TLV_TYPE_STR_HASH_ED2K = 0x0071;
|
|
|
|
const uint16_t TLV_TYPE_IPV4_LOCAL = 0x0080;
|
|
const uint16_t TLV_TYPE_IPV4_REMOTE = 0x0081;
|
|
const uint16_t TLV_TYPE_IPV4_LAST = 0x0082;
|
|
const uint16_t TLV_TYPE_STR_DYNDNS = 0x0083;
|
|
const uint16_t TLV_TYPE_STR_DOMADDR = 0x0084;
|
|
|
|
// rearrange these in the future.
|
|
const uint16_t TLV_TYPE_IPV4 = 0x0085;
|
|
const uint16_t TLV_TYPE_IPV6 = 0x0086;
|
|
|
|
/*** MORE STRING IDS ****/
|
|
const uint16_t TLV_TYPE_STR_GROUPID = 0x00a0;
|
|
const uint16_t TLV_TYPE_STR_MSGID = 0x00a1;
|
|
const uint16_t TLV_TYPE_STR_PARENTID = 0x00a2;
|
|
const uint16_t TLV_TYPE_STR_THREADID = 0x00a3;
|
|
const uint16_t TLV_TYPE_STR_KEYID = 0x00a4;
|
|
|
|
/* even MORE string Ids for GXS services */
|
|
|
|
const uint16_t TLV_TYPE_STR_CAPTION = 0x00b1;
|
|
const uint16_t TLV_TYPE_STR_CATEGORY = 0x00b2;
|
|
const uint16_t TLV_TYPE_STR_DESCR = 0x00b3;
|
|
const uint16_t TLV_TYPE_STR_SIGN = 0x00b4;
|
|
const uint16_t TLV_TYPE_STR_HASH_TAG = 0x00b5;
|
|
const uint16_t TLV_TYPE_STR_WIKI_PAGE = 0x00b6;
|
|
const uint16_t TLV_TYPE_STR_DATE = 0x00b7;
|
|
const uint16_t TLV_TYPE_STR_PIC_TYPE = 0x00b8;
|
|
const uint16_t TLV_TYPE_STR_PIC_AUTH = 0x00b9;
|
|
const uint16_t TLV_TYPE_STR_GXS_ID = 0x00ba;
|
|
|
|
|
|
/**** Binary Types ****/
|
|
const uint16_t TLV_TYPE_CERT_XPGP_DER = 0x0100;
|
|
const uint16_t TLV_TYPE_CERT_X509 = 0x0101;
|
|
const uint16_t TLV_TYPE_CERT_OPENPGP = 0x0102;
|
|
|
|
const uint16_t TLV_TYPE_KEY_EVP_PKEY = 0x0110; /* Used (Generic - Distrib) */
|
|
const uint16_t TLV_TYPE_KEY_PRIV_RSA = 0x0111; /* not used yet */
|
|
const uint16_t TLV_TYPE_KEY_PUB_RSA = 0x0112; /* not used yet */
|
|
|
|
const uint16_t TLV_TYPE_SIGN_RSA_SHA1 = 0x0120; /* Used (Distrib/Forums) */
|
|
|
|
const uint16_t TLV_TYPE_BIN_IMAGE = 0x0130; /* Used (Generic - Forums) */
|
|
const uint16_t TLV_TYPE_BIN_FILEDATA = 0x0140; /* Used - ACTIVE! */
|
|
const uint16_t TLV_TYPE_BIN_SERIALISE = 0x0150; /* Used (Generic - Distrib) */
|
|
const uint16_t TLV_TYPE_BIN_GENERIC = 0x0160; /* Used (DSDV Data) */
|
|
const uint16_t TLV_TYPE_BIN_ENCRYPTED = 0x0170; /* Encrypted data */
|
|
|
|
|
|
/**** Compound Types ****/
|
|
const uint16_t TLV_TYPE_FILEITEM = 0x1000;
|
|
const uint16_t TLV_TYPE_FILESET = 0x1001;
|
|
const uint16_t TLV_TYPE_FILEDATA = 0x1002;
|
|
|
|
const uint16_t TLV_TYPE_KEYVALUE = 0x1010;
|
|
const uint16_t TLV_TYPE_KEYVALUESET = 0x1011;
|
|
|
|
const uint16_t TLV_TYPE_STRINGSET = 0x1020; /* dummy non-existant */
|
|
const uint16_t TLV_TYPE_PEERSET = 0x1021;
|
|
const uint16_t TLV_TYPE_HASHSET = 0x1022;
|
|
|
|
const uint16_t TLV_TYPE_PGPIDSET = 0x1023;
|
|
const uint16_t TLV_TYPE_RECOGNSET = 0x1024;
|
|
const uint16_t TLV_TYPE_GXSIDSET = 0x1025;
|
|
const uint16_t TLV_TYPE_GXSCIRCLEIDSET= 0x1026;
|
|
const uint16_t TLV_TYPE_NODEGROUPIDSET= 0x1027;
|
|
|
|
const uint16_t TLV_TYPE_SERVICESET = 0x1030;
|
|
|
|
// *_deprectate should not be used anymore!!
|
|
// We use 1040 for both public and private keys, so that transmitting them still works (backward compatibility), and so that
|
|
// signatures are kept. But the two different classes will check that the flags are correct when deserialising.
|
|
|
|
const uint16_t TLV_TYPE_SECURITY_KEY = 0x1040;
|
|
const uint16_t TLV_TYPE_SECURITYKEYSET = 0x1041;
|
|
|
|
const uint16_t TLV_TYPE_KEYSIGNATURE = 0x1050;
|
|
const uint16_t TLV_TYPE_KEYSIGNATURESET = 0x1051;
|
|
const uint16_t TLV_TYPE_KEYSIGNATURETYPE = 0x1052;
|
|
|
|
const uint16_t TLV_TYPE_IMAGE = 0x1060;
|
|
|
|
const uint16_t TLV_TYPE_ADDRESS_INFO = 0x1070;
|
|
const uint16_t TLV_TYPE_ADDRESS_SET = 0x1071;
|
|
const uint16_t TLV_TYPE_ADDRESS = 0x1072;
|
|
|
|
const uint16_t TLV_TYPE_DSDV_ENDPOINT = 0x1080;
|
|
const uint16_t TLV_TYPE_DSDV_ENTRY = 0x1081;
|
|
const uint16_t TLV_TYPE_DSDV_ENTRY_SET= 0x1082;
|
|
|
|
const uint16_t TLV_TYPE_BAN_ENTRY_dep = 0x1090;
|
|
const uint16_t TLV_TYPE_BAN_ENTRY = 0x1092;
|
|
const uint16_t TLV_TYPE_BAN_LIST = 0x1091;
|
|
|
|
const uint16_t TLV_TYPE_MSG_ADDRESS = 0x10A0;
|
|
const uint16_t TLV_TYPE_MSG_ID = 0x10A1;
|
|
|
|
|
|
const uint32_t RSTLV_IMAGE_TYPE_PNG = 0x0001;
|
|
const uint32_t RSTLV_IMAGE_TYPE_JPG = 0x0002;
|
|
|
|
/**** Basic TLV Functions ****/
|
|
uint32_t GetTlvSize(void *data);
|
|
uint16_t GetTlvType(void *data);
|
|
bool SetTlvBase(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint32_t len);
|
|
bool SetTlvSize(void *data, uint32_t size, uint32_t len);
|
|
bool SetTlvType(void *data, uint32_t size, uint16_t type);
|
|
|
|
/* skip past the unknown tlv elements */
|
|
bool SkipUnknownTlv(void *data, uint32_t size, uint32_t *offset);
|
|
|
|
/**** Generic TLV Functions ****
|
|
* This have the same data (int or string for example),
|
|
* but they can have different types eg. a string could represent a name or a path,
|
|
* so we include a type parameter in the arguments
|
|
*/
|
|
|
|
bool SetTlvUInt8(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint8_t out);
|
|
bool GetTlvUInt8(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint8_t *in);
|
|
|
|
bool SetTlvUInt16(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint16_t out);
|
|
bool GetTlvUInt16(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint16_t *in);
|
|
|
|
bool SetTlvUInt32(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint32_t out);
|
|
bool GetTlvUInt32(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint32_t *in);
|
|
|
|
bool SetTlvUInt64(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint64_t out);
|
|
bool GetTlvUInt64(void *data, uint32_t size, uint32_t *offset, uint16_t type, uint64_t *in);
|
|
|
|
uint32_t GetTlvUInt8Size();
|
|
uint32_t GetTlvUInt16Size();
|
|
uint32_t GetTlvUInt32Size();
|
|
uint32_t GetTlvUInt64Size();
|
|
|
|
|
|
bool SetTlvString(void *data, uint32_t size, uint32_t *offset, uint16_t type, std::string out);
|
|
bool GetTlvString(void *data, uint32_t size, uint32_t *offset, uint16_t type, std::string &in);
|
|
uint32_t GetTlvStringSize(const std::string &in);
|
|
|
|
#ifdef REMOVED_CODE
|
|
bool SetTlvWideString(void *data, uint32_t size, uint32_t *offset, uint16_t type, std::wstring out);
|
|
bool GetTlvWideString(void *data, uint32_t size, uint32_t *offset, uint16_t type, std::wstring &in);
|
|
uint32_t GetTlvWideStringSize(std::wstring &in);
|
|
#endif
|
|
|
|
bool SetTlvIpAddrPortV4(void *data, uint32_t size, uint32_t *offset, uint16_t type, struct sockaddr_in *out);
|
|
bool GetTlvIpAddrPortV4(void *data, uint32_t size, uint32_t *offset, uint16_t type, struct sockaddr_in *in);
|
|
uint32_t GetTlvIpAddrPortV4Size();
|
|
|
|
bool SetTlvIpAddrPortV6(void *data, uint32_t size, uint32_t *offset, uint16_t type, struct sockaddr_in6 *out);
|
|
bool GetTlvIpAddrPortV6(void *data, uint32_t size, uint32_t *offset, uint16_t type, struct sockaddr_in6 *in);
|
|
uint32_t GetTlvIpAddrPortV6Size();
|
|
|
|
/* additional function to be added
|
|
|
|
bool SetTlvBinData(void* data, uint32_t size, uint32_t* offset, uint16_t type, void* data_bin, uint32_t len_tlv)
|
|
|
|
above(SetTlvbinData) is partially implemented
|
|
|
|
bool GetTlvBinData(void* data, uint32_t size, uint32_t* offset, uint16_t type, void* data_bin, uint32_t len_tlv)
|
|
|
|
*************************************/
|