Browse Source

Fix vault node data leak when field content flags are set but not flagged

Michael Hansen 12 years ago
parent
commit
5f4f9b9f5f
  1. 37
      Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.cpp

37
Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.cpp

@ -90,7 +90,7 @@ static inline void IReadArray (T ** buf, unsigned * elems, uint8_t ** buffer, un
ASSERT(bytes % sizeof(T) == 0); ASSERT(bytes % sizeof(T) == 0);
*elems = bytes / sizeof(T); *elems = bytes / sizeof(T);
T * src = (T *)*buffer; T * src = (T *)*buffer;
delete *buf; free(*buf);
*buf = (T *)malloc(bytes); *buf = (T *)malloc(bytes);
memcpy(*buf, src, bytes); memcpy(*buf, src, bytes);
*buffer += bytes; *buffer += bytes;
@ -338,28 +338,19 @@ void NetGameRank::CopyFrom(const NetGameRank & fromRank) {
//============================================================================ //============================================================================
static void DeallocNodeFields (NetVaultNode * node) { static void DeallocNodeFields (NetVaultNode * node) {
for (uint64_t fieldFlag = 1; fieldFlag; fieldFlag <<= 1) { free(node->createAgeName);
if (fieldFlag > node->fieldFlags) free(node->string64_1);
break; free(node->string64_2);
free(node->string64_3);
#define DELFIELD(f, v) case (uint64_t)(NetVaultNode::f): delete node->v; node->v = nil; break free(node->string64_4);
switch (fieldFlag & node->fieldFlags) { free(node->string64_5);
DELFIELD(kCreateAgeName, createAgeName); free(node->string64_6);
DELFIELD(kString64_1, string64_1); free(node->istring64_1);
DELFIELD(kString64_2, string64_2); free(node->istring64_2);
DELFIELD(kString64_3, string64_3); free(node->text_1);
DELFIELD(kString64_4, string64_4); free(node->text_2);
DELFIELD(kString64_5, string64_5); free(node->blob_1);
DELFIELD(kString64_6, string64_6); free(node->blob_2);
DELFIELD(kIString64_1, istring64_1);
DELFIELD(kIString64_2, istring64_2);
DELFIELD(kText_1, text_1);
DELFIELD(kText_2, text_2);
DELFIELD(kBlob_1, blob_1);
DELFIELD(kBlob_2, blob_2);
default: break;
}
}
} }
//============================================================================ //============================================================================

Loading…
Cancel
Save