Blame SOURCES/sqlite-3.26.0-CVE-2019-19959.patch

4bd5ce
From 16c5290d72cb8059e9dfe545613183b850fc44e4 Mon Sep 17 00:00:00 2001
4bd5ce
From: Ondrej Dubaj <odubaj@redhat.com>
4bd5ce
Date: Mon, 20 Jan 2020 10:26:35 +0100
4bd5ce
Subject: [PATCH] Fix the zipfile() function in the zipfile extension so that
4bd5ce
 it is able to
4bd5ce
4bd5ce
deal with goofy filenames that contain embedded zeros.
4bd5ce
---
4bd5ce
 ext/misc/zipfile.c |  4 ++--
4bd5ce
 test/zipfile.test  | 13 +++++++++++++
4bd5ce
 2 files changed, 15 insertions(+), 2 deletions(-)
4bd5ce
4bd5ce
diff --git a/ext/misc/zipfile.c b/ext/misc/zipfile.c
4bd5ce
index 6f48d0f..e6141ef 100644
4bd5ce
--- a/ext/misc/zipfile.c
4bd5ce
+++ b/ext/misc/zipfile.c
4bd5ce
@@ -1632,7 +1632,7 @@ static int zipfileUpdate(
4bd5ce
         zFree = sqlite3_mprintf("%s/", zPath);
4bd5ce
         if( zFree==0 ){ rc = SQLITE_NOMEM; }
4bd5ce
         zPath = (const char*)zFree;
4bd5ce
-        nPath++;
4bd5ce
+        nPath = (int)strlen(zPath);
4bd5ce
       }
4bd5ce
     }
4bd5ce
 
4bd5ce
@@ -2033,11 +2033,11 @@ void zipfileStep(sqlite3_context *pCtx, int nVal, sqlite3_value **apVal){
4bd5ce
   }else{
4bd5ce
     if( zName[nName-1]!='/' ){
4bd5ce
       zName = zFree = sqlite3_mprintf("%s/", zName);
4bd5ce
-      nName++;
4bd5ce
       if( zName==0 ){
4bd5ce
         rc = SQLITE_NOMEM;
4bd5ce
         goto zipfile_step_out;
4bd5ce
       }
4bd5ce
+      nName = (int)strlen(zName);
4bd5ce
     }else{
4bd5ce
       while( nName>1 && zName[nName-2]=='/' ) nName--;
4bd5ce
     }
4bd5ce
diff --git a/test/zipfile.test b/test/zipfile.test
4bd5ce
index 5bca10b..e4b8088 100644
4bd5ce
--- a/test/zipfile.test
4bd5ce
+++ b/test/zipfile.test
4bd5ce
@@ -808,4 +808,17 @@ do_execsql_test 13.10 {
4bd5ce
          quote(data),quote(method) FROM t1;
4bd5ce
 } {'' 10 10 2 X'3130' X'3130' 0}
4bd5ce
 
4bd5ce
+# 2019-12-23 Yongheng and Rui fuzzer
4bd5ce
+# Run using valgrind to see the problem.
4bd5ce
+#
4bd5ce
+do_execsql_test 14.10 {
4bd5ce
+  DROP TABLE t1;
4bd5ce
+  CREATE TABLE t1(x char);
4bd5ce
+  INSERT INTO t1(x) VALUES('1');
4bd5ce
+  INSERT INTO t1(x) SELECT zipfile(x, 'xyz') FROM t1;
4bd5ce
+  INSERT INTO t1(x) SELECT zipfile(x, 'uvw') FROM t1;
4bd5ce
+  SELECT count(*) FROM t1;
4bd5ce
+  PRAGMA integrity_check;
4bd5ce
+} {3 ok}
4bd5ce
+
4bd5ce
 finish_test
4bd5ce
-- 
4bd5ce
2.19.1
4bd5ce