mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-15 09:27:09 -05:00
Merge branch 'master' into webui
This commit is contained in:
commit
2fed36a029
@ -1,5 +1,76 @@
|
|||||||
retroshare06 (0.6.0-1.XXXXXX~YYYYYY) YYYYYY; urgency=low
|
retroshare06 (0.6.0-1.XXXXXX~YYYYYY) YYYYYY; urgency=low
|
||||||
|
|
||||||
|
0ff6349 thunder2 Fri, 15 Jan 2016 12:01:37 +0100 Fixed possibility of XXE injection in FeedReader plugin.
|
||||||
|
748147f thunder2 Fri, 15 Jan 2016 12:00:02 +0100 Fixed Windows compile.
|
||||||
|
b5f6059 Cyril Soler Fri, 15 Jan 2016 10:07:21 -0500 deprecated updateClientSyncTS() which is not needed anymore
|
||||||
|
c24447f csoler Thu, 14 Jan 2016 20:11:26 -0500 fixed update of mGrpClientUpdateMap when no new group is available, avoiding unnecessary GXS grp list traffic (patch from jolavillette)
|
||||||
|
3b18c43 csoler Wed, 13 Jan 2016 20:25:18 -0500 removed [dos] LF from rsgxsnetservice (causes merging rampage)
|
||||||
|
086b076 csoler Wed, 13 Jan 2016 12:22:55 -0500 fixed a few serialisation issues
|
||||||
|
96f3446 csoler Wed, 13 Jan 2016 11:13:23 -0500 added size limit to packet grouping
|
||||||
|
b56881e csoler Wed, 13 Jan 2016 10:23:21 -0500 fixed windows compilation
|
||||||
|
4916496 csoler Wed, 13 Jan 2016 10:20:51 -0500 Merge pull request #253 from csoler/v0.6-SecurityReview
|
||||||
|
2c019d9 csoler Wed, 13 Jan 2016 00:39:22 -0500 added load image option in forum posts when images are to be displayed
|
||||||
|
60408b3 csoler Wed, 13 Jan 2016 00:13:16 -0500 fixed a bug in GRouterGenericDataItem::duplicate()
|
||||||
|
2a8fc7f csoler Wed, 13 Jan 2016 00:08:27 -0500 hardened the restriction to image loading to avoid external resources in RSTextBrowser
|
||||||
|
d55993d csoler Tue, 12 Jan 2016 21:43:04 -0500 removed two instances of malloc(0) captured by new rs_malloc funtion
|
||||||
|
d13526f csoler Tue, 12 Jan 2016 21:10:11 -0500 added a new method rs_malloc that checks its arguments and prints a stacktrace on error/weird call.
|
||||||
|
Changed the code everywhere to use this instead of malloc. Removed some mallocs and replaced with RsTemporaryMemory
|
||||||
|
9c6e7df csoler Mon, 11 Jan 2016 23:49:00 -0500 added checks after mallocs in several files
|
||||||
|
46520b0 csoler Mon, 11 Jan 2016 20:49:26 -0500 fixed potential integer overflow / Out of bounds read in gxstunnelitems.cc
|
||||||
|
8e666fc csoler Mon, 11 Jan 2016 20:40:57 -0500 fixed potential integer overflow / Out of bounds read in rsturtleitems.cc
|
||||||
|
6e9d96e csoler Mon, 11 Jan 2016 20:26:19 -0500 fixed potential integer overflow / Out of bounds read in RsVOIPDataItem.cc
|
||||||
|
98f0c10 csoler Mon, 11 Jan 2016 19:26:54 -0500 fixed potential integer overflow / Out of bounds read in GRouterItems.cc
|
||||||
|
3094b52 csoler Mon, 11 Jan 2016 19:08:52 -0500 fixed potential integer overflow / Out of bounds read in rsbaseserial.cc. Also added a few more error output.
|
||||||
|
8e6998b electron128 Sun, 10 Jan 2016 14:34:08 +0100 removed redundant map _lobby_ids from DistributedChatService. The same information and more is stored in the _chat_lobbys map.
|
||||||
|
_lobby_ids is unused since commit 67e1495d9a78ac259649014355cd127a2febeaaf
|
||||||
|
09ed1ea electron128 Sun, 10 Jan 2016 14:22:06 +0100 removed getVirtualPeerId method from rsmsgs lobby interface. It is not neccesary anymore to have the virtual peer id exposed to the GUI layer.
|
||||||
|
67e1495 electron128 Sun, 10 Jan 2016 13:29:40 +0100 use ChatId instead of virtual peer id for chat lobby popup. Removed a now unused method from rsmsgs interface and DistributedChatService.
|
||||||
|
c3d422a csoler Sat, 9 Jan 2016 14:31:20 -0500 added some tooltips on keys and certificate details
|
||||||
|
994bfaf csoler Sat, 9 Jan 2016 13:54:24 -0500 updated TODO
|
||||||
|
e01b1a4 csoler Sat, 9 Jan 2016 11:00:57 -0500 Merge pull request #245 from csoler/v0.6-Messaging
|
||||||
|
ee84ab7 csoler Sat, 9 Jan 2016 10:58:49 -0500 fixed serialisation error (missing call) for received Distant msg hash map
|
||||||
|
b125cb1 electron128 Sat, 9 Jan 2016 12:09:43 +0100 fix the bug where a filter is applied in friends file list even if view mode is tree and search box is hidden. Problem was:
|
||||||
|
SharedFilesDialog::FilterItems() is called from multiple places. The check if we should filter or not is now in the filter function itself.
|
||||||
|
a118870 electron128 Sat, 9 Jan 2016 12:01:32 +0100 if file in friends file list is available locally or is being downloaded, then show it in red like in search. The color is hardcoded, because
|
||||||
|
it is not possible to style arbitrary QObjects with stylesheets. closes #195
|
||||||
|
9f4256c csoler Fri, 8 Jan 2016 23:19:45 -0500 Merge pull request #244 from csoler/v0.6-Messaging
|
||||||
|
fe02167 csoler Fri, 8 Jan 2016 23:18:45 -0500 disabled part of msg re-sending code in order to improve it later
|
||||||
|
56a844b csoler Fri, 8 Jan 2016 23:08:14 -0500 Merge pull request #243 from csoler/v0.6-Messaging
|
||||||
|
a540ffd csoler Fri, 8 Jan 2016 22:52:01 -0500 removed two debug outputs from MessageDialog
|
||||||
|
3f6964b csoler Fri, 8 Jan 2016 22:50:03 -0500 added back messages to sent box
|
||||||
|
75edb46 csoler Fri, 8 Jan 2016 20:48:47 -0500 added auto-resend of unsent messages. Fixed display of From field in outbox
|
||||||
|
0c591f0 csoler Thu, 7 Jan 2016 22:22:05 -0500 added auto re-send of distant messages after global router notified the message cannot be sent. Added a map n p3msgService to avoid
|
||||||
|
receiving multiple times the same message.
|
||||||
|
9651f43 csoler Thu, 7 Jan 2016 21:01:50 -0500 fixed wrong usage of local client ids in global router causing distant messages to stay in outbox forever.
|
||||||
|
81e2a59 defnax Thu, 7 Jan 2016 19:25:52 +0100 Fixing People Margins Update emotes file
|
||||||
|
4484b08 csoler Thu, 7 Jan 2016 00:04:52 -0500 cleaned up the problem of outgoing messages being shown with the from from field.
|
||||||
|
3d6fa0c csoler Wed, 6 Jan 2016 18:38:27 -0500 fixed bug causing turtle to keep asking for a tunnel after a distant chat is closed if not connected
|
||||||
|
61f8e73 csoler Wed, 6 Jan 2016 18:12:15 -0500 improved text of warning against pasting pgp keys in connect wizard
|
||||||
|
984ce2d csoler Wed, 6 Jan 2016 18:07:20 -0500 removed circles tab from IdDialog. Came from a difficult manual merging between dos and unix encoded files
|
||||||
|
7da2ad1 csoler Wed, 6 Jan 2016 10:31:59 -0500 re-enabled previously disabled code in rsgxsnetservice, that proved useful
|
||||||
|
6398b7b csoler Tue, 5 Jan 2016 23:00:26 -0500 added comment in rsgxsnetservice.cc
|
||||||
|
3fa8d86 csoler Tue, 5 Jan 2016 22:53:56 -0500 removed time-stamp-ing of messages on client side in locked_genReqMsgTransaction() as it is already handled when receiving messages,
|
||||||
|
and the need to stamp non subscribed groups is not justified anymore
|
||||||
|
678afe7 csoler Tue, 5 Jan 2016 22:27:00 -0500 fixed stupid mistake in previous commit (GXS transaction timestamp)
|
||||||
|
7b3fd53 csoler Tue, 5 Jan 2016 19:23:59 -0500 added correct timestamp in msg list response items for GXS. To be tested.
|
||||||
|
141f092 csoler Tue, 5 Jan 2016 14:22:27 -0500 added tooltip and fixed text in connect friend dialog
|
||||||
|
496546e defnax Tue, 5 Jan 2016 18:25:44 +0100 Merge branch 'master' of https://github.com/RetroShare/RetroShare
|
||||||
|
19011ba defnax Tue, 5 Jan 2016 18:23:43 +0100 clean up emotes, removed some unused. changed icons for emotes button. reduze the size of the emoticons
|
||||||
|
9fd0fc5 csoler Tue, 5 Jan 2016 11:43:50 -0500 fixed bandwidth measurement in pqistreamer
|
||||||
|
e6cd4a4 defnax Tue, 5 Jan 2016 16:09:14 +0100 Merge pull request #240 from sehraf/pr-smiley-whitespace
|
||||||
|
54f9912 sehraf Tue, 5 Jan 2016 14:58:41 +0100 Add whitespaces around smileys. Only replace smileys with an image when they are surrounded by whitespaces.
|
||||||
|
This fixes smileys in links and other text that happen to include the sequence for a smiley.
|
||||||
|
f1f111f csoler Mon, 4 Jan 2016 20:05:44 -0500 merged
|
||||||
|
e04b933 B.Cristea Mon, 4 Jan 2016 15:25:22 +0200 corrected compilation inst on openSUSE
|
||||||
|
fddc008 csoler Sun, 3 Jan 2016 17:31:22 -0500 merged with origin
|
||||||
|
3d5042b csoler Sun, 3 Jan 2016 14:29:33 -0500 Merge pull request #237 from G10h4ck/master
|
||||||
|
05fd33b Gio Sun, 3 Jan 2016 17:21:11 +0100 p3ServiceControl: Optimize checkFilter(...), solve memory leak removing mSerialiser, code cleanup
|
||||||
|
1082a8d csoler Sat, 2 Jan 2016 18:59:05 -0500 updated ubuntu changelog
|
||||||
|
|
||||||
|
-- Cyril Soler <csoler@users.sourceforge.net> Thu, 14 Jan 2016 20:00:00 +0100
|
||||||
|
|
||||||
|
retroshare06 (0.6.0-1.20160102.1082a8d1~trusty) trusty; urgency=low
|
||||||
|
|
||||||
4953324 electron128 Sat, 2 Jan 2016 14:53:24 +0100 Merge pull request #235 from PhenomRetroShare/Fix_MakeMACOS_PluginWorking
|
4953324 electron128 Sat, 2 Jan 2016 14:53:24 +0100 Merge pull request #235 from PhenomRetroShare/Fix_MakeMACOS_PluginWorking
|
||||||
c5e6f62 Phenom Sat, 2 Jan 2016 14:19:53 +0100 Make Plugin working in Mac OSX.
|
c5e6f62 Phenom Sat, 2 Jan 2016 14:19:53 +0100 Make Plugin working in Mac OSX.
|
||||||
b6b5f9c csoler Fri, 1 Jan 2016 22:36:07 -0500 fixed some of the issues reported by coverity scan (mainly uninitialised class members)
|
b6b5f9c csoler Fri, 1 Jan 2016 22:36:07 -0500 fixed some of the issues reported by coverity scan (mainly uninitialised class members)
|
||||||
|
@ -2399,6 +2399,13 @@ bdNodeNetMsg::bdNodeNetMsg(char *msg, int len, struct sockaddr_in *in_addr)
|
|||||||
:data(NULL), mSize(len), addr(*in_addr)
|
:data(NULL), mSize(len), addr(*in_addr)
|
||||||
{
|
{
|
||||||
data = (char *) malloc(len);
|
data = (char *) malloc(len);
|
||||||
|
|
||||||
|
if(data == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) " << __PRETTY_FUNCTION__ << ": ERROR. cannot allocate memory for " << len << " bytes." << std::endl;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
|
||||||
memcpy(data, msg, len);
|
memcpy(data, msg, len);
|
||||||
//print(std::cerr);
|
//print(std::cerr);
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <iostream>
|
||||||
#include <stdlib.h> /* malloc() realloc() free() strtoll() */
|
#include <stdlib.h> /* malloc() realloc() free() strtoll() */
|
||||||
#include <string.h> /* memset() */
|
#include <string.h> /* memset() */
|
||||||
#include "util/bdstring.h"
|
#include "util/bdstring.h"
|
||||||
@ -111,6 +112,13 @@ static char *_be_decode_str(const char **data, long long *data_len)
|
|||||||
|
|
||||||
if (**data == ':') {
|
if (**data == ':') {
|
||||||
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
||||||
|
|
||||||
|
if(_ret == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) " << __PRETTY_FUNCTION__ << ": ERROR. cannot allocate memory for " << len+1+sizeof(sllen) << " bytes." << std::endl;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
memcpy(_ret, &sllen, sizeof(sllen));
|
memcpy(_ret, &sllen, sizeof(sllen));
|
||||||
ret = _ret + sizeof(sllen);
|
ret = _ret + sizeof(sllen);
|
||||||
memcpy(ret, *data + 1, len);
|
memcpy(ret, *data + 1, len);
|
||||||
@ -500,6 +508,12 @@ be_node *be_create_str(const char *str)
|
|||||||
int len = strlen(str);
|
int len = strlen(str);
|
||||||
long long int sllen = len;
|
long long int sllen = len;
|
||||||
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
||||||
|
|
||||||
|
if(_ret == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) " << __PRETTY_FUNCTION__ << ": ERROR. cannot allocate memory for " << len+1+sizeof(sllen) << " bytes." << std::endl;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
memcpy(_ret, &sllen, sizeof(sllen));
|
memcpy(_ret, &sllen, sizeof(sllen));
|
||||||
@ -519,6 +533,12 @@ be_node *be_create_str_wlen(const char *str, int len) /* not including \0 */
|
|||||||
be_node *n = be_alloc(BE_STR);
|
be_node *n = be_alloc(BE_STR);
|
||||||
long long int sllen = len;
|
long long int sllen = len;
|
||||||
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
||||||
|
|
||||||
|
if(_ret == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) " << __PRETTY_FUNCTION__ << ": ERROR. cannot allocate memory for " << len+1+sizeof(sllen) << " bytes." << std::endl;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
memcpy(_ret, &sllen, sizeof(sllen));
|
memcpy(_ret, &sllen, sizeof(sllen));
|
||||||
@ -561,6 +581,12 @@ int be_add_keypair(be_node *dict, const char *str, be_node *node)
|
|||||||
int len = strlen(str);
|
int len = strlen(str);
|
||||||
long long int sllen = len;
|
long long int sllen = len;
|
||||||
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
char *_ret = (char *) malloc(sizeof(sllen) + len + 1);
|
||||||
|
|
||||||
|
if(_ret == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) " << __PRETTY_FUNCTION__ << ": ERROR. cannot allocate memory for " << len+1+sizeof(sllen) << " bytes." << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
//fprintf(stderr, "be_add_keypair() key len = %d\n",len);
|
//fprintf(stderr, "be_add_keypair() key len = %d\n",len);
|
||||||
|
@ -66,7 +66,11 @@ class udpPacket
|
|||||||
:raddr(*addr), len(dlen)
|
:raddr(*addr), len(dlen)
|
||||||
{
|
{
|
||||||
data = malloc(len);
|
data = malloc(len);
|
||||||
|
|
||||||
|
if(data != NULL)
|
||||||
memcpy(data, dta, len);
|
memcpy(data, dta, len);
|
||||||
|
else
|
||||||
|
std::cerr << "(EE) error in memory allocation in " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
~udpPacket()
|
~udpPacket()
|
||||||
@ -242,6 +246,12 @@ void UdpLayer::recv_loop()
|
|||||||
int maxsize = 16000;
|
int maxsize = 16000;
|
||||||
void *inbuf = malloc(maxsize);
|
void *inbuf = malloc(maxsize);
|
||||||
|
|
||||||
|
if(inbuf == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Error in memory allocation of size " << maxsize << " in " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
|
||||||
int status;
|
int status;
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
|
|
||||||
|
@ -100,6 +100,13 @@ int bloomFilter::setFilterBits(const std::string &hex)
|
|||||||
|
|
||||||
// convert to binary array.
|
// convert to binary array.
|
||||||
uint8_t *tmparray = (uint8_t *) malloc(bytes);
|
uint8_t *tmparray = (uint8_t *) malloc(bytes);
|
||||||
|
|
||||||
|
if(tmparray == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Error. Cannot allocate memory for " << bytes << " bytes in " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t i = 0;
|
uint32_t i = 0;
|
||||||
|
|
||||||
for(i = 0; i < bytes; i++)
|
for(i = 0; i < bytes; i++)
|
||||||
@ -139,6 +146,13 @@ std::string bloomFilter::getFilter()
|
|||||||
|
|
||||||
// convert to binary array.
|
// convert to binary array.
|
||||||
uint8_t *tmparray = (uint8_t *) malloc(bytes);
|
uint8_t *tmparray = (uint8_t *) malloc(bytes);
|
||||||
|
|
||||||
|
if(tmparray == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Error. Cannot allocate memory for " << bytes << " bytes in " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return std::string();
|
||||||
|
}
|
||||||
|
|
||||||
int i,j;
|
int i,j;
|
||||||
|
|
||||||
for(i = 0; i < bytes; i++)
|
for(i = 0; i < bytes; i++)
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
#include "rsserver/p3face.h"
|
#include "rsserver/p3face.h"
|
||||||
#include "dbase/fimonitor.h"
|
#include "dbase/fimonitor.h"
|
||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "pqi/authssl.h"
|
#include "pqi/authssl.h"
|
||||||
#include "serialiser/rsserviceids.h"
|
#include "serialiser/rsserviceids.h"
|
||||||
#include "retroshare/rsiface.h"
|
#include "retroshare/rsiface.h"
|
||||||
@ -128,13 +129,11 @@ HashCache::HashCache(const std::string& path)
|
|||||||
|
|
||||||
// read the binary stream into memory.
|
// read the binary stream into memory.
|
||||||
//
|
//
|
||||||
void *buffer = malloc(file_size) ;
|
void *buffer = rs_malloc(file_size) ;
|
||||||
|
|
||||||
if(buffer == NULL)
|
if(buffer == NULL)
|
||||||
{
|
|
||||||
std::cerr << "Cannot allocate memory for reading encrypted file cache, bytes=" << file_size << std::endl;
|
|
||||||
return ;
|
return ;
|
||||||
}
|
|
||||||
FILE *F = fopen( (_path+".bin").c_str(),"rb") ;
|
FILE *F = fopen( (_path+".bin").c_str(),"rb") ;
|
||||||
if (!F)
|
if (!F)
|
||||||
{
|
{
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
#include "util/rsstring.h"
|
#include "util/rsstring.h"
|
||||||
#endif
|
#endif
|
||||||
#include "util/rsdiscspace.h"
|
#include "util/rsdiscspace.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
#include "ft/ftcontroller.h"
|
#include "ft/ftcontroller.h"
|
||||||
|
|
||||||
@ -747,8 +748,14 @@ bool ftController::copyFile(const std::string& source,const std::string& dest)
|
|||||||
size_t T=0;
|
size_t T=0;
|
||||||
|
|
||||||
static const int BUFF_SIZE = 10485760 ; // 10 MB buffer to speed things up.
|
static const int BUFF_SIZE = 10485760 ; // 10 MB buffer to speed things up.
|
||||||
void *buffer = malloc(BUFF_SIZE) ;
|
void *buffer = rs_malloc(BUFF_SIZE) ;
|
||||||
|
|
||||||
|
if(buffer == NULL)
|
||||||
|
{
|
||||||
|
fclose (in);
|
||||||
|
fclose (out);
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
bool bRet = true;
|
bool bRet = true;
|
||||||
|
|
||||||
while( (s = fread(buffer,1,BUFF_SIZE,in)) > 0)
|
while( (s = fread(buffer,1,BUFF_SIZE,in)) > 0)
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#include "ft/ftfileprovider.h"
|
#include "ft/ftfileprovider.h"
|
||||||
#include "ft/ftsearch.h"
|
#include "ft/ftsearch.h"
|
||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include <retroshare/rsturtle.h>
|
#include <retroshare/rsturtle.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
@ -878,13 +879,11 @@ bool ftDataMultiplex::locked_handleServerRequest(ftFileProvider *provider, const
|
|||||||
std::cerr << "Warning: peer " << peerId << " is asking a large chunk (s=" << chunksize << ") for hash " << hash << ", filesize=" << size << ". This is unexpected." << std::endl ;
|
std::cerr << "Warning: peer " << peerId << " is asking a large chunk (s=" << chunksize << ") for hash " << hash << ", filesize=" << size << ". This is unexpected." << std::endl ;
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
void *data = malloc(chunksize);
|
void *data = rs_malloc(chunksize);
|
||||||
|
|
||||||
if(data == NULL)
|
if(data == NULL)
|
||||||
{
|
|
||||||
std::cerr << "WARNING: Could not allocate data for a chunksize of " << chunksize << std::endl ;
|
|
||||||
return false ;
|
return false ;
|
||||||
}
|
|
||||||
#ifdef MPLEX_DEBUG
|
#ifdef MPLEX_DEBUG
|
||||||
std::cerr << "ftDataMultiplex::locked_handleServerRequest()";
|
std::cerr << "ftDataMultiplex::locked_handleServerRequest()";
|
||||||
std::cerr << "\t peer: " << peerId << " hash: " << hash;
|
std::cerr << "\t peer: " << peerId << " hash: " << hash;
|
||||||
|
@ -465,6 +465,8 @@ RsTurtleGenericTunnelItem *ftServer::deserialiseItem(void *data,uint32_t size) c
|
|||||||
return NULL; /* wrong type */
|
return NULL; /* wrong type */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
switch(getRsItemSubType(rstype))
|
switch(getRsItemSubType(rstype))
|
||||||
{
|
{
|
||||||
case RS_TURTLE_SUBTYPE_FILE_REQUEST : return new RsTurtleFileRequestItem(data,size) ;
|
case RS_TURTLE_SUBTYPE_FILE_REQUEST : return new RsTurtleFileRequestItem(data,size) ;
|
||||||
@ -475,6 +477,13 @@ RsTurtleGenericTunnelItem *ftServer::deserialiseItem(void *data,uint32_t size) c
|
|||||||
case RS_TURTLE_SUBTYPE_CHUNK_CRC : return new RsTurtleChunkCrcItem(data,size) ;
|
case RS_TURTLE_SUBTYPE_CHUNK_CRC : return new RsTurtleChunkCrcItem(data,size) ;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(std::exception& e)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) deserialisation error in " << __PRETTY_FUNCTION__ << ": " << e.what() << std::endl;
|
||||||
|
|
||||||
return NULL ;
|
return NULL ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1093,11 +1102,10 @@ bool ftServer::sendData(const RsPeerId& peerId, const RsFileHash& hash, uint64_t
|
|||||||
|
|
||||||
item->chunk_offset = offset+baseoffset ;
|
item->chunk_offset = offset+baseoffset ;
|
||||||
item->chunk_size = chunk;
|
item->chunk_size = chunk;
|
||||||
item->chunk_data = malloc(chunk) ;
|
item->chunk_data = rs_malloc(chunk) ;
|
||||||
|
|
||||||
if(item->chunk_data == NULL)
|
if(item->chunk_data == NULL)
|
||||||
{
|
{
|
||||||
std::cerr << "p3turtle: Warning: failed malloc of " << chunk << " bytes for sending data packet." << std::endl ;
|
|
||||||
delete item;
|
delete item;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
|
#include <util/rsmemory.h>
|
||||||
#include <serialiser/itempriorities.h>
|
#include <serialiser/itempriorities.h>
|
||||||
#include <ft/ftturtlefiletransferitem.h>
|
#include <ft/ftturtlefiletransferitem.h>
|
||||||
|
|
||||||
@ -422,14 +423,24 @@ RsTurtleFileDataItem::RsTurtleFileDataItem(void *data,uint32_t pktsize)
|
|||||||
uint32_t offset = 8; // skip the header
|
uint32_t offset = 8; // skip the header
|
||||||
uint32_t rssize = getRsItemSize(data);
|
uint32_t rssize = getRsItemSize(data);
|
||||||
|
|
||||||
/* add mandatory parts first */
|
|
||||||
|
|
||||||
bool ok = true ;
|
bool ok = true ;
|
||||||
|
|
||||||
|
if(rssize > pktsize)
|
||||||
|
ok = false ;
|
||||||
|
|
||||||
|
/* add mandatory parts first */
|
||||||
ok &= getRawUInt32(data, pktsize, &offset, &tunnel_id) ;
|
ok &= getRawUInt32(data, pktsize, &offset, &tunnel_id) ;
|
||||||
ok &= getRawUInt64(data, pktsize, &offset, &chunk_offset);
|
ok &= getRawUInt64(data, pktsize, &offset, &chunk_offset);
|
||||||
ok &= getRawUInt32(data, pktsize, &offset, &chunk_size);
|
ok &= getRawUInt32(data, pktsize, &offset, &chunk_size);
|
||||||
|
|
||||||
chunk_data = (void*)malloc(chunk_size) ;
|
if(chunk_size > rssize || rssize - chunk_size < offset)
|
||||||
|
throw std::runtime_error("RsTurtleFileDataItem::() error while deserializing.") ;
|
||||||
|
|
||||||
|
chunk_data = (void*)rs_malloc(chunk_size) ;
|
||||||
|
|
||||||
|
if(chunk_data == NULL)
|
||||||
|
throw std::runtime_error("RsTurtleFileDataItem::() cannot allocate memory.") ;
|
||||||
|
|
||||||
memcpy(chunk_data,(void*)((unsigned char*)data+offset),chunk_size) ;
|
memcpy(chunk_data,(void*)((unsigned char*)data+offset),chunk_size) ;
|
||||||
|
|
||||||
offset += chunk_size ;
|
offset += chunk_size ;
|
||||||
|
@ -66,6 +66,12 @@ RsGRouterTransactionChunkItem *RsGRouterSerialiser::deserialise_RsGRouterTransac
|
|||||||
uint32_t rssize = getRsItemSize(data);
|
uint32_t rssize = getRsItemSize(data);
|
||||||
bool ok = true ;
|
bool ok = true ;
|
||||||
|
|
||||||
|
if(tlvsize < rssize)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << ": wrong encoding of item size. Serialisation error!" << std::endl;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
|
||||||
RsGRouterTransactionChunkItem *item = new RsGRouterTransactionChunkItem() ;
|
RsGRouterTransactionChunkItem *item = new RsGRouterTransactionChunkItem() ;
|
||||||
|
|
||||||
/* add mandatory parts first */
|
/* add mandatory parts first */
|
||||||
@ -74,15 +80,14 @@ RsGRouterTransactionChunkItem *RsGRouterSerialiser::deserialise_RsGRouterTransac
|
|||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->chunk_size);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->chunk_size);
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->total_size);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->total_size);
|
||||||
|
|
||||||
if( NULL == (item->chunk_data = (uint8_t*)malloc(item->chunk_size)))
|
if(item->chunk_size > rssize || offset > rssize - item->chunk_size) // better than if(item->chunk_size + offset > rssize)
|
||||||
{
|
{
|
||||||
std::cerr << __PRETTY_FUNCTION__ << ": Cannot allocate memory for chunk " << item->chunk_size << std::endl;
|
std::cerr << __PRETTY_FUNCTION__ << ": Cannot read beyond item size. Serialisation error!" << std::endl;
|
||||||
delete item;
|
delete item;
|
||||||
return NULL ;
|
return NULL ;
|
||||||
}
|
}
|
||||||
if(item->chunk_size + offset > rssize)
|
if( NULL == (item->chunk_data = (uint8_t*)rs_malloc(item->chunk_size)))
|
||||||
{
|
{
|
||||||
std::cerr << __PRETTY_FUNCTION__ << ": Cannot read beyond item size. Serialisation error!" << std::endl;
|
|
||||||
delete item;
|
delete item;
|
||||||
return NULL ;
|
return NULL ;
|
||||||
}
|
}
|
||||||
@ -125,6 +130,11 @@ RsGRouterGenericDataItem *RsGRouterSerialiser::deserialise_RsGRouterGenericDataI
|
|||||||
uint32_t rssize = getRsItemSize(data);
|
uint32_t rssize = getRsItemSize(data);
|
||||||
bool ok = true ;
|
bool ok = true ;
|
||||||
|
|
||||||
|
if(pktsize < rssize)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << ": wrong encoding of item size. Serialisation error!" << std::endl;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
RsGRouterGenericDataItem *item = new RsGRouterGenericDataItem() ;
|
RsGRouterGenericDataItem *item = new RsGRouterGenericDataItem() ;
|
||||||
|
|
||||||
ok &= getRawUInt64(data, pktsize, &offset, &item->routing_id);
|
ok &= getRawUInt64(data, pktsize, &offset, &item->routing_id);
|
||||||
@ -132,16 +142,15 @@ RsGRouterGenericDataItem *RsGRouterSerialiser::deserialise_RsGRouterGenericDataI
|
|||||||
ok &= getRawUInt32(data, pktsize, &offset, &item->service_id);
|
ok &= getRawUInt32(data, pktsize, &offset, &item->service_id);
|
||||||
ok &= getRawUInt32(data, pktsize, &offset, &item->data_size);
|
ok &= getRawUInt32(data, pktsize, &offset, &item->data_size);
|
||||||
|
|
||||||
if( NULL == (item->data_bytes = (uint8_t*)malloc(item->data_size)))
|
if(item->data_size > rssize || offset > rssize - item->data_size) // better than if(item->data_size + offset > rssize)
|
||||||
{
|
{
|
||||||
std::cerr << __PRETTY_FUNCTION__ << ": Cannot allocate memory for chunk " << item->data_size << std::endl;
|
std::cerr << __PRETTY_FUNCTION__ << ": Cannot read beyond item size. Serialisation error!" << std::endl;
|
||||||
delete item;
|
delete item;
|
||||||
return NULL ;
|
return NULL ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(item->data_size + offset > rssize)
|
if( NULL == (item->data_bytes = (uint8_t*)rs_malloc(item->data_size)))
|
||||||
{
|
{
|
||||||
std::cerr << __PRETTY_FUNCTION__ << ": Cannot read beyond item size. Serialisation error!" << std::endl;
|
|
||||||
delete item;
|
delete item;
|
||||||
return NULL ;
|
return NULL ;
|
||||||
}
|
}
|
||||||
@ -337,8 +346,19 @@ RsGRouterGenericDataItem *RsGRouterGenericDataItem::duplicate() const
|
|||||||
|
|
||||||
// then duplicate the memory chunk
|
// then duplicate the memory chunk
|
||||||
|
|
||||||
item->data_bytes = (uint8_t*)malloc(data_size) ;
|
if(data_size > 0)
|
||||||
|
{
|
||||||
|
item->data_bytes = (uint8_t*)rs_malloc(data_size) ;
|
||||||
|
|
||||||
|
if(item->data_bytes == NULL)
|
||||||
|
{
|
||||||
|
delete item ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
memcpy(item->data_bytes,data_bytes,data_size) ;
|
memcpy(item->data_bytes,data_bytes,data_size) ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
item->data_bytes = NULL ;
|
||||||
|
|
||||||
return item ;
|
return item ;
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,8 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
#include "serialiser/rsserial.h"
|
#include "serialiser/rsserial.h"
|
||||||
#include "serialiser/rstlvkeys.h"
|
#include "serialiser/rstlvkeys.h"
|
||||||
#include "serialiser/rsserviceids.h"
|
#include "serialiser/rsserviceids.h"
|
||||||
@ -194,7 +196,11 @@ class RsGRouterTransactionChunkItem: public RsGRouterTransactionItem, public RsG
|
|||||||
{
|
{
|
||||||
RsGRouterTransactionChunkItem *item = new RsGRouterTransactionChunkItem ;
|
RsGRouterTransactionChunkItem *item = new RsGRouterTransactionChunkItem ;
|
||||||
*item = *this ; // copy all fields
|
*item = *this ; // copy all fields
|
||||||
item->chunk_data = (uint8_t*)malloc(chunk_size) ; // deep copy memory chunk
|
item->chunk_data = (uint8_t*)rs_malloc(chunk_size) ; // deep copy memory chunk
|
||||||
|
|
||||||
|
if(item->chunk_data == NULL)
|
||||||
|
return NULL ;
|
||||||
|
|
||||||
memcpy(item->chunk_data,chunk_data,chunk_size) ;
|
memcpy(item->chunk_data,chunk_data,chunk_size) ;
|
||||||
return item ;
|
return item ;
|
||||||
}
|
}
|
||||||
|
@ -1121,13 +1121,11 @@ bool p3GRouter::locked_sendTransactionData(const RsPeerId& pid,const RsGRouterTr
|
|||||||
std::cerr << " sending to tunnel vpid " << pid << std::endl;
|
std::cerr << " sending to tunnel vpid " << pid << std::endl;
|
||||||
#endif
|
#endif
|
||||||
uint32_t turtle_data_size = trans_item.serial_size() ;
|
uint32_t turtle_data_size = trans_item.serial_size() ;
|
||||||
uint8_t *turtle_data = (uint8_t*)malloc(turtle_data_size) ;
|
uint8_t *turtle_data = (uint8_t*)rs_malloc(turtle_data_size) ;
|
||||||
|
|
||||||
if(turtle_data == NULL)
|
if(turtle_data == NULL)
|
||||||
{
|
|
||||||
std::cerr << " ERROR: Cannot allocate turtle data memory for size " << turtle_data_size << std::endl;
|
|
||||||
return false ;
|
return false ;
|
||||||
}
|
|
||||||
if(!trans_item.serialise(turtle_data,turtle_data_size))
|
if(!trans_item.serialise(turtle_data,turtle_data_size))
|
||||||
{
|
{
|
||||||
std::cerr << " ERROR: cannot serialise RsGRouterTransactionChunkItem." << std::endl;
|
std::cerr << " ERROR: cannot serialise RsGRouterTransactionChunkItem." << std::endl;
|
||||||
@ -1304,14 +1302,13 @@ bool p3GRouter::sliceDataItem(RsGRouterAbstractMsgItem *item,std::list<RsGRouter
|
|||||||
chunk_item->total_size = size;
|
chunk_item->total_size = size;
|
||||||
chunk_item->chunk_start= offset;
|
chunk_item->chunk_start= offset;
|
||||||
chunk_item->chunk_size = chunk_size ;
|
chunk_item->chunk_size = chunk_size ;
|
||||||
chunk_item->chunk_data = (uint8_t*)malloc(chunk_size) ;
|
chunk_item->chunk_data = (uint8_t*)rs_malloc(chunk_size) ;
|
||||||
#ifdef GROUTER_DEBUG
|
#ifdef GROUTER_DEBUG
|
||||||
std::cerr << " preparing to send a chunk [" << offset << " -> " << offset + chunk_size << " / " << size << "]" << std::endl;
|
std::cerr << " preparing to send a chunk [" << offset << " -> " << offset + chunk_size << " / " << size << "]" << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(chunk_item->chunk_data == NULL)
|
if(chunk_item->chunk_data == NULL)
|
||||||
{
|
{
|
||||||
std::cerr << " ERROR: Cannot allocate memory for size " << chunk_size << std::endl;
|
|
||||||
delete chunk_item;
|
delete chunk_item;
|
||||||
throw ;
|
throw ;
|
||||||
}
|
}
|
||||||
@ -1921,7 +1918,11 @@ bool p3GRouter::sendData(const RsGxsId& destination,const GRouterServiceId& clie
|
|||||||
|
|
||||||
RsGRouterGenericDataItem *data_item = new RsGRouterGenericDataItem ;
|
RsGRouterGenericDataItem *data_item = new RsGRouterGenericDataItem ;
|
||||||
|
|
||||||
data_item->data_bytes = (uint8_t*)malloc(data_size) ;
|
data_item->data_bytes = (uint8_t*)rs_malloc(data_size) ;
|
||||||
|
|
||||||
|
if(data_item->data_bytes == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
memcpy(data_item->data_bytes,data,data_size) ;
|
memcpy(data_item->data_bytes,data,data_size) ;
|
||||||
|
|
||||||
data_item->data_size = data_size ;
|
data_item->data_size = data_size ;
|
||||||
|
@ -444,7 +444,11 @@ bool GxsSecurity::encrypt(uint8_t *& out, uint32_t &outlen, const uint8_t *in, u
|
|||||||
int out_offset = 0;
|
int out_offset = 0;
|
||||||
|
|
||||||
int max_evp_key_size = EVP_PKEY_size(public_key);
|
int max_evp_key_size = EVP_PKEY_size(public_key);
|
||||||
ek = (unsigned char*)malloc(max_evp_key_size);
|
ek = (unsigned char*)rs_malloc(max_evp_key_size);
|
||||||
|
|
||||||
|
if(ek == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
const EVP_CIPHER *cipher = EVP_aes_128_cbc();
|
const EVP_CIPHER *cipher = EVP_aes_128_cbc();
|
||||||
int cipher_block_size = EVP_CIPHER_block_size(cipher);
|
int cipher_block_size = EVP_CIPHER_block_size(cipher);
|
||||||
int size_net_ekl = sizeof(net_ekl);
|
int size_net_ekl = sizeof(net_ekl);
|
||||||
@ -455,13 +459,10 @@ bool GxsSecurity::encrypt(uint8_t *& out, uint32_t &outlen, const uint8_t *in, u
|
|||||||
if(!EVP_SealInit(&ctx, EVP_aes_128_cbc(), &ek, &eklen, iv, &public_key, 1)) return false;
|
if(!EVP_SealInit(&ctx, EVP_aes_128_cbc(), &ek, &eklen, iv, &public_key, 1)) return false;
|
||||||
|
|
||||||
// now assign memory to out accounting for data, and cipher block size, key length, and key length val
|
// now assign memory to out accounting for data, and cipher block size, key length, and key length val
|
||||||
out = (uint8_t*)malloc(inlen + cipher_block_size + size_net_ekl + eklen + EVP_MAX_IV_LENGTH);
|
out = (uint8_t*)rs_malloc(inlen + cipher_block_size + size_net_ekl + eklen + EVP_MAX_IV_LENGTH);
|
||||||
|
|
||||||
if(out == NULL)
|
if(out == NULL)
|
||||||
{
|
|
||||||
std::cerr << "gxssecurity::encrypt(): cnnot allocate memory of size " << inlen + cipher_block_size + size_net_ekl + eklen + EVP_MAX_IV_LENGTH << " to encrypt data." << std::endl;
|
|
||||||
return false ;
|
return false ;
|
||||||
}
|
|
||||||
|
|
||||||
net_ekl = htonl(eklen);
|
net_ekl = htonl(eklen);
|
||||||
memcpy((unsigned char*)out + out_offset, &net_ekl, size_net_ekl);
|
memcpy((unsigned char*)out + out_offset, &net_ekl, size_net_ekl);
|
||||||
@ -540,7 +541,11 @@ bool GxsSecurity::decrypt(uint8_t *& out, uint32_t & outlen, const uint8_t *in,
|
|||||||
|
|
||||||
EVP_CIPHER_CTX ctx;
|
EVP_CIPHER_CTX ctx;
|
||||||
int eklen = 0, net_ekl = 0;
|
int eklen = 0, net_ekl = 0;
|
||||||
unsigned char *ek = (unsigned char*)malloc(EVP_PKEY_size(privateKey));
|
unsigned char *ek = (unsigned char*)rs_malloc(EVP_PKEY_size(privateKey));
|
||||||
|
|
||||||
|
if(ek == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
unsigned char iv[EVP_MAX_IV_LENGTH];
|
unsigned char iv[EVP_MAX_IV_LENGTH];
|
||||||
EVP_CIPHER_CTX_init(&ctx);
|
EVP_CIPHER_CTX_init(&ctx);
|
||||||
|
|
||||||
@ -574,13 +579,10 @@ bool GxsSecurity::decrypt(uint8_t *& out, uint32_t & outlen, const uint8_t *in,
|
|||||||
std::cerr << "Severe error in " << __PRETTY_FUNCTION__ << ": cannot encrypt. " << std::endl;
|
std::cerr << "Severe error in " << __PRETTY_FUNCTION__ << ": cannot encrypt. " << std::endl;
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
out = (uint8_t*)malloc(inlen - in_offset);
|
out = (uint8_t*)rs_malloc(inlen - in_offset);
|
||||||
|
|
||||||
if(out == NULL)
|
if(out == NULL)
|
||||||
{
|
|
||||||
std::cerr << "gxssecurity::decrypt(): cannot allocate memory of size " << inlen - in_offset << " to decrypt data." << std::endl;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
if(!EVP_OpenUpdate(&ctx, (unsigned char*) out, &out_currOffset, (unsigned char*)in + in_offset, inlen - in_offset))
|
if(!EVP_OpenUpdate(&ctx, (unsigned char*) out, &out_currOffset, (unsigned char*)in + in_offset, inlen - in_offset))
|
||||||
{
|
{
|
||||||
|
@ -1666,7 +1666,9 @@ void RsGxsNetService::data_tick()
|
|||||||
if(mUpdateCounter >= 120) // 60 seconds
|
if(mUpdateCounter >= 120) // 60 seconds
|
||||||
{
|
{
|
||||||
updateServerSyncTS();
|
updateServerSyncTS();
|
||||||
|
#ifdef TO_REMOVE
|
||||||
updateClientSyncTS();
|
updateClientSyncTS();
|
||||||
|
#endif
|
||||||
mUpdateCounter = 1;
|
mUpdateCounter = 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1724,6 +1726,7 @@ void RsGxsNetService::debugDump()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef TO_REMOVE
|
||||||
// This method is normally not needed, but we use it to correct possible inconsistencies in the updte time stamps
|
// This method is normally not needed, but we use it to correct possible inconsistencies in the updte time stamps
|
||||||
// on the client side.
|
// on the client side.
|
||||||
|
|
||||||
@ -1761,6 +1764,7 @@ void RsGxsNetService::updateClientSyncTS()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void RsGxsNetService::updateServerSyncTS()
|
void RsGxsNetService::updateServerSyncTS()
|
||||||
{
|
{
|
||||||
@ -2935,6 +2939,24 @@ void RsGxsNetService::locked_genReqGrpTransaction(NxsTransaction* tr)
|
|||||||
|
|
||||||
if(!reqList.empty())
|
if(!reqList.empty())
|
||||||
locked_pushGrpTransactionFromList(reqList, tr->mTransaction->PeerId(), transN);
|
locked_pushGrpTransactionFromList(reqList, tr->mTransaction->PeerId(), transN);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ClientGrpMap::iterator it = mClientGrpUpdateMap.find(tr->mTransaction->PeerId());
|
||||||
|
RsGxsGrpUpdateItem* item = NULL;
|
||||||
|
if(it != mClientGrpUpdateMap.end())
|
||||||
|
item = it->second;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
item = new RsGxsGrpUpdateItem(mServType);
|
||||||
|
mClientGrpUpdateMap.insert(std::make_pair(tr->mTransaction->PeerId(), item));
|
||||||
|
}
|
||||||
|
#ifdef NXS_NET_DEBUG_0
|
||||||
|
GXSNETDEBUG_P_(tr->mTransaction->PeerId()) << " reqList is empty, updating anyway ClientGrpUpdate TS for peer " << tr->mTransaction->PeerId() << " to: " << tr->mTransaction->updateTS << std::endl;
|
||||||
|
#endif
|
||||||
|
item->grpUpdateTS = tr->mTransaction->updateTS;
|
||||||
|
item->peerId = tr->mTransaction->PeerId();
|
||||||
|
IndicateConfigChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RsGxsNetService::locked_genSendGrpsTransaction(NxsTransaction* tr)
|
void RsGxsNetService::locked_genSendGrpsTransaction(NxsTransaction* tr)
|
||||||
@ -3266,6 +3288,10 @@ void RsGxsNetService::locked_pushGrpRespFromList(std::list<RsNxsItem*>& respList
|
|||||||
trItem->timestamp = 0;
|
trItem->timestamp = 0;
|
||||||
trItem->PeerId(peer);
|
trItem->PeerId(peer);
|
||||||
trItem->transactionNumber = transN;
|
trItem->transactionNumber = transN;
|
||||||
|
#ifdef NXS_NET_DEBUG_0
|
||||||
|
GXSNETDEBUG_P_ (peer) << "Setting tr->mTransaction->updateTS to " << mGrpServerUpdateItem->grpUpdateTS << std::endl;
|
||||||
|
#endif
|
||||||
|
trItem->updateTS = mGrpServerUpdateItem->grpUpdateTS;
|
||||||
// also make a copy for the resident transaction
|
// also make a copy for the resident transaction
|
||||||
tr->mTransaction = new RsNxsTransac(*trItem);
|
tr->mTransaction = new RsNxsTransac(*trItem);
|
||||||
tr->mTransaction->PeerId(mOwnId);
|
tr->mTransaction->PeerId(mOwnId);
|
||||||
|
@ -378,7 +378,9 @@ private:
|
|||||||
void locked_doMsgUpdateWork(const RsNxsTransac* nxsTrans, const RsGxsGroupId& grpId);
|
void locked_doMsgUpdateWork(const RsNxsTransac* nxsTrans, const RsGxsGroupId& grpId);
|
||||||
|
|
||||||
void updateServerSyncTS();
|
void updateServerSyncTS();
|
||||||
|
#ifdef TO_REMOVE
|
||||||
void updateClientSyncTS();
|
void updateClientSyncTS();
|
||||||
|
#endif
|
||||||
|
|
||||||
bool locked_CanReceiveUpdate(const RsNxsSyncGrp* item);
|
bool locked_CanReceiveUpdate(const RsNxsSyncGrp* item);
|
||||||
bool locked_CanReceiveUpdate(const RsNxsSyncMsg* item);
|
bool locked_CanReceiveUpdate(const RsNxsSyncMsg* item);
|
||||||
|
@ -856,7 +856,7 @@ void p3GxsTunnelService::handleRecvDHPublicKey(RsGxsTunnelDHPublicKeyItem *item)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint32_t pubkey_size = BN_num_bytes(item->public_key) ;
|
uint32_t pubkey_size = BN_num_bytes(item->public_key) ;
|
||||||
unsigned char *data = (unsigned char *)malloc(pubkey_size) ;
|
RsTemporaryMemory data(pubkey_size) ;
|
||||||
BN_bn2bin(item->public_key, data) ;
|
BN_bn2bin(item->public_key, data) ;
|
||||||
|
|
||||||
RsTlvSecurityKey signature_key ;
|
RsTlvSecurityKey signature_key ;
|
||||||
@ -901,7 +901,7 @@ void p3GxsTunnelService::handleRecvDHPublicKey(RsGxsTunnelDHPublicKeyItem *item)
|
|||||||
signature_key = item->gxs_key ;
|
signature_key = item->gxs_key ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!GxsSecurity::validateSignature((char*)data,pubkey_size,signature_key,item->signature))
|
if(!GxsSecurity::validateSignature((char*)(unsigned char*)data,pubkey_size,signature_key,item->signature))
|
||||||
{
|
{
|
||||||
std::cerr << "(SS) Signature was verified and it doesn't check! This is a security issue!" << std::endl;
|
std::cerr << "(SS) Signature was verified and it doesn't check! This is a security issue!" << std::endl;
|
||||||
return ;
|
return ;
|
||||||
@ -939,7 +939,7 @@ void p3GxsTunnelService::handleRecvDHPublicKey(RsGxsTunnelDHPublicKeyItem *item)
|
|||||||
// Looks for the DH params. If not there yet, create them.
|
// Looks for the DH params. If not there yet, create them.
|
||||||
//
|
//
|
||||||
int size = DH_size(it->second.dh) ;
|
int size = DH_size(it->second.dh) ;
|
||||||
unsigned char *key_buff = new unsigned char[size] ;
|
RsTemporaryMemory key_buff(size) ;
|
||||||
|
|
||||||
if(size != DH_compute_key(key_buff,item->public_key,it->second.dh))
|
if(size != DH_compute_key(key_buff,item->public_key,it->second.dh))
|
||||||
{
|
{
|
||||||
@ -959,7 +959,6 @@ void p3GxsTunnelService::handleRecvDHPublicKey(RsGxsTunnelDHPublicKeyItem *item)
|
|||||||
|
|
||||||
assert(GXS_TUNNEL_AES_KEY_SIZE <= Sha1CheckSum::SIZE_IN_BYTES) ;
|
assert(GXS_TUNNEL_AES_KEY_SIZE <= Sha1CheckSum::SIZE_IN_BYTES) ;
|
||||||
memcpy(pinfo.aes_key, RsDirUtil::sha1sum(key_buff,size).toByteArray(),GXS_TUNNEL_AES_KEY_SIZE) ;
|
memcpy(pinfo.aes_key, RsDirUtil::sha1sum(key_buff,size).toByteArray(),GXS_TUNNEL_AES_KEY_SIZE) ;
|
||||||
delete[] key_buff ;
|
|
||||||
|
|
||||||
pinfo.last_contact = time(NULL) ;
|
pinfo.last_contact = time(NULL) ;
|
||||||
pinfo.last_keep_alive_sent = time(NULL) ;
|
pinfo.last_keep_alive_sent = time(NULL) ;
|
||||||
@ -1036,7 +1035,15 @@ bool p3GxsTunnelService::locked_sendDHPublicKey(const DH *dh,const RsGxsId& own_
|
|||||||
uint32_t error_status ;
|
uint32_t error_status ;
|
||||||
|
|
||||||
uint32_t size = BN_num_bytes(dhitem->public_key) ;
|
uint32_t size = BN_num_bytes(dhitem->public_key) ;
|
||||||
unsigned char *data = (unsigned char *)malloc(size) ;
|
|
||||||
|
RsTemporaryMemory data(size) ;
|
||||||
|
|
||||||
|
if(data == NULL)
|
||||||
|
{
|
||||||
|
delete(dhitem);
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
|
|
||||||
BN_bn2bin(dhitem->public_key, data) ;
|
BN_bn2bin(dhitem->public_key, data) ;
|
||||||
|
|
||||||
if(!mGixs->signData((unsigned char*)data,size,own_gxs_id,signature,error_status))
|
if(!mGixs->signData((unsigned char*)data,size,own_gxs_id,signature,error_status))
|
||||||
@ -1048,11 +1055,9 @@ bool p3GxsTunnelService::locked_sendDHPublicKey(const DH *dh,const RsGxsId& own_
|
|||||||
default: std::cerr << "(EE) Unknown error when signing" << std::endl;
|
default: std::cerr << "(EE) Unknown error when signing" << std::endl;
|
||||||
break ;
|
break ;
|
||||||
}
|
}
|
||||||
free(data) ;
|
|
||||||
delete(dhitem);
|
delete(dhitem);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
free(data) ;
|
|
||||||
|
|
||||||
if(!mGixs->getKey(own_gxs_id,signature_key_public))
|
if(!mGixs->getKey(own_gxs_id,signature_key_public))
|
||||||
{
|
{
|
||||||
@ -1136,8 +1141,13 @@ bool p3GxsTunnelService::locked_sendClearTunnelData(RsGxsTunnelDHPublicKeyItem *
|
|||||||
uint32_t rssize = item->serial_size() ;
|
uint32_t rssize = item->serial_size() ;
|
||||||
|
|
||||||
gitem->data_size = rssize + 8 ;
|
gitem->data_size = rssize + 8 ;
|
||||||
gitem->data_bytes = malloc(rssize+8) ;
|
gitem->data_bytes = rs_malloc(rssize+8) ;
|
||||||
|
|
||||||
|
if(gitem->data_bytes == NULL)
|
||||||
|
{
|
||||||
|
delete gitem ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
// by convention, we use a IV of 0 for unencrypted data.
|
// by convention, we use a IV of 0 for unencrypted data.
|
||||||
memset(gitem->data_bytes,0,8) ;
|
memset(gitem->data_bytes,0,8) ;
|
||||||
|
|
||||||
@ -1221,7 +1231,10 @@ bool p3GxsTunnelService::locked_sendEncryptedTunnelData(RsGxsTunnelItem *item)
|
|||||||
RsTurtleGenericDataItem *gitem = new RsTurtleGenericDataItem ;
|
RsTurtleGenericDataItem *gitem = new RsTurtleGenericDataItem ;
|
||||||
|
|
||||||
gitem->data_size = encrypted_size + GXS_TUNNEL_ENCRYPTION_IV_SIZE + GXS_TUNNEL_ENCRYPTION_HMAC_SIZE ;
|
gitem->data_size = encrypted_size + GXS_TUNNEL_ENCRYPTION_IV_SIZE + GXS_TUNNEL_ENCRYPTION_HMAC_SIZE ;
|
||||||
gitem->data_bytes = malloc(gitem->data_size) ;
|
gitem->data_bytes = rs_malloc(gitem->data_size) ;
|
||||||
|
|
||||||
|
if(gitem->data_bytes == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
memcpy(& ((uint8_t*)gitem->data_bytes)[0] ,&IV,8) ;
|
memcpy(& ((uint8_t*)gitem->data_bytes)[0] ,&IV,8) ;
|
||||||
|
|
||||||
@ -1316,7 +1329,11 @@ bool p3GxsTunnelService::sendData(const RsGxsTunnelId &tunnel_id, uint32_t servi
|
|||||||
item->flags = 0; // not used yet.
|
item->flags = 0; // not used yet.
|
||||||
item->service_id = service_id;
|
item->service_id = service_id;
|
||||||
item->data_size = size; // encrypted data size
|
item->data_size = size; // encrypted data size
|
||||||
item->data = (uint8_t*)malloc(size); // encrypted data
|
item->data = (uint8_t*)rs_malloc(size); // encrypted data
|
||||||
|
|
||||||
|
if(item->data == NULL)
|
||||||
|
delete item ;
|
||||||
|
|
||||||
item->PeerId(RsPeerId(tunnel_id)) ;
|
item->PeerId(RsPeerId(tunnel_id)) ;
|
||||||
memcpy(item->data,data,size) ;
|
memcpy(item->data,data,size) ;
|
||||||
|
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
#include "serialiser/rsbaseserial.h"
|
#include "serialiser/rsbaseserial.h"
|
||||||
#include "serialiser/rstlvbase.h"
|
#include "serialiser/rstlvbase.h"
|
||||||
#include "util/rsprint.h"
|
#include "util/rsprint.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
#include "gxstunnel/rsgxstunnelitems.h"
|
#include "gxstunnel/rsgxstunnelitems.h"
|
||||||
|
|
||||||
@ -343,6 +344,13 @@ RsGxsTunnelDHPublicKeyItem *RsGxsTunnelSerialiser::deserialise_RsGxsTunnelDHPubl
|
|||||||
/* get mandatory parts first */
|
/* get mandatory parts first */
|
||||||
ok &= getRawUInt32(data, rssize, &offset, &s);
|
ok &= getRawUInt32(data, rssize, &offset, &s);
|
||||||
|
|
||||||
|
if(s > rssize || rssize - s < offset)
|
||||||
|
{
|
||||||
|
std::cerr << "RsGxsTunnelDHPublicKeyItem::() Size error while deserializing." << std::endl ;
|
||||||
|
delete item ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
|
||||||
item->public_key = BN_bin2bn(&((unsigned char *)data)[offset],s,NULL) ;
|
item->public_key = BN_bin2bn(&((unsigned char *)data)[offset],s,NULL) ;
|
||||||
offset += s ;
|
offset += s ;
|
||||||
|
|
||||||
@ -380,11 +388,15 @@ RsGxsTunnelDataItem *RsGxsTunnelSerialiser::deserialise_RsGxsTunnelDataItem(void
|
|||||||
ok &= getRawUInt32(dat, rssize, &offset, &item->service_id);
|
ok &= getRawUInt32(dat, rssize, &offset, &item->service_id);
|
||||||
ok &= getRawUInt32(dat, rssize, &offset, &item->data_size);
|
ok &= getRawUInt32(dat, rssize, &offset, &item->data_size);
|
||||||
|
|
||||||
if(offset + item->data_size <= size)
|
if(item->data_size > rssize || rssize - item->data_size < offset)
|
||||||
{
|
{
|
||||||
item->data = (unsigned char*)malloc(item->data_size) ;
|
std::cerr << "RsGxsTunnelDHPublicKeyItem::() Size error while deserializing." << std::endl ;
|
||||||
|
delete item ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
item->data = (unsigned char*)rs_malloc(item->data_size) ;
|
||||||
|
|
||||||
if(dat == NULL)
|
if(item->data == NULL)
|
||||||
{
|
{
|
||||||
delete item ;
|
delete item ;
|
||||||
return NULL ;
|
return NULL ;
|
||||||
@ -392,9 +404,6 @@ RsGxsTunnelDataItem *RsGxsTunnelSerialiser::deserialise_RsGxsTunnelDataItem(void
|
|||||||
|
|
||||||
memcpy(item->data,&((uint8_t*)dat)[offset],item->data_size) ;
|
memcpy(item->data,&((uint8_t*)dat)[offset],item->data_size) ;
|
||||||
offset += item->data_size ;
|
offset += item->data_size ;
|
||||||
}
|
|
||||||
else
|
|
||||||
ok = false ;
|
|
||||||
|
|
||||||
|
|
||||||
if (offset != rssize)
|
if (offset != rssize)
|
||||||
|
@ -361,7 +361,6 @@ HEADERS += chat/distantchat.h \
|
|||||||
|
|
||||||
HEADERS += pqi/authssl.h \
|
HEADERS += pqi/authssl.h \
|
||||||
pqi/authgpg.h \
|
pqi/authgpg.h \
|
||||||
pqi/rsmemory.h \
|
|
||||||
pgp/pgphandler.h \
|
pgp/pgphandler.h \
|
||||||
pgp/pgpkeyutil.h \
|
pgp/pgpkeyutil.h \
|
||||||
pgp/rsaes.h \
|
pgp/rsaes.h \
|
||||||
@ -475,6 +474,7 @@ HEADERS += turtle/p3turtle.h \
|
|||||||
|
|
||||||
HEADERS += util/folderiterator.h \
|
HEADERS += util/folderiterator.h \
|
||||||
util/rsdebug.h \
|
util/rsdebug.h \
|
||||||
|
util/rsmemory.h \
|
||||||
util/rscompress.h \
|
util/rscompress.h \
|
||||||
util/smallobject.h \
|
util/smallobject.h \
|
||||||
util/rsdir.h \
|
util/rsdir.h \
|
||||||
@ -631,6 +631,7 @@ SOURCES += util/folderiterator.cc \
|
|||||||
util/rscompress.cc \
|
util/rscompress.cc \
|
||||||
util/smallobject.cc \
|
util/smallobject.cc \
|
||||||
util/rsdir.cc \
|
util/rsdir.cc \
|
||||||
|
util/rsmemory.cc \
|
||||||
util/rsdiscspace.cc \
|
util/rsdiscspace.cc \
|
||||||
util/rsnet.cc \
|
util/rsnet.cc \
|
||||||
util/rsnet_ss.cc \
|
util/rsnet_ss.cc \
|
||||||
|
@ -26,6 +26,7 @@ extern "C" {
|
|||||||
#include "retroshare/rspeers.h" // For rsicontrol.
|
#include "retroshare/rspeers.h" // For rsicontrol.
|
||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
#include "util/rsdiscspace.h"
|
#include "util/rsdiscspace.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "pgp/pgpkeyutil.h"
|
#include "pgp/pgpkeyutil.h"
|
||||||
|
|
||||||
static const uint32_t PGP_CERTIFICATE_LIMIT_MAX_NAME_SIZE = 64 ;
|
static const uint32_t PGP_CERTIFICATE_LIMIT_MAX_NAME_SIZE = 64 ;
|
||||||
@ -39,7 +40,11 @@ PassphraseCallback PGPHandler::_passphrase_callback = NULL ;
|
|||||||
|
|
||||||
ops_keyring_t *PGPHandler::allocateOPSKeyring()
|
ops_keyring_t *PGPHandler::allocateOPSKeyring()
|
||||||
{
|
{
|
||||||
ops_keyring_t *kr = (ops_keyring_t*)malloc(sizeof(ops_keyring_t)) ;
|
ops_keyring_t *kr = (ops_keyring_t*)rs_malloc(sizeof(ops_keyring_t)) ;
|
||||||
|
|
||||||
|
if(kr == NULL)
|
||||||
|
return NULL ;
|
||||||
|
|
||||||
kr->nkeys = 0 ;
|
kr->nkeys = 0 ;
|
||||||
kr->nkeys_allocated = 0 ;
|
kr->nkeys_allocated = 0 ;
|
||||||
kr->keys = 0 ;
|
kr->keys = 0 ;
|
||||||
|
@ -117,10 +117,10 @@ static struct CRYPTO_dynlock_value *dyn_create_function(const char */*file*/, in
|
|||||||
{
|
{
|
||||||
struct CRYPTO_dynlock_value *value;
|
struct CRYPTO_dynlock_value *value;
|
||||||
|
|
||||||
value = (struct CRYPTO_dynlock_value*) malloc(sizeof(struct CRYPTO_dynlock_value));
|
value = (struct CRYPTO_dynlock_value*) rs_malloc(sizeof(struct CRYPTO_dynlock_value));
|
||||||
if (!value) {
|
if (!value)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
pthread_mutex_init(&value->mutex, NULL);
|
pthread_mutex_init(&value->mutex, NULL);
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
@ -166,10 +166,10 @@ static void dyn_destroy_function(struct CRYPTO_dynlock_value *l, const char */*f
|
|||||||
bool tls_init()
|
bool tls_init()
|
||||||
{
|
{
|
||||||
/* static locks area */
|
/* static locks area */
|
||||||
mutex_buf = (pthread_mutex_t*) malloc(CRYPTO_num_locks() * sizeof(pthread_mutex_t));
|
mutex_buf = (pthread_mutex_t*) rs_malloc(CRYPTO_num_locks() * sizeof(pthread_mutex_t));
|
||||||
if (mutex_buf == NULL) {
|
if (mutex_buf == NULL)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
for (int i = 0; i < CRYPTO_num_locks(); i++) {
|
for (int i = 0; i < CRYPTO_num_locks(); i++) {
|
||||||
pthread_mutex_init(&mutex_buf[i], NULL);
|
pthread_mutex_init(&mutex_buf[i], NULL);
|
||||||
}
|
}
|
||||||
@ -1259,7 +1259,11 @@ bool AuthSSLimpl::encrypt(void *&out, int &outlen, const void *in, int inlen,
|
|||||||
int out_offset = 0;
|
int out_offset = 0;
|
||||||
|
|
||||||
int max_evp_key_size = EVP_PKEY_size(public_key);
|
int max_evp_key_size = EVP_PKEY_size(public_key);
|
||||||
ek = (unsigned char*)malloc(max_evp_key_size);
|
ek = (unsigned char*)rs_malloc(max_evp_key_size);
|
||||||
|
|
||||||
|
if(ek == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
const EVP_CIPHER *cipher = EVP_aes_128_cbc();
|
const EVP_CIPHER *cipher = EVP_aes_128_cbc();
|
||||||
int cipher_block_size = EVP_CIPHER_block_size(cipher);
|
int cipher_block_size = EVP_CIPHER_block_size(cipher);
|
||||||
int size_net_ekl = sizeof(net_ekl);
|
int size_net_ekl = sizeof(net_ekl);
|
||||||
@ -1273,8 +1277,13 @@ bool AuthSSLimpl::encrypt(void *&out, int &outlen, const void *in, int inlen,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// now assign memory to out accounting for data, and cipher block size, key length, and key length val
|
// now assign memory to out accounting for data, and cipher block size, key length, and key length val
|
||||||
out = (unsigned char*)malloc(inlen + cipher_block_size + size_net_ekl + eklen + EVP_MAX_IV_LENGTH);
|
out = (unsigned char*)rs_malloc(inlen + cipher_block_size + size_net_ekl + eklen + EVP_MAX_IV_LENGTH);
|
||||||
|
|
||||||
|
if(out == NULL)
|
||||||
|
{
|
||||||
|
free(ek) ;
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
net_ekl = htonl(eklen);
|
net_ekl = htonl(eklen);
|
||||||
memcpy((unsigned char*)out + out_offset, &net_ekl, size_net_ekl);
|
memcpy((unsigned char*)out + out_offset, &net_ekl, size_net_ekl);
|
||||||
out_offset += size_net_ekl;
|
out_offset += size_net_ekl;
|
||||||
@ -1343,6 +1352,12 @@ bool AuthSSLimpl::decrypt(void *&out, int &outlen, const void *in, int inlen)
|
|||||||
unsigned char iv[EVP_MAX_IV_LENGTH];
|
unsigned char iv[EVP_MAX_IV_LENGTH];
|
||||||
int ek_mkl = EVP_PKEY_size(mOwnPrivateKey);
|
int ek_mkl = EVP_PKEY_size(mOwnPrivateKey);
|
||||||
ek = (unsigned char*)malloc(ek_mkl);
|
ek = (unsigned char*)malloc(ek_mkl);
|
||||||
|
|
||||||
|
if(ek == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Cannot allocate memory for " << ek_mkl << " bytes in " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
EVP_CIPHER_CTX_init(&ctx);
|
EVP_CIPHER_CTX_init(&ctx);
|
||||||
|
|
||||||
int in_offset = 0, out_currOffset = 0;
|
int in_offset = 0, out_currOffset = 0;
|
||||||
@ -1380,8 +1395,13 @@ bool AuthSSLimpl::decrypt(void *&out, int &outlen, const void *in, int inlen)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
out = (unsigned char*)malloc(inlen - in_offset);
|
out = (unsigned char*)rs_malloc(inlen - in_offset);
|
||||||
|
|
||||||
|
if(out == NULL)
|
||||||
|
{
|
||||||
|
free(ek) ;
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
if(!EVP_OpenUpdate(&ctx, (unsigned char*) out, &out_currOffset, (unsigned char*)in + in_offset, inlen - in_offset)) {
|
if(!EVP_OpenUpdate(&ctx, (unsigned char*) out, &out_currOffset, (unsigned char*)in + in_offset, inlen - in_offset)) {
|
||||||
free(ek);
|
free(ek);
|
||||||
free(out) ;
|
free(out) ;
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "pqi/authssl.h"
|
#include "pqi/authssl.h"
|
||||||
#include "util/rsnet.h"
|
#include "util/rsnet.h"
|
||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
// #define DEBUG_PQIBIN
|
// #define DEBUG_PQIBIN
|
||||||
|
|
||||||
@ -314,7 +315,13 @@ BinMemInterface::BinMemInterface(int defsize, int flags)
|
|||||||
:bin_flags(flags), buf(NULL), size(defsize),
|
:bin_flags(flags), buf(NULL), size(defsize),
|
||||||
recvsize(0), readloc(0), hash(NULL), bcount(0)
|
recvsize(0), readloc(0), hash(NULL), bcount(0)
|
||||||
{
|
{
|
||||||
buf = malloc(defsize);
|
buf = rs_malloc(defsize);
|
||||||
|
|
||||||
|
if(buf == NULL)
|
||||||
|
{
|
||||||
|
close() ;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
if (bin_flags & BIN_FLAGS_HASH_DATA)
|
if (bin_flags & BIN_FLAGS_HASH_DATA)
|
||||||
{
|
{
|
||||||
hash = new pqihash();
|
hash = new pqihash();
|
||||||
@ -326,7 +333,13 @@ BinMemInterface::BinMemInterface(const void *data, const int defsize, int flags)
|
|||||||
:bin_flags(flags), buf(NULL), size(defsize),
|
:bin_flags(flags), buf(NULL), size(defsize),
|
||||||
recvsize(0), readloc(0), hash(NULL), bcount(0)
|
recvsize(0), readloc(0), hash(NULL), bcount(0)
|
||||||
{
|
{
|
||||||
buf = malloc(defsize);
|
buf = rs_malloc(defsize);
|
||||||
|
|
||||||
|
if(buf == NULL)
|
||||||
|
{
|
||||||
|
close() ;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
if (bin_flags & BIN_FLAGS_HASH_DATA)
|
if (bin_flags & BIN_FLAGS_HASH_DATA)
|
||||||
{
|
{
|
||||||
hash = new pqihash();
|
hash = new pqihash();
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#ifdef WINDOWS_SYS
|
#ifdef WINDOWS_SYS
|
||||||
#include "util/rswin.h"
|
#include "util/rswin.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include <ws2tcpip.h>
|
#include <ws2tcpip.h>
|
||||||
#endif // WINDOWS_SYS
|
#endif // WINDOWS_SYS
|
||||||
|
|
||||||
@ -290,7 +291,11 @@ bool getLocalAddresses(std::list<sockaddr_storage> & addrs)
|
|||||||
#ifdef WINDOWS_SYS
|
#ifdef WINDOWS_SYS
|
||||||
// Seems strange to me but M$ documentation suggests to allocate this way...
|
// Seems strange to me but M$ documentation suggests to allocate this way...
|
||||||
DWORD bf_size = 16000;
|
DWORD bf_size = 16000;
|
||||||
IP_ADAPTER_ADDRESSES* adapter_addresses = (IP_ADAPTER_ADDRESSES*) malloc(bf_size);
|
IP_ADAPTER_ADDRESSES* adapter_addresses = (IP_ADAPTER_ADDRESSES*) rs_malloc(bf_size);
|
||||||
|
|
||||||
|
if(adapter_addresses == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
DWORD error = GetAdaptersAddresses(AF_UNSPEC,
|
DWORD error = GetAdaptersAddresses(AF_UNSPEC,
|
||||||
GAA_FLAG_SKIP_MULTICAST |
|
GAA_FLAG_SKIP_MULTICAST |
|
||||||
GAA_FLAG_SKIP_DNS_SERVER |
|
GAA_FLAG_SKIP_DNS_SERVER |
|
||||||
|
@ -46,6 +46,7 @@
|
|||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
|
||||||
#include "util/rsdebug.h"
|
#include "util/rsdebug.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "util/rsstring.h"
|
#include "util/rsstring.h"
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -194,7 +195,12 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint32_t pktsize = rsSerialiser->size(pqi);
|
uint32_t pktsize = rsSerialiser->size(pqi);
|
||||||
void *ptr = malloc(pktsize);
|
|
||||||
|
RsTemporaryMemory ptr(pktsize) ;
|
||||||
|
|
||||||
|
if(ptr == NULL)
|
||||||
|
return 0 ;
|
||||||
|
|
||||||
if (!(rsSerialiser->serialise(pqi, ptr, &pktsize)))
|
if (!(rsSerialiser->serialise(pqi, ptr, &pktsize)))
|
||||||
{
|
{
|
||||||
#ifdef PQISTORE_DEBUG
|
#ifdef PQISTORE_DEBUG
|
||||||
@ -203,7 +209,6 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
pqioutput(PQL_ALERT, pqistorezone, out);
|
pqioutput(PQL_ALERT, pqistorezone, out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
free(ptr);
|
|
||||||
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
||||||
delete pqi;
|
delete pqi;
|
||||||
return 0;
|
return 0;
|
||||||
@ -218,7 +223,6 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
pqi -> print_string(out);
|
pqi -> print_string(out);
|
||||||
pqioutput(PQL_ALERT, pqistorezone, out);
|
pqioutput(PQL_ALERT, pqistorezone, out);
|
||||||
|
|
||||||
free(ptr);
|
|
||||||
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
||||||
delete pqi;
|
delete pqi;
|
||||||
return 0;
|
return 0;
|
||||||
@ -232,7 +236,6 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
pqi -> print_string(out);
|
pqi -> print_string(out);
|
||||||
pqioutput(PQL_ALERT, pqistorezone, out);
|
pqioutput(PQL_ALERT, pqistorezone, out);
|
||||||
|
|
||||||
free(ptr);
|
|
||||||
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
||||||
delete pqi;
|
delete pqi;
|
||||||
|
|
||||||
@ -250,7 +253,6 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
pqioutput(PQL_ALERT, pqistorezone, out);
|
pqioutput(PQL_ALERT, pqistorezone, out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
free(ptr);
|
|
||||||
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
||||||
delete pqi;
|
delete pqi;
|
||||||
|
|
||||||
@ -262,7 +264,6 @@ int pqistore::writePkt(RsItem *pqi)
|
|||||||
pqioutput(PQL_DEBUG_BASIC, pqistorezone, out);
|
pqioutput(PQL_DEBUG_BASIC, pqistorezone, out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
free(ptr);
|
|
||||||
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
if (!(bio_flags & BIN_FLAGS_NO_DELETE))
|
||||||
delete pqi;
|
delete pqi;
|
||||||
|
|
||||||
@ -288,7 +289,10 @@ int pqistore::readPkt(RsItem **item_out)
|
|||||||
|
|
||||||
// initial read size: basic packet.
|
// initial read size: basic packet.
|
||||||
int blen = getRsPktBaseSize();
|
int blen = getRsPktBaseSize();
|
||||||
void *block = malloc(blen);
|
void *block = rs_malloc(blen);
|
||||||
|
|
||||||
|
if(block == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
int tmplen;
|
int tmplen;
|
||||||
/* we have the header */
|
/* we have the header */
|
||||||
@ -495,7 +499,10 @@ int pqiSSLstore::readPkt(RsItem **item_out)
|
|||||||
|
|
||||||
// initial read size: basic packet.
|
// initial read size: basic packet.
|
||||||
int blen = getRsPktBaseSize();
|
int blen = getRsPktBaseSize();
|
||||||
void *block = malloc(blen);
|
void *block = rs_malloc(blen);
|
||||||
|
|
||||||
|
if(block == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
int tmplen;
|
int tmplen;
|
||||||
/* we have the header */
|
/* we have the header */
|
||||||
|
@ -315,7 +315,11 @@ int pqistreamer::queue_outpqi_locked(RsItem *pqi,uint32_t& pktsize)
|
|||||||
/* decide which type of packet it is */
|
/* decide which type of packet it is */
|
||||||
|
|
||||||
pktsize = mRsSerialiser->size(pqi);
|
pktsize = mRsSerialiser->size(pqi);
|
||||||
void *ptr = malloc(pktsize);
|
void *ptr = rs_malloc(pktsize);
|
||||||
|
|
||||||
|
if(ptr == NULL)
|
||||||
|
return 0 ;
|
||||||
|
|
||||||
|
|
||||||
#ifdef DEBUG_PQISTREAMER
|
#ifdef DEBUG_PQISTREAMER
|
||||||
std::cerr << "pqistreamer::queue_outpqi() serializing packet with packet size : " << pktsize << std::endl;
|
std::cerr << "pqistreamer::queue_outpqi() serializing packet with packet size : " << pktsize << std::endl;
|
||||||
@ -471,6 +475,7 @@ int pqistreamer::handleoutgoing_locked()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#define GROUP_OUTGOING_PACKETS 1
|
#define GROUP_OUTGOING_PACKETS 1
|
||||||
|
#define PACKET_GROUPING_SIZE_LIMIT 32768
|
||||||
// send a out_pkt., else send out_data. unless
|
// send a out_pkt., else send out_data. unless
|
||||||
// there is a pending packet.
|
// there is a pending packet.
|
||||||
if (!mPkt_wpending)
|
if (!mPkt_wpending)
|
||||||
@ -480,7 +485,7 @@ int pqistreamer::handleoutgoing_locked()
|
|||||||
mPkt_wpending_size = 0 ;
|
mPkt_wpending_size = 0 ;
|
||||||
int k=0;
|
int k=0;
|
||||||
|
|
||||||
while(mPkt_wpending_size < maxbytes && (dta = locked_pop_out_data())!=NULL )
|
while(mPkt_wpending_size < (uint32_t)maxbytes && mPkt_wpending_size < PACKET_GROUPING_SIZE_LIMIT && (dta = locked_pop_out_data())!=NULL )
|
||||||
{
|
{
|
||||||
uint32_t s = getRsItemSize(dta);
|
uint32_t s = getRsItemSize(dta);
|
||||||
mPkt_wpending = realloc(mPkt_wpending,s+mPkt_wpending_size) ;
|
mPkt_wpending = realloc(mPkt_wpending,s+mPkt_wpending_size) ;
|
||||||
@ -1040,7 +1045,10 @@ void pqistreamer::allocate_rpend_locked()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
mPkt_rpend_size = getRsPktMaxSize();
|
mPkt_rpend_size = getRsPktMaxSize();
|
||||||
mPkt_rpending = malloc(mPkt_rpend_size);
|
mPkt_rpending = rs_malloc(mPkt_rpend_size);
|
||||||
|
|
||||||
|
if(mPkt_rpending == NULL)
|
||||||
|
return ;
|
||||||
|
|
||||||
// avoid uninitialized (and random) memory read.
|
// avoid uninitialized (and random) memory read.
|
||||||
memset(mPkt_rpending,0,mPkt_rpend_size) ;
|
memset(mPkt_rpending,0,mPkt_rpend_size) ;
|
||||||
|
@ -160,7 +160,7 @@ class RsPlugin
|
|||||||
// creates a new resource api handler object. ownership is transferred to the caller.
|
// creates a new resource api handler object. ownership is transferred to the caller.
|
||||||
// the caller should supply a statetokenserver, and keep it valid until destruction
|
// the caller should supply a statetokenserver, and keep it valid until destruction
|
||||||
// the plugin should return a entry point name. this is to make the entry point name independent from file names
|
// the plugin should return a entry point name. this is to make the entry point name independent from file names
|
||||||
virtual resource_api::ResourceRouter* new_resource_api_handler(const RsPlugInInterfaces& ifaces, resource_api::StateTokenServer* sts, std::string &entrypoint) const { return 0;}
|
virtual resource_api::ResourceRouter* new_resource_api_handler(const RsPlugInInterfaces& /* ifaces */, resource_api::StateTokenServer* /* sts */, std::string & /*entrypoint*/) const { return 0;}
|
||||||
|
|
||||||
// Shutdown
|
// Shutdown
|
||||||
virtual void stop() {}
|
virtual void stop() {}
|
||||||
|
@ -273,7 +273,13 @@ bool RsLoginHandler::tryAutoLogin(const RsPeerId& ssl_id,std::string& ssl_passwd
|
|||||||
fseek(fp, 0, SEEK_END);
|
fseek(fp, 0, SEEK_END);
|
||||||
datalen = ftell(fp);
|
datalen = ftell(fp);
|
||||||
fseek(fp, 0, SEEK_SET);
|
fseek(fp, 0, SEEK_SET);
|
||||||
dataptr = (char *) malloc(datalen);
|
dataptr = (char *) rs_malloc(datalen);
|
||||||
|
|
||||||
|
if(dataptr == NULL)
|
||||||
|
{
|
||||||
|
fclose(fp);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
fread(dataptr, 1, datalen, fp);
|
fread(dataptr, 1, datalen, fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ bool getRawUInt8(void *data, uint32_t size, uint32_t *offset, uint8_t *out)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 1)
|
if (size < *offset + 1)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot deserialise uint8_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
||||||
@ -56,6 +57,7 @@ bool setRawUInt8(void *data, uint32_t size, uint32_t *offset, uint8_t in)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 1)
|
if (size < *offset + 1)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot serialise uint8_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,6 +76,7 @@ bool getRawUInt16(void *data, uint32_t size, uint32_t *offset, uint16_t *out)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 2)
|
if (size < *offset + 2)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot deserialise uint16_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
||||||
@ -92,6 +95,7 @@ bool setRawUInt16(void *data, uint32_t size, uint32_t *offset, uint16_t in)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 2)
|
if (size < *offset + 2)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot serialise uint16_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -114,6 +118,7 @@ bool getRawUInt32(void *data, uint32_t size, uint32_t *offset, uint32_t *out)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 4)
|
if (size < *offset + 4)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot deserialise uint32_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
||||||
@ -132,6 +137,7 @@ bool setRawUInt32(void *data, uint32_t size, uint32_t *offset, uint32_t in)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 4)
|
if (size < *offset + 4)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot serialise uint32_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,6 +160,7 @@ bool getRawUInt64(void *data, uint32_t size, uint32_t *offset, uint64_t *out)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 8)
|
if (size < *offset + 8)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot deserialise uint64_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
void *buf = (void *) &(((uint8_t *) data)[*offset]);
|
||||||
@ -172,6 +179,7 @@ bool setRawUInt64(void *data, uint32_t size, uint32_t *offset, uint64_t in)
|
|||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 8)
|
if (size < *offset + 8)
|
||||||
{
|
{
|
||||||
|
std::cerr << "(EE) Cannot serialise uint64_t: not enough size." << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -231,12 +239,13 @@ bool getRawString(void *data, uint32_t size, uint32_t *offset, std::string &outS
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* check there is space for string */
|
/* check there is space for string */
|
||||||
if (size < *offset + len)
|
if(len > size || size-len < *offset) // better than if(size < *offset + len) because it avoids integer overflow
|
||||||
{
|
{
|
||||||
std::cerr << "getRawString() not enough size" << std::endl;
|
std::cerr << "getRawString() not enough size" << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
uint8_t *buf = &(((uint8_t *) data)[*offset]);
|
uint8_t *buf = &(((uint8_t *) data)[*offset]);
|
||||||
|
|
||||||
for (uint32_t i = 0; i < len; i++)
|
for (uint32_t i = 0; i < len; i++)
|
||||||
{
|
{
|
||||||
outStr += buf[i];
|
outStr += buf[i];
|
||||||
@ -250,11 +259,10 @@ bool setRawString(void *data, uint32_t size, uint32_t *offset, const std::string
|
|||||||
{
|
{
|
||||||
uint32_t len = inStr.length();
|
uint32_t len = inStr.length();
|
||||||
/* first check there is space */
|
/* first check there is space */
|
||||||
if (size < *offset + 4 + len)
|
|
||||||
|
if(size < 4 || len > size-4 || size-len-4 < *offset) // better than if(size < *offset + len + 4) because it avoids integer overflow
|
||||||
{
|
{
|
||||||
//#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "setRawString() Not enough size" << std::endl;
|
std::cerr << "setRawString() Not enough size" << std::endl;
|
||||||
//#endif
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "retroshare/rstypes.h"
|
#include "retroshare/rstypes.h"
|
||||||
|
|
||||||
/*******************************************************************
|
/*******************************************************************
|
||||||
@ -181,7 +182,7 @@ class RsRawItem: public RsItem
|
|||||||
RsRawItem(uint32_t t, uint32_t size)
|
RsRawItem(uint32_t t, uint32_t size)
|
||||||
:RsItem(t), len(size)
|
:RsItem(t), len(size)
|
||||||
{
|
{
|
||||||
data = malloc(len);
|
data = rs_malloc(len);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~RsRawItem()
|
virtual ~RsRawItem()
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "serialiser/rstlvbinary.h"
|
#include "serialiser/rstlvbinary.h"
|
||||||
|
|
||||||
#include "serialiser/rstlvbase.h"
|
#include "serialiser/rstlvbase.h"
|
||||||
@ -74,7 +75,11 @@ bool RsTlvBinaryData::setBinData(const void *data, uint32_t size)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bin_data = malloc(bin_len);
|
bin_data = rs_malloc(bin_len);
|
||||||
|
|
||||||
|
if(bin_data == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
memcpy(bin_data, data, bin_len);
|
memcpy(bin_data, data, bin_len);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -916,6 +916,12 @@ bool SSGxsChannelGroup::load(const std::string &input)
|
|||||||
mAutoDownload = false;
|
mAutoDownload = false;
|
||||||
mDownloadDirectory.clear();
|
mDownloadDirectory.clear();
|
||||||
|
|
||||||
|
if(input.empty())
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) SSGxsChannelGroup::load() asked to load a null string. Weird." << std::endl;
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
|
|
||||||
RsTemporaryMemory tmpmem(input.length());
|
RsTemporaryMemory tmpmem(input.length());
|
||||||
|
|
||||||
if (1 == sscanf(input.c_str(), "D:%d", &download_val))
|
if (1 == sscanf(input.c_str(), "D:%d", &download_val))
|
||||||
|
@ -98,7 +98,8 @@ void RsGxsImage::take(uint8_t *data, uint32_t size)
|
|||||||
// NB Must make sure that we always use malloc/free for this data.
|
// NB Must make sure that we always use malloc/free for this data.
|
||||||
uint8_t *RsGxsImage::allocate(uint32_t size)
|
uint8_t *RsGxsImage::allocate(uint32_t size)
|
||||||
{
|
{
|
||||||
uint8_t *val = (uint8_t *) malloc(size);
|
uint8_t *val = (uint8_t *) rs_malloc(size);
|
||||||
|
|
||||||
#ifdef DEBUG_GXSCOMMON
|
#ifdef DEBUG_GXSCOMMON
|
||||||
std::cerr << "RsGxsImage()::allocate(" << (void *) val << ")";
|
std::cerr << "RsGxsImage()::allocate(" << (void *) val << ")";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
|
@ -26,7 +26,11 @@ bool RsPhotoThumbnail::copyFrom(const RsPhotoThumbnail &nail)
|
|||||||
|
|
||||||
size = nail.size;
|
size = nail.size;
|
||||||
type = nail.type;
|
type = nail.type;
|
||||||
data = (uint8_t *) malloc(size);
|
data = (uint8_t *) rs_malloc(size);
|
||||||
|
|
||||||
|
if(data == NULL)
|
||||||
|
return false ;
|
||||||
|
|
||||||
memcpy(data, nail.data, size);
|
memcpy(data, nail.data, size);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <util/rsmemory.h>
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
@ -79,7 +80,9 @@ TcpPacket::TcpPacket(uint8 *ptr, int size)
|
|||||||
if (size > 0)
|
if (size > 0)
|
||||||
{
|
{
|
||||||
datasize = size;
|
datasize = size;
|
||||||
data = (uint8 *) malloc(datasize);
|
data = (uint8 *) rs_malloc(datasize);
|
||||||
|
|
||||||
|
if(data != NULL)
|
||||||
memcpy(data, (void *) ptr, size);
|
memcpy(data, (void *) ptr, size);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
@ -185,7 +188,17 @@ int TcpPacket::readPacket(void *buf, int size)
|
|||||||
free(data);
|
free(data);
|
||||||
}
|
}
|
||||||
datasize = size - TCP_PSEUDO_HDR_SIZE;
|
datasize = size - TCP_PSEUDO_HDR_SIZE;
|
||||||
data = (uint8 *) malloc(datasize);
|
|
||||||
|
if(datasize == 0) // this happens!
|
||||||
|
{
|
||||||
|
data = NULL ;
|
||||||
|
return 0 ;
|
||||||
|
}
|
||||||
|
|
||||||
|
data = (uint8 *) rs_malloc(datasize);
|
||||||
|
|
||||||
|
if(data == NULL)
|
||||||
|
return 0 ;
|
||||||
|
|
||||||
/* now the data */
|
/* now the data */
|
||||||
memcpy(data, (void *) &(((uint8 *) buf)[20]), datasize);
|
memcpy(data, (void *) &(((uint8 *) buf)[20]), datasize);
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "udprelay.h"
|
#include "udprelay.h"
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#include <util/rsmemory.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* #define DEBUG_UDP_RELAY 1
|
* #define DEBUG_UDP_RELAY 1
|
||||||
@ -70,7 +71,7 @@ UdpRelayReceiver::UdpRelayReceiver(UdpPublisher *pub)
|
|||||||
setRelayClassMax(UDP_RELAY_CLASS_GENERAL, UDP_RELAY_DEFAULT_GENERAL, UDP_RELAY_DEFAULT_BANDWIDTH);
|
setRelayClassMax(UDP_RELAY_CLASS_GENERAL, UDP_RELAY_DEFAULT_GENERAL, UDP_RELAY_DEFAULT_BANDWIDTH);
|
||||||
|
|
||||||
/* only allocate this space once */
|
/* only allocate this space once */
|
||||||
mTmpSendPkt = malloc(MAX_RELAY_UDP_PACKET_SIZE);
|
mTmpSendPkt = rs_malloc(MAX_RELAY_UDP_PACKET_SIZE);
|
||||||
mTmpSendSize = MAX_RELAY_UDP_PACKET_SIZE;
|
mTmpSendSize = MAX_RELAY_UDP_PACKET_SIZE;
|
||||||
|
|
||||||
clearDataTransferred();
|
clearDataTransferred();
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include "util/rsrandom.h"
|
#include "util/rsrandom.h"
|
||||||
#include "util/rsprint.h"
|
#include "util/rsprint.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "util/rsstring.h"
|
#include "util/rsstring.h"
|
||||||
|
|
||||||
static const int STUN_TTL = 64;
|
static const int STUN_TTL = 64;
|
||||||
@ -535,7 +536,11 @@ bool UdpStun_generate_stun_pkt(void *stun_pkt, int *len)
|
|||||||
void *UdpStun_generate_stun_reply(struct sockaddr_in *stun_addr, int *len)
|
void *UdpStun_generate_stun_reply(struct sockaddr_in *stun_addr, int *len)
|
||||||
{
|
{
|
||||||
/* just the header */
|
/* just the header */
|
||||||
void *stun_pkt = malloc(28);
|
void *stun_pkt = rs_malloc(28);
|
||||||
|
|
||||||
|
if(!stun_pkt)
|
||||||
|
return NULL ;
|
||||||
|
|
||||||
((uint16_t *) stun_pkt)[0] = (uint16_t) htons(0x0101);
|
((uint16_t *) stun_pkt)[0] = (uint16_t) htons(0x0101);
|
||||||
((uint16_t *) stun_pkt)[1] = (uint16_t) htons(28); /* only header + 8 byte addr */
|
((uint16_t *) stun_pkt)[1] = (uint16_t) htons(28); /* only header + 8 byte addr */
|
||||||
/* transaction id - should be random */
|
/* transaction id - should be random */
|
||||||
|
@ -284,19 +284,24 @@ RsTurtleRegExpSearchRequestItem::RsTurtleRegExpSearchRequestItem(void *data,uint
|
|||||||
uint32_t n =0 ;
|
uint32_t n =0 ;
|
||||||
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
||||||
|
|
||||||
|
if(ok)
|
||||||
expr._tokens.resize(n) ;
|
expr._tokens.resize(n) ;
|
||||||
|
|
||||||
for(uint32_t i=0;i<n;++i) ok &= getRawUInt8(data,pktsize,&offset,&expr._tokens[i]) ;
|
for(uint32_t i=0;i<n && ok;++i) ok &= getRawUInt8(data,pktsize,&offset,&expr._tokens[i]) ;
|
||||||
|
|
||||||
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
||||||
|
|
||||||
|
if(ok)
|
||||||
expr._ints.resize(n) ;
|
expr._ints.resize(n) ;
|
||||||
|
|
||||||
for(uint32_t i=0;i<n;++i) ok &= getRawUInt32(data,pktsize,&offset,&expr._ints[i]) ;
|
for(uint32_t i=0;i<n && ok;++i) ok &= getRawUInt32(data,pktsize,&offset,&expr._ints[i]) ;
|
||||||
|
|
||||||
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
ok &= getRawUInt32(data,pktsize,&offset,&n) ;
|
||||||
|
|
||||||
|
if(ok)
|
||||||
expr._strings.resize(n) ;
|
expr._strings.resize(n) ;
|
||||||
|
|
||||||
for(uint32_t i=0;i<n;++i) ok &= GetTlvString(data, pktsize, &offset, TLV_TYPE_STR_VALUE, expr._strings[i]);
|
for(uint32_t i=0;i<n && ok;++i) ok &= GetTlvString(data, pktsize, &offset, TLV_TYPE_STR_VALUE, expr._strings[i]);
|
||||||
|
|
||||||
#ifdef WINDOWS_SYS // No Exceptions in Windows compile. (drbobs).
|
#ifdef WINDOWS_SYS // No Exceptions in Windows compile. (drbobs).
|
||||||
UNREFERENCED_LOCAL_VARIABLE(rssize);
|
UNREFERENCED_LOCAL_VARIABLE(rssize);
|
||||||
@ -531,6 +536,9 @@ RsTurtleGenericDataItem::RsTurtleGenericDataItem(void *data,uint32_t pktsize)
|
|||||||
uint32_t offset = 8; // skip the header
|
uint32_t offset = 8; // skip the header
|
||||||
uint32_t rssize = getRsItemSize(data);
|
uint32_t rssize = getRsItemSize(data);
|
||||||
|
|
||||||
|
if(rssize > pktsize)
|
||||||
|
throw std::runtime_error("RsTurtleTunnelOkItem::() wrong rssize (exceeds pktsize).") ;
|
||||||
|
|
||||||
/* add mandatory parts first */
|
/* add mandatory parts first */
|
||||||
|
|
||||||
bool ok = true ;
|
bool ok = true ;
|
||||||
@ -540,7 +548,11 @@ RsTurtleGenericDataItem::RsTurtleGenericDataItem(void *data,uint32_t pktsize)
|
|||||||
#ifdef P3TURTLE_DEBUG
|
#ifdef P3TURTLE_DEBUG
|
||||||
std::cerr << " request_id=" << (void*)request_id << ", tunnel_id=" << (void*)tunnel_id << std::endl ;
|
std::cerr << " request_id=" << (void*)request_id << ", tunnel_id=" << (void*)tunnel_id << std::endl ;
|
||||||
#endif
|
#endif
|
||||||
data_bytes = malloc(data_size) ;
|
|
||||||
|
if(data_size > rssize || rssize - data_size < offset)
|
||||||
|
throw std::runtime_error("RsTurtleTunnelOkItem::() wrong data_size (exceeds rssize).") ;
|
||||||
|
|
||||||
|
data_bytes = rs_malloc(data_size) ;
|
||||||
|
|
||||||
if(data_bytes != NULL)
|
if(data_bytes != NULL)
|
||||||
{
|
{
|
||||||
@ -548,10 +560,7 @@ RsTurtleGenericDataItem::RsTurtleGenericDataItem(void *data,uint32_t pktsize)
|
|||||||
offset += data_size ;
|
offset += data_size ;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
|
||||||
std::cerr << "(EE) RsTurtleGenericDataItem: Error. Cannot allocate data for a size of " << data_size << " bytes." <<std::endl;
|
|
||||||
offset = 0 ; // generate an error
|
offset = 0 ; // generate an error
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef WINDOWS_SYS // No Exceptions in Windows compile. (drbobs).
|
#ifdef WINDOWS_SYS // No Exceptions in Windows compile. (drbobs).
|
||||||
UNREFERENCED_LOCAL_VARIABLE(rssize);
|
UNREFERENCED_LOCAL_VARIABLE(rssize);
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include "rscompress.h"
|
#include "rscompress.h"
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
// 16K buffer size.
|
// 16K buffer size.
|
||||||
//
|
//
|
||||||
@ -42,7 +43,10 @@ bool RsCompress::compress_memory_chunk(const uint8_t *input_mem,const uint32_t i
|
|||||||
uint32_t output_offset = 0 ;
|
uint32_t output_offset = 0 ;
|
||||||
uint32_t input_offset = 0 ;
|
uint32_t input_offset = 0 ;
|
||||||
output_size = 1024 ;
|
output_size = 1024 ;
|
||||||
output_mem = (uint8_t*)malloc(output_size) ;
|
output_mem = (uint8_t*)rs_malloc(output_size) ;
|
||||||
|
|
||||||
|
if(!output_mem)
|
||||||
|
return false ;
|
||||||
|
|
||||||
int ret, flush;
|
int ret, flush;
|
||||||
unsigned have;
|
unsigned have;
|
||||||
@ -113,7 +117,10 @@ bool RsCompress::uncompress_memory_chunk(const uint8_t *input_mem,const uint32_t
|
|||||||
output_size = input_size ;
|
output_size = input_size ;
|
||||||
uint32_t output_offset = 0 ;
|
uint32_t output_offset = 0 ;
|
||||||
uint32_t input_offset = 0 ;
|
uint32_t input_offset = 0 ;
|
||||||
output_mem = (uint8_t*)malloc(output_size) ;
|
output_mem = (uint8_t*)rs_malloc(output_size) ;
|
||||||
|
|
||||||
|
if(!output_mem)
|
||||||
|
return false ;
|
||||||
|
|
||||||
int ret;
|
int ret;
|
||||||
unsigned have;
|
unsigned have;
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
#include "util/rsstring.h"
|
#include "util/rsstring.h"
|
||||||
#include "util/rsrandom.h"
|
#include "util/rsrandom.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
#include "retroshare/rstypes.h"
|
#include "retroshare/rstypes.h"
|
||||||
#include "rsthreads.h"
|
#include "rsthreads.h"
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
@ -267,7 +268,14 @@ bool RsDirUtil::copyFile(const std::string& source,const std::string& dest)
|
|||||||
size_t T=0;
|
size_t T=0;
|
||||||
|
|
||||||
static const int BUFF_SIZE = 10485760 ; // 10 MB buffer to speed things up.
|
static const int BUFF_SIZE = 10485760 ; // 10 MB buffer to speed things up.
|
||||||
void *buffer = malloc(BUFF_SIZE) ;
|
RsTemporaryMemory buffer(BUFF_SIZE) ;
|
||||||
|
|
||||||
|
if(!buffer)
|
||||||
|
{
|
||||||
|
fclose(in) ;
|
||||||
|
fclose(out) ;
|
||||||
|
return false ;
|
||||||
|
}
|
||||||
|
|
||||||
bool bRet = true;
|
bool bRet = true;
|
||||||
|
|
||||||
@ -286,8 +294,6 @@ bool RsDirUtil::copyFile(const std::string& source,const std::string& dest)
|
|||||||
fclose(in) ;
|
fclose(in) ;
|
||||||
fclose(out) ;
|
fclose(out) ;
|
||||||
|
|
||||||
free(buffer) ;
|
|
||||||
|
|
||||||
return true ;
|
return true ;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
32
libretroshare/src/util/rsmemory.cc
Normal file
32
libretroshare/src/util/rsmemory.cc
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
|
void *rs_malloc(size_t size)
|
||||||
|
{
|
||||||
|
static const size_t SAFE_MEMALLOC_THRESHOLD = 1024*1024*1024 ; // 1Gb should be enough for everything!
|
||||||
|
|
||||||
|
if(size == 0)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Memory allocation error. A chunk of size 0 was requested. Callstack:" << std::endl;
|
||||||
|
print_stacktrace() ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(size > SAFE_MEMALLOC_THRESHOLD)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Memory allocation error. A chunk of size 0 was requested. Callstack:" << std::endl;
|
||||||
|
print_stacktrace() ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *mem = malloc(size) ;
|
||||||
|
|
||||||
|
if(mem == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Memory allocation error for a chunk of " << size << " bytes. Callstack:" << std::endl;
|
||||||
|
print_stacktrace() ;
|
||||||
|
return NULL ;
|
||||||
|
}
|
||||||
|
|
||||||
|
return mem ;
|
||||||
|
}
|
||||||
|
|
@ -1,6 +1,10 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <iostream>
|
||||||
|
#include <util/stacktrace.h>
|
||||||
|
|
||||||
|
void *rs_malloc(size_t size) ;
|
||||||
|
|
||||||
// This is a scope guard to release the memory block when going of of the current scope.
|
// This is a scope guard to release the memory block when going of of the current scope.
|
||||||
// Can be very useful to auto-delete some memory on quit without the need to call free each time.
|
// Can be very useful to auto-delete some memory on quit without the need to call free each time.
|
||||||
@ -24,7 +28,7 @@ class RsTemporaryMemory
|
|||||||
public:
|
public:
|
||||||
RsTemporaryMemory(size_t s)
|
RsTemporaryMemory(size_t s)
|
||||||
{
|
{
|
||||||
_mem = (unsigned char *)malloc(s) ;
|
_mem = (unsigned char *)rs_malloc(s) ;
|
||||||
|
|
||||||
if(_mem)
|
if(_mem)
|
||||||
_size = s ;
|
_size = s ;
|
||||||
@ -53,5 +57,3 @@ private:
|
|||||||
RsTemporaryMemory& operator=(const RsTemporaryMemory&) { return *this ;}
|
RsTemporaryMemory& operator=(const RsTemporaryMemory&) { return *this ;}
|
||||||
RsTemporaryMemory(const RsTemporaryMemory&) {}
|
RsTemporaryMemory(const RsTemporaryMemory&) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -145,7 +145,12 @@ bool RsRecogn::loadSigningKeys(std::map<RsGxsId, RsGxsRecognSignerItem *> &signM
|
|||||||
|
|
||||||
/* store in */
|
/* store in */
|
||||||
uint32_t datalen = recognSerialiser.size(item);
|
uint32_t datalen = recognSerialiser.size(item);
|
||||||
uint8_t *data = (uint8_t *) malloc(datalen);
|
|
||||||
|
RsTemporaryMemory data(datalen) ;
|
||||||
|
|
||||||
|
if(!data)
|
||||||
|
return false ;
|
||||||
|
|
||||||
uint32_t pktlen = datalen;
|
uint32_t pktlen = datalen;
|
||||||
int signOk = 0;
|
int signOk = 0;
|
||||||
|
|
||||||
@ -181,8 +186,6 @@ bool RsRecogn::loadSigningKeys(std::map<RsGxsId, RsGxsRecognSignerItem *> &signM
|
|||||||
#endif // DEBUG_RECOGN
|
#endif // DEBUG_RECOGN
|
||||||
delete item;
|
delete item;
|
||||||
}
|
}
|
||||||
|
|
||||||
free(data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* clean up */
|
/* clean up */
|
||||||
@ -233,7 +236,12 @@ bool RsRecogn::validateTagSignature(RsGxsRecognSignerItem *signer, RsGxsRecognTa
|
|||||||
RsGxsRecognSerialiser serialiser;
|
RsGxsRecognSerialiser serialiser;
|
||||||
|
|
||||||
uint32_t datalen = serialiser.size(item);
|
uint32_t datalen = serialiser.size(item);
|
||||||
uint8_t *data = (uint8_t *) malloc(datalen);
|
|
||||||
|
RsTemporaryMemory data(datalen) ;
|
||||||
|
|
||||||
|
if(!data)
|
||||||
|
return false ;
|
||||||
|
|
||||||
int signOk = 0;
|
int signOk = 0;
|
||||||
|
|
||||||
uint32_t pktlen = datalen;
|
uint32_t pktlen = datalen;
|
||||||
@ -263,8 +271,6 @@ bool RsRecogn::validateTagSignature(RsGxsRecognSignerItem *signer, RsGxsRecognTa
|
|||||||
EVP_MD_CTX_destroy(mdctx);
|
EVP_MD_CTX_destroy(mdctx);
|
||||||
EVP_PKEY_free(signKey);
|
EVP_PKEY_free(signKey);
|
||||||
|
|
||||||
free(data);
|
|
||||||
|
|
||||||
return (signOk == 1);
|
return (signOk == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include "smallobject.h"
|
#include "smallobject.h"
|
||||||
#include "util/rsthreads.h"
|
#include "util/rsthreads.h"
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
using namespace RsMemoryManagement ;
|
using namespace RsMemoryManagement ;
|
||||||
|
|
||||||
@ -206,7 +207,7 @@ SmallObjectAllocator::~SmallObjectAllocator()
|
|||||||
void *SmallObjectAllocator::allocate(size_t bytes)
|
void *SmallObjectAllocator::allocate(size_t bytes)
|
||||||
{
|
{
|
||||||
if(bytes > _maxObjectSize)
|
if(bytes > _maxObjectSize)
|
||||||
return malloc(bytes) ;
|
return rs_malloc(bytes) ;
|
||||||
else if(_lastAlloc != NULL && _lastAlloc->blockSize() == bytes)
|
else if(_lastAlloc != NULL && _lastAlloc->blockSize() == bytes)
|
||||||
return _lastAlloc->allocate() ;
|
return _lastAlloc->allocate() ;
|
||||||
else
|
else
|
||||||
|
@ -114,13 +114,16 @@ void ops_finish(void)
|
|||||||
\note Should be freed after use with free().
|
\note Should be freed after use with free().
|
||||||
*/
|
*/
|
||||||
void *ops_mallocz(size_t n)
|
void *ops_mallocz(size_t n)
|
||||||
{
|
{
|
||||||
void *m=malloc(n);
|
void *m=malloc(n);
|
||||||
|
|
||||||
|
if(m == NULL)
|
||||||
|
fprintf(stderr,"(EE) Cannot allocate %d bytes of memory in %s\n",n,__PRETTY_FUNCTION__) ;
|
||||||
|
else
|
||||||
memset(m,'\0',n);
|
memset(m,'\0',n);
|
||||||
|
|
||||||
return m;
|
return m;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
@ -182,7 +182,7 @@ bool XMLWrapper::readXML(const char *xml)
|
|||||||
cleanup();
|
cleanup();
|
||||||
|
|
||||||
handleError(true, mLastErrorString);
|
handleError(true, mLastErrorString);
|
||||||
mDocument = xmlReadDoc(BAD_CAST xml, "", NULL, /*XML_PARSE_NOERROR | XML_PARSE_NOWARNING | */XML_PARSE_COMPACT | XML_PARSE_NOENT | XML_PARSE_NOCDATA);
|
mDocument = xmlReadDoc(BAD_CAST xml, "", NULL, /*XML_PARSE_NOERROR | XML_PARSE_NOWARNING | */XML_PARSE_COMPACT | XML_PARSE_NOCDATA);
|
||||||
handleError(false, mLastErrorString);
|
handleError(false, mLastErrorString);
|
||||||
|
|
||||||
if (mDocument) {
|
if (mDocument) {
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "SpeexProcessor.h"
|
#include "SpeexProcessor.h"
|
||||||
|
|
||||||
|
#include <util/rsmemory.h>
|
||||||
#include <speex/speex.h>
|
#include <speex/speex.h>
|
||||||
#include <speex/speex_preprocess.h>
|
#include <speex/speex_preprocess.h>
|
||||||
|
|
||||||
@ -350,7 +351,11 @@ void SpeexOutputProcessor::putNetworkPacket(QString name, QByteArray packet) {
|
|||||||
if (userJitterHash.contains(name)) {
|
if (userJitterHash.contains(name)) {
|
||||||
userJitter = userJitterHash.value(name);
|
userJitter = userJitterHash.value(name);
|
||||||
} else {
|
} else {
|
||||||
userJitter = (SpeexJitter*)malloc(sizeof(SpeexJitter));
|
userJitter = (SpeexJitter*)rs_malloc(sizeof(SpeexJitter));
|
||||||
|
|
||||||
|
if(!userJitter)
|
||||||
|
return ;
|
||||||
|
|
||||||
speex_jitter_init(userJitter, speex_decoder_init(&speex_wb_mode), SAMPLING_RATE);
|
speex_jitter_init(userJitter, speex_decoder_init(&speex_wb_mode), SAMPLING_RATE);
|
||||||
int on = 1;
|
int on = 1;
|
||||||
speex_decoder_ctl(userJitter->dec, SPEEX_SET_ENH, &on);
|
speex_decoder_ctl(userJitter->dec, SPEEX_SET_ENH, &on);
|
||||||
|
@ -10,6 +10,8 @@
|
|||||||
#include <QBuffer>
|
#include <QBuffer>
|
||||||
#include <QImage>
|
#include <QImage>
|
||||||
|
|
||||||
|
#include "util/rsmemory.h"
|
||||||
|
|
||||||
#include "VideoProcessor.h"
|
#include "VideoProcessor.h"
|
||||||
#include "QVideoDevice.h"
|
#include "QVideoDevice.h"
|
||||||
|
|
||||||
@ -384,7 +386,10 @@ bool JPEGVideo::encodeData(const QImage& image,uint32_t /* size_hint */,RsVOIPDa
|
|||||||
buffer.open(QIODevice::WriteOnly) ;
|
buffer.open(QIODevice::WriteOnly) ;
|
||||||
encoded_frame.save(&buffer,"JPEG") ;
|
encoded_frame.save(&buffer,"JPEG") ;
|
||||||
|
|
||||||
voip_chunk.data = malloc(HEADER_SIZE + qb.size());
|
voip_chunk.data = rs_malloc(HEADER_SIZE + qb.size());
|
||||||
|
|
||||||
|
if(!voip_chunk.data)
|
||||||
|
return false ;
|
||||||
|
|
||||||
// build header
|
// build header
|
||||||
uint32_t flags = differential_frame ? JPEG_VIDEO_FLAGS_DIFFERENTIAL_FRAME : 0x0 ;
|
uint32_t flags = differential_frame ? JPEG_VIDEO_FLAGS_DIFFERENTIAL_FRAME : 0x0 ;
|
||||||
@ -679,7 +684,11 @@ bool FFmpegVideo::encodeData(const QImage& image, uint32_t target_encoding_bitra
|
|||||||
|
|
||||||
if(got_output)
|
if(got_output)
|
||||||
{
|
{
|
||||||
voip_chunk.data = malloc(pkt.size + HEADER_SIZE) ;
|
voip_chunk.data = rs_malloc(pkt.size + HEADER_SIZE) ;
|
||||||
|
|
||||||
|
if(!voip_chunk.data)
|
||||||
|
return false ;
|
||||||
|
|
||||||
uint32_t flags = 0;
|
uint32_t flags = 0;
|
||||||
|
|
||||||
((unsigned char *)voip_chunk.data)[0] = VideoProcessor::VIDEO_PROCESSOR_CODEC_ID_MPEG_VIDEO & 0xff ;
|
((unsigned char *)voip_chunk.data)[0] = VideoProcessor::VIDEO_PROCESSOR_CODEC_ID_MPEG_VIDEO & 0xff ;
|
||||||
|
@ -280,11 +280,10 @@ int p3VOIP::sendVoipData(const RsPeerId& peer_id,const RsVOIPDataChunk& chunk)
|
|||||||
std::cerr << "Cannot allocate RsVOIPDataItem !" << std::endl;
|
std::cerr << "Cannot allocate RsVOIPDataItem !" << std::endl;
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
item->voip_data = malloc(chunk.size) ;
|
item->voip_data = rs_malloc(chunk.size) ;
|
||||||
|
|
||||||
if(item->voip_data == NULL)
|
if(item->voip_data == NULL)
|
||||||
{
|
{
|
||||||
std::cerr << "Cannot allocate RsVOIPDataItem.voip_data of size " << chunk.size << " !" << std::endl;
|
|
||||||
delete item ;
|
delete item ;
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
@ -432,7 +431,13 @@ bool p3VOIP::getIncomingData(const RsPeerId& peer_id,std::vector<RsVOIPDataChunk
|
|||||||
{
|
{
|
||||||
RsVOIPDataChunk chunk ;
|
RsVOIPDataChunk chunk ;
|
||||||
chunk.size = (*it2)->data_size ;
|
chunk.size = (*it2)->data_size ;
|
||||||
chunk.data = malloc((*it2)->data_size) ;
|
chunk.data = rs_malloc((*it2)->data_size) ;
|
||||||
|
|
||||||
|
if(chunk.data == NULL)
|
||||||
|
{
|
||||||
|
delete *it2 ;
|
||||||
|
continue ;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t type_flags = (*it2)->flags & (RS_VOIP_FLAGS_AUDIO_DATA | RS_VOIP_FLAGS_VIDEO_DATA) ;
|
uint32_t type_flags = (*it2)->flags & (RS_VOIP_FLAGS_AUDIO_DATA | RS_VOIP_FLAGS_VIDEO_DATA) ;
|
||||||
if(type_flags == RS_VOIP_FLAGS_AUDIO_DATA)
|
if(type_flags == RS_VOIP_FLAGS_AUDIO_DATA)
|
||||||
|
@ -447,7 +447,14 @@ RsVOIPDataItem::RsVOIPDataItem(void *data, uint32_t pktsize)
|
|||||||
ok &= getRawUInt32(data, rssize, &offset, &flags);
|
ok &= getRawUInt32(data, rssize, &offset, &flags);
|
||||||
ok &= getRawUInt32(data, rssize, &offset, &data_size);
|
ok &= getRawUInt32(data, rssize, &offset, &data_size);
|
||||||
|
|
||||||
voip_data = malloc(data_size) ;
|
if(data_size > rssize || rssize - data_size < offset)
|
||||||
|
throw std::runtime_error("Not enough space.") ;
|
||||||
|
|
||||||
|
voip_data = rs_malloc(data_size) ;
|
||||||
|
|
||||||
|
if(!voip_data)
|
||||||
|
throw std::runtime_error("Serialization error.") ;
|
||||||
|
|
||||||
memcpy(voip_data,&((uint8_t*)data)[offset],data_size) ;
|
memcpy(voip_data,&((uint8_t*)data)[offset],data_size) ;
|
||||||
offset += data_size ;
|
offset += data_size ;
|
||||||
|
|
||||||
|
@ -73,7 +73,26 @@
|
|||||||
#define RSID_FILTER_ALL 0xffff
|
#define RSID_FILTER_ALL 0xffff
|
||||||
|
|
||||||
#define IMAGE_EDIT ":/images/edit_16.png"
|
#define IMAGE_EDIT ":/images/edit_16.png"
|
||||||
|
// quick solution for RSID_COL_VOTES sorting
|
||||||
|
class TreeWidgetItem : public QTreeWidgetItem {
|
||||||
|
public:
|
||||||
|
TreeWidgetItem(int type=Type): QTreeWidgetItem(type) {}
|
||||||
|
TreeWidgetItem(QTreeWidget *tree): QTreeWidgetItem(tree) {}
|
||||||
|
TreeWidgetItem(const QStringList& strings): QTreeWidgetItem (strings) {}
|
||||||
|
bool operator< (const QTreeWidgetItem& other ) const {
|
||||||
|
int column = treeWidget()->sortColumn();
|
||||||
|
const QVariant v1 = data(column, Qt::DisplayRole);
|
||||||
|
const QVariant v2 = other.data(column, Qt::DisplayRole);
|
||||||
|
double value1 = v1.toDouble();
|
||||||
|
double value2 = v2.toDouble();
|
||||||
|
if (value1 != value2) {
|
||||||
|
return value1 < value2;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return (v1.toString().compare (v2.toString(), Qt::CaseInsensitive) < 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
/** Constructor */
|
/** Constructor */
|
||||||
IdDialog::IdDialog(QWidget *parent) :
|
IdDialog::IdDialog(QWidget *parent) :
|
||||||
RsGxsUpdateBroadcastPage(rsIdentity, parent),
|
RsGxsUpdateBroadcastPage(rsIdentity, parent),
|
||||||
@ -368,7 +387,7 @@ bool IdDialog::fillIdListItem(const RsGxsIdGroup& data, QTreeWidgetItem *&item,
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!item)
|
if (!item)
|
||||||
item = new QTreeWidgetItem();
|
item = new TreeWidgetItem();
|
||||||
|
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputations::ReputationInfo info ;
|
||||||
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),info) ;
|
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),info) ;
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#include <iostream>
|
||||||
|
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
|
||||||
@ -72,13 +74,23 @@ void RSTextBrowser::paintEvent(QPaintEvent *event)
|
|||||||
|
|
||||||
QVariant RSTextBrowser::loadResource(int type, const QUrl &name)
|
QVariant RSTextBrowser::loadResource(int type, const QUrl &name)
|
||||||
{
|
{
|
||||||
if (mShowImages || type != QTextDocument::ImageResource || name.scheme().compare("data", Qt::CaseInsensitive) != 0) {
|
// case 1: always trust the image if it comes from an internal resource
|
||||||
return QTextBrowser::loadResource(type, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mImageBlockWidget) {
|
if(name.scheme().compare("qrc",Qt::CaseInsensitive)==0 && type == QTextDocument::ImageResource)
|
||||||
|
return QTextBrowser::loadResource(type, name);
|
||||||
|
|
||||||
|
// case 2: only display if the user allows it. Data resources can be bad (svg bombs) but we filter them out globally at the network layer.
|
||||||
|
// It would be good to add here a home-made resource loader that only loads images and not svg crap, just in case.
|
||||||
|
|
||||||
|
if(name.scheme().compare("data",Qt::CaseInsensitive)==0 && mShowImages)
|
||||||
|
return QTextBrowser::loadResource(type, name);
|
||||||
|
|
||||||
|
// case 3: otherwise, do not display
|
||||||
|
|
||||||
|
std::cerr << "TEXTBROWSER: refusing load ressource request: type=" << type << " scheme=" << name.scheme().toStdString() << ", url=" << name.toString().toStdString() << std::endl;
|
||||||
|
|
||||||
|
if (mImageBlockWidget)
|
||||||
mImageBlockWidget->show();
|
mImageBlockWidget->show();
|
||||||
}
|
|
||||||
|
|
||||||
return QPixmap(":/trolltech/styles/commonstyle/images/file-16.png");
|
return QPixmap(":/trolltech/styles/commonstyle/images/file-16.png");
|
||||||
}
|
}
|
||||||
|
@ -213,6 +213,8 @@ GxsForumThreadWidget::GxsForumThreadWidget(const RsGxsGroupId &forumId, QWidget
|
|||||||
ui->line_2->hide() ;
|
ui->line_2->hide() ;
|
||||||
ui->by_text_label->hide() ;
|
ui->by_text_label->hide() ;
|
||||||
ui->by_label->hide() ;
|
ui->by_label->hide() ;
|
||||||
|
ui->postText->setImageBlockWidget(ui->imageBlockWidget);
|
||||||
|
ui->postText->resetImagesStatus(Settings->getForumLoadEmbeddedImages()) ;
|
||||||
|
|
||||||
ui->subscribeToolButton->setToolTip(tr("<p>Subscribing to the forum will gather \
|
ui->subscribeToolButton->setToolTip(tr("<p>Subscribing to the forum will gather \
|
||||||
available posts from your subscribed friends, and make the \
|
available posts from your subscribed friends, and make the \
|
||||||
@ -590,6 +592,7 @@ void GxsForumThreadWidget::changedThread()
|
|||||||
if (mFillThread) {
|
if (mFillThread) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
ui->postText->resetImagesStatus(Settings->getForumLoadEmbeddedImages()) ;
|
||||||
|
|
||||||
insertMessage();
|
insertMessage();
|
||||||
}
|
}
|
||||||
|
@ -6,17 +6,14 @@
|
|||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>622</width>
|
<width>851</width>
|
||||||
<height>412</height>
|
<height>721</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string>Form</string>
|
<string>Form</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout_3">
|
||||||
<property name="margin">
|
|
||||||
<number>0</number>
|
|
||||||
</property>
|
|
||||||
<item>
|
<item>
|
||||||
<widget class="QSplitter" name="threadSplitter">
|
<widget class="QSplitter" name="threadSplitter">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
@ -117,6 +114,12 @@
|
|||||||
<property name="sizeType">
|
<property name="sizeType">
|
||||||
<enum>QSizePolicy::MinimumExpanding</enum>
|
<enum>QSizePolicy::MinimumExpanding</enum>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>0</width>
|
||||||
|
<height>0</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
</spacer>
|
</spacer>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
@ -446,6 +449,19 @@
|
|||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
|
<widget class="QWidget" name="">
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="RSImageBlockWidget" name="imageBlockWidget" native="true">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Preferred" vsizetype="Maximum">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
<widget class="RSTextBrowser" name="postText">
|
<widget class="RSTextBrowser" name="postText">
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
<sizepolicy hsizetype="Expanding" vsizetype="Expanding">
|
<sizepolicy hsizetype="Expanding" vsizetype="Expanding">
|
||||||
@ -457,6 +473,9 @@
|
|||||||
<enum>Qt::CustomContextMenu</enum>
|
<enum>Qt::CustomContextMenu</enum>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
@ -502,6 +521,12 @@
|
|||||||
<header location="global">gui/common/ElidedLabel.h</header>
|
<header location="global">gui/common/ElidedLabel.h</header>
|
||||||
<container>1</container>
|
<container>1</container>
|
||||||
</customwidget>
|
</customwidget>
|
||||||
|
<customwidget>
|
||||||
|
<class>RSImageBlockWidget</class>
|
||||||
|
<extends>QWidget</extends>
|
||||||
|
<header>gui/common/RSImageBlockWidget.h</header>
|
||||||
|
<container>1</container>
|
||||||
|
</customwidget>
|
||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources>
|
<resources>
|
||||||
<include location="../images.qrc"/>
|
<include location="../images.qrc"/>
|
||||||
|
@ -151,11 +151,25 @@ class SignatureEventData
|
|||||||
{
|
{
|
||||||
// We need a new memory chnk because there's no guarranty _sign nor _signlen are not in the stack
|
// We need a new memory chnk because there's no guarranty _sign nor _signlen are not in the stack
|
||||||
|
|
||||||
sign = (unsigned char *)malloc(_signlen) ;
|
sign = (unsigned char *)rs_malloc(_signlen) ;
|
||||||
|
|
||||||
|
if(!sign)
|
||||||
|
{
|
||||||
|
signlen = NULL ;
|
||||||
|
signature_result = SELF_SIGNATURE_RESULT_FAILED ;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
|
||||||
signlen = new unsigned int ;
|
signlen = new unsigned int ;
|
||||||
*signlen = _signlen ;
|
*signlen = _signlen ;
|
||||||
signature_result = SELF_SIGNATURE_RESULT_PENDING ;
|
signature_result = SELF_SIGNATURE_RESULT_PENDING ;
|
||||||
data = malloc(_len) ;
|
data = rs_malloc(_len) ;
|
||||||
|
|
||||||
|
if(!data)
|
||||||
|
{
|
||||||
|
len = 0 ;
|
||||||
|
return ;
|
||||||
|
}
|
||||||
len = _len ;
|
len = _len ;
|
||||||
memcpy(data,_data,len) ;
|
memcpy(data,_data,len) ;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user