diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index ca872924..4c2fb7a1 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -33,7 +33,7 @@ jobs: uses: actions/setup-java@v2 with: distribution: adopt - java-version: '15' + java-version: '17' # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL diff --git a/build.gradle b/build.gradle index 7a71a6a5..211a2a74 100644 --- a/build.gradle +++ b/build.gradle @@ -27,7 +27,7 @@ dependencies { implementation 'org.apache.commons:commons-text:1.10.0' implementation 'org.apache.logging.log4j:log4j-core:2.19.0' - testCompileOnly files("${System.properties['user.home']}/BurpSuitePro/burpsuite_pro.jar") + testRuntimeOnly files("${System.properties['user.home']}/BurpSuitePro/burpsuite_pro.jar") } jar { diff --git a/src/main/java/com/nccgroup/loggerplusplus/logging/JTextAreaAppender.java b/src/main/java/com/nccgroup/loggerplusplus/logging/JTextAreaAppender.java deleted file mode 100644 index 59482b62..00000000 --- a/src/main/java/com/nccgroup/loggerplusplus/logging/JTextAreaAppender.java +++ /dev/null @@ -1,88 +0,0 @@ -package com.nccgroup.loggerplusplus.logging; - -import org.apache.logging.log4j.core.*; -import org.apache.logging.log4j.core.appender.AbstractAppender; -import org.apache.logging.log4j.core.config.plugins.Plugin; -import org.apache.logging.log4j.core.config.plugins.PluginAttribute; -import org.apache.logging.log4j.core.config.plugins.PluginElement; -import org.apache.logging.log4j.core.config.plugins.PluginFactory; - -import javax.swing.*; -import java.util.ArrayList; - -import static javax.swing.SwingUtilities.invokeLater; -import static org.apache.logging.log4j.core.config.Property.EMPTY_ARRAY; -import static org.apache.logging.log4j.core.layout.PatternLayout.createDefaultLayout; - -/** - * JTextAreaAppender - https://stackoverflow.com/a/29736246 - * Credit to https://stackoverflow.com/users/4544015/vshiro - */ - -@Plugin(name = "JTextAreaAppender", category = Core.CATEGORY_NAME, elementType = Appender.ELEMENT_TYPE) -public class JTextAreaAppender extends AbstractAppender { - private static volatile ArrayList textAreas = new ArrayList<>(); - - private int maxLines; - - private JTextAreaAppender(String name, Layout layout, Filter filter, int maxLines, boolean ignoreExceptions) { - super(name, filter, layout, ignoreExceptions, EMPTY_ARRAY); - this.maxLines = maxLines; - } - - @SuppressWarnings("unused") - @PluginFactory - public static JTextAreaAppender createAppender(@PluginAttribute("name") String name, - @PluginAttribute("maxLines") int maxLines, - @PluginAttribute("ignoreExceptions") boolean ignoreExceptions, - @PluginElement("Layout") Layout layout, - @PluginElement("Filters") Filter filter) { - if (name == null) { - LOGGER.error("No name provided for JTextAreaAppender"); - return null; - } - - if (layout == null) { - layout = createDefaultLayout(); - } - return new JTextAreaAppender(name, layout, filter, maxLines, ignoreExceptions); - } - - // Add the target JTextArea to be populated and updated by the logging information. - public static void addLog4j2TextAreaAppender(final JTextArea textArea) { - JTextAreaAppender.textAreas.add(textArea); - } - - @Override - public void append(LogEvent event) { - String message = new String(this.getLayout().toByteArray(event)); - - // Append formatted message to text area using the Thread. - try { - invokeLater(() -> - { - for (JTextArea textArea : textAreas) { - try { - if (textArea != null) { - if (textArea.getText().length() == 0) { - textArea.setText(message); - } else { - textArea.append("\n" + message); - if (maxLines > 0 & textArea.getLineCount() > maxLines + 1) { - int endIdx = textArea.getDocument().getText(0, textArea.getDocument().getLength()).indexOf("\n"); - textArea.getDocument().remove(0, endIdx + 1); - } - } - String content = textArea.getText(); - textArea.setText(content.substring(0, content.length() - 1)); - } - } catch (Throwable throwable) { - throwable.printStackTrace(); - } - } - }); - } catch (IllegalStateException exception) { - exception.printStackTrace(); - } - } -} diff --git a/src/test/java/Test.java b/src/test/java/Test.java index 998ff084..e2ec439c 100644 --- a/src/test/java/Test.java +++ b/src/test/java/Test.java @@ -1,5 +1,12 @@ +import java.lang.reflect.Method; + public class Test { public static void main(String[] args) { - burp.StartBurp.main(args); + try { + Method main = Class.forName("burp.StartBurp").getMethod("main", String[].class); + main.invoke(null, (Object) args); + }catch (Exception e){ + System.err.println("Cannot start burp. Check the burp jar is correctly included in the classpath."); + } } }