This is an automated email from the ASF dual-hosted git repository.

swebb2066 pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/logging-log4cxx.git


The following commit(s) were added to refs/heads/master by this push:
     new 4fb8904e Add HTMLLayout fuzzer (#454)
4fb8904e is described below

commit 4fb8904e051bc33f48eced1959f039305d645a73
Author: AdamKorcz <[email protected]>
AuthorDate: Wed Jan 22 06:07:43 2025 +0000

    Add HTMLLayout fuzzer (#454)
    
    Signed-off-by: Adam Korczynski <[email protected]>
---
 src/fuzzers/cpp/CMakeLists.txt       |  2 +-
 src/fuzzers/cpp/HTMLLayoutFuzzer.cpp | 89 ++++++++++++++++++++++++++++++++++++
 2 files changed, 90 insertions(+), 1 deletion(-)

diff --git a/src/fuzzers/cpp/CMakeLists.txt b/src/fuzzers/cpp/CMakeLists.txt
index 0b7d4f62..b4ae9606 100644
--- a/src/fuzzers/cpp/CMakeLists.txt
+++ b/src/fuzzers/cpp/CMakeLists.txt
@@ -15,7 +15,7 @@
 # limitations under the License.
 #
 
-set(ALL_LOG4CXX_FUZZERS PatternLayoutFuzzer XMLLayoutFuzzer)
+set(ALL_LOG4CXX_FUZZERS PatternLayoutFuzzer XMLLayoutFuzzer HTMLLayoutFuzzer)
 set(LOG4CXX_CHAR "utf-8")
 
 # Get the most recent Git commit ID
diff --git a/src/fuzzers/cpp/HTMLLayoutFuzzer.cpp 
b/src/fuzzers/cpp/HTMLLayoutFuzzer.cpp
new file mode 100644
index 00000000..75bf138f
--- /dev/null
+++ b/src/fuzzers/cpp/HTMLLayoutFuzzer.cpp
@@ -0,0 +1,89 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "stdint.h"
+#include <log4cxx/logstring.h>
+#include <log4cxx/ndc.h>
+#include <log4cxx/helpers/stringhelper.h>
+#include <fuzzer/FuzzedDataProvider.h>
+#include <log4cxx/mdc.h>
+#include <log4cxx/htmllayout.h>
+
+using namespace log4cxx;
+using namespace log4cxx::helpers;
+using namespace log4cxx::spi;
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
+       // Setup HTMLLayout
+       HTMLLayout layout;
+       log4cxx::helpers::Pool p;
+
+       FuzzedDataProvider fdp(data, size);
+
+       // Optional locationinfo
+       if (fdp.ConsumeBool()) {
+               layout.setOption(LOG4CXX_STR("LOCATIONINFO"), 
LOG4CXX_STR("true"));
+       }
+       // Optional threadinfo
+       if (fdp.ConsumeBool()) {
+               LOG4CXX_DECODE_CHAR(title, fdp.ConsumeRandomLengthString());
+               layout.setOption(LOG4CXX_STR("TITLE"), title);
+       }
+
+       // Header
+       if (fdp.ConsumeBool()) {
+               std::string headerStr = fdp.ConsumeRandomLengthString();
+               layout.appendHeader(LOG4CXX_STR(headerStr), p);
+       }
+
+       // Create random strings we need later
+       std::string key1 = fdp.ConsumeRandomLengthString();
+       std::string val1 = fdp.ConsumeRandomLengthString();
+       std::string key2 = fdp.ConsumeRandomLengthString();
+       std::string val2 = fdp.ConsumeRandomLengthString();
+       std::string key3 = fdp.ConsumeRandomLengthString();
+       std::string val3 = fdp.ConsumeRandomLengthString();
+       std::string key4 = fdp.ConsumeRandomLengthString();
+       std::string val4 = fdp.ConsumeRandomLengthString();
+       std::string ndcMessage = fdp.ConsumeRandomLengthString();
+       std::string loggerStr = fdp.ConsumeRandomLengthString();
+       std::string content = fdp.ConsumeRemainingBytesAsString();
+
+       log4cxx::LogString logger = LOG4CXX_STR(loggerStr);
+       log4cxx::LevelPtr level = log4cxx::Level::getInfo();
+       log4cxx::NDC::push(ndcMessage);
+       log4cxx::spi::LoggingEventPtr event = log4cxx::spi::LoggingEventPtr(
+               new log4cxx::spi::LoggingEvent(
+                       logger, level, LOG4CXX_STR(content), LOG4CXX_LOCATION));
+
+       // Set properties
+       event->setProperty(LOG4CXX_STR(key1), LOG4CXX_STR(val1));
+       event->setProperty(LOG4CXX_STR(key2), LOG4CXX_STR(val2));
+
+       // Set MDC
+       log4cxx::MDC::put(key3, val3);
+       log4cxx::MDC::put(key4, val4);
+
+       // Call the target API
+       log4cxx::LogString result;
+       layout.format(result, event, p);
+
+       // Clean up
+       log4cxx::NDC::clear();
+       log4cxx::MDC::clear();
+       return 0;
+}

Reply via email to