diff -up xmlsec1-1.2.29/src/c14n.c.orig xmlsec1-1.2.29/src/c14n.c --- xmlsec1-1.2.29/src/c14n.c.orig 2024-05-10 13:47:12.698153446 +0200 +++ xmlsec1-1.2.29/src/c14n.c 2024-05-10 18:30:35.148285625 +0200 @@ -233,7 +233,10 @@ xmlSecTransformC14NPushXml(xmlSecTransfo /* we are using a semi-hack here: we know that xmlSecPtrList keeps * all pointers in the big array */ nsList = xmlSecTransformC14NGetNsList(transform); - xmlSecAssert2(xmlSecPtrListCheckId(nsList, xmlSecStringListId), -1); + if (! xmlSecPtrListCheckId(nsList, xmlSecStringListId)) { + xmlOutputBufferClose(buf); + xmlSecAssert2(0, -1); + }; ret = xmlSecTransformC14NExecute(transform->id, nodes, (xmlChar**)(nsList->data), buf); if(ret < 0) { @@ -297,7 +300,10 @@ xmlSecTransformC14NPopBin(xmlSecTransfor /* we are using a semi-hack here: we know that xmlSecPtrList keeps * all pointers in the big array */ nsList = xmlSecTransformC14NGetNsList(transform); - xmlSecAssert2(xmlSecPtrListCheckId(nsList, xmlSecStringListId), -1); + if (! xmlSecPtrListCheckId(nsList, xmlSecStringListId)) { + xmlOutputBufferClose(buf); + xmlSecAssert2(0, -1); + } ret = xmlSecTransformC14NExecute(transform->id, transform->inNodes, (xmlChar**)(nsList->data), buf); if(ret < 0) { @@ -737,4 +743,3 @@ xmlSecTransformId xmlSecTransformRemoveXmlTagsC14NGetKlass(void) { return(&xmlSecTransformRemoveXmlTagsC14NKlass); } - diff -up xmlsec1-1.2.29/src/gcrypt/asymkeys.c.orig xmlsec1-1.2.29/src/gcrypt/asymkeys.c --- xmlsec1-1.2.29/src/gcrypt/asymkeys.c.orig 2024-05-10 18:47:45.800368678 +0200 +++ xmlsec1-1.2.29/src/gcrypt/asymkeys.c 2024-05-13 09:11:08.784351577 +0200 @@ -186,6 +186,9 @@ xmlSecGCryptAsymKeyDataAdoptKey(xmlSecKe pub_key = NULL; /* data owns it now */ priv_key = NULL; /* data owns it now */ + /* Adopt functions assume ownership thus the caller would expect this to be released */ + gcry_sexp_release(key_pair); + /* success */ res = 0; diff -up xmlsec1-1.2.29/src/parser.c.orig xmlsec1-1.2.29/src/parser.c --- xmlsec1-1.2.29/src/parser.c.orig 2024-05-10 13:46:59.217160842 +0200 +++ xmlsec1-1.2.29/src/parser.c 2024-05-10 17:28:22.848994008 +0200 @@ -368,7 +368,6 @@ xmlDocPtr xmlSecParseFile(const char *filename) { xmlParserCtxtPtr ctxt; xmlDocPtr res = NULL; - char *directory = NULL; int ret; xmlSecAssert2(filename != NULL, NULL); @@ -385,23 +384,15 @@ xmlSecParseFile(const char *filename) { /* crashes on x64 xmlCtxtUseOptions (ctxt, XML_PARSE_HUGE); */ /* todo: set directories from current doc? */ - if ((ctxt->directory == NULL) && (directory == NULL)) { - directory = xmlParserGetDirectory(filename); - if(directory == NULL) { + if (ctxt->directory == NULL) { + ctxt->directory = xmlParserGetDirectory(filename); + if(ctxt->directory == NULL) { xmlSecXmlError2("xmlParserGetDirectory", NULL, "filename=%s", xmlSecErrorsSafeString(filename)); xmlFreeParserCtxt(ctxt); return(NULL); } } - if ((ctxt->directory == NULL) && (directory != NULL)) { - ctxt->directory = (char *) xmlStrdup(BAD_CAST directory); - if(ctxt->directory == NULL) { - xmlSecStrdupError(BAD_CAST directory, NULL); - xmlFreeParserCtxt(ctxt); - return(NULL); - } - } /* required for c14n! */ ctxt->loadsubset = XML_DETECT_IDS | XML_COMPLETE_ATTRS; @@ -559,7 +550,7 @@ xmlSecParseMemory(const xmlSecByte *buff if(ctxt->myDoc != NULL) { xmlFreeDoc(ctxt->myDoc); ctxt->myDoc = NULL; - } + } xmlFreeParserCtxt(ctxt); return(NULL); } @@ -580,4 +571,3 @@ xmlSecParseMemory(const xmlSecByte *buff xmlFreeParserCtxt(ctxt); return(res); } -