From df34ec151cba2d5bd8cb2086c0246d8dcdf5d957 Mon Sep 17 00:00:00 2001 From: Seonah Moon Date: Mon, 19 Jun 2017 10:15:46 +0900 Subject: [PATCH] [CVE-2017-7407] --write-out out of buffer read https://curl.haxx.se/docs/adv_20170403.html Change-Id: I3cc866289e8929b52d31914f2f3164e18a2e1b5d Signed-off-by: Seonah Moon --- src/tool_writeout.c | 6 +++--- tests/data/Makefile.inc | 2 +- tests/data/test1440 | 31 +++++++++++++++++++++++++++++++ tests/data/test1441 | 31 +++++++++++++++++++++++++++++++ tests/data/test1442 | 35 +++++++++++++++++++++++++++++++++++ 5 files changed, 101 insertions(+), 4 deletions(-) create mode 100644 tests/data/test1440 create mode 100644 tests/data/test1441 create mode 100644 tests/data/test1442 diff --git a/src/tool_writeout.c b/src/tool_writeout.c index 2fb7774..5d92bd2 100644 --- a/src/tool_writeout.c +++ b/src/tool_writeout.c @@ -5,7 +5,7 @@ * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * - * Copyright (C) 1998 - 2016, Daniel Stenberg, , et al. + * Copyright (C) 1998 - 2017, Daniel Stenberg, , et al. * * This software is licensed as described in the file COPYING, which * you should have received as part of this distribution. The terms @@ -113,7 +113,7 @@ void ourWriteOut(CURL *curl, struct OutStruct *outs, const char *writeinfo) double doubleinfo; while(ptr && *ptr) { - if('%' == *ptr) { + if('%' == *ptr && ptr[1]) { if('%' == ptr[1]) { /* an escaped %-letter */ fputc('%', stream); @@ -341,7 +341,7 @@ void ourWriteOut(CURL *curl, struct OutStruct *outs, const char *writeinfo) } } } - else if('\\' == *ptr) { + else if('\\' == *ptr && ptr[1]) { switch(ptr[1]) { case 'r': fputc('\r', stream); diff --git a/tests/data/Makefile.inc b/tests/data/Makefile.inc index 8251ab9..267ff6a 100644 --- a/tests/data/Makefile.inc +++ b/tests/data/Makefile.inc @@ -151,7 +151,7 @@ test1408 test1409 test1410 test1411 test1412 test1413 test1414 test1415 \ test1416 test1417 test1418 test1419 test1420 test1421 test1422 test1423 \ test1424 \ test1428 test1429 test1430 test1431 test1432 test1433 test1434 test1435 \ -test1436 test1437 test1438 test1439 \ +test1436 test1437 test1438 test1439 test1440 test1441 test1442 \ \ test1500 test1501 test1502 test1503 test1504 test1505 test1506 test1507 \ test1508 test1509 test1510 test1511 test1512 test1513 test1514 test1515 \ diff --git a/tests/data/test1440 b/tests/data/test1440 new file mode 100644 index 0000000..7ed0c4d --- /dev/null +++ b/tests/data/test1440 @@ -0,0 +1,31 @@ + + + +--write-out + + +# Server-side + + + +# Client-side + + +file + + + +Check --write-out with trailing %{ + + +file://localhost/%PWD/log/ --write-out '%{' + + + +# Verify data + + +%{ + + + diff --git a/tests/data/test1441 b/tests/data/test1441 new file mode 100644 index 0000000..6e253a6 --- /dev/null +++ b/tests/data/test1441 @@ -0,0 +1,31 @@ + + + +--write-out + + +# Server-side + + + +# Client-side + + +file + + + +Check --write-out with trailing % + + +file://localhost/%PWD/log/ --write-out '%' + + + +# Verify data + + +% + + + diff --git a/tests/data/test1442 b/tests/data/test1442 new file mode 100644 index 0000000..255a4c9 --- /dev/null +++ b/tests/data/test1442 @@ -0,0 +1,35 @@ + + + +--write-out +FILE + + +# Server-side + + + +# Client-side + + +file + + + +Check --write-out with trailing \ + + +file://localhost/%PWD/log/non-existent-file.txt --write-out '\' + + + +# Verify data + + +37 + + +\ + + + -- 2.7.4