From e5757d1e11f8f421f60c83ca809203e559d978d9 Mon Sep 17 00:00:00 2001 From: Ramana Reddy Date: Thu, 5 Sep 2024 19:32:16 +0530 Subject: [PATCH 1/3] allow links clickable in template editor --- .../nuclei/gui/TemplateGeneratorTab.java | 74 +++++++++++++++---- 1 file changed, 60 insertions(+), 14 deletions(-) diff --git a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java index cc99196..61d4e2c 100644 --- a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java +++ b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java @@ -20,15 +20,20 @@ import org.yaml.snakeyaml.error.YAMLException; import javax.swing.*; +import javax.swing.event.MouseInputAdapter; +import javax.swing.text.BadLocationException; import javax.swing.text.JTextComponent; import java.awt.*; import java.awt.datatransfer.Clipboard; import java.awt.datatransfer.StringSelection; import java.awt.event.InputEvent; import java.awt.event.KeyEvent; +import java.awt.event.MouseEvent; import java.io.File; import java.io.IOException; import java.io.InputStream; +import java.net.URI; +import java.net.URISyntaxException; import java.net.URL; import java.nio.file.Files; import java.nio.file.Path; @@ -121,14 +126,14 @@ private String createCommand(Path nucleiPath, URL targetUrl) { } return String.format("%s -v -t %s -u %s", - wrapWithQuotesIfNecessary(nucleiPath.toString()), - wrapWithQuotesIfNecessary(this.templatePath.toString()), - wrapWithQuotesIfNecessary(targetUrl.toString())); + wrapWithQuotesIfNecessary(nucleiPath.toString()), + wrapWithQuotesIfNecessary(this.templatePath.toString()), + wrapWithQuotesIfNecessary(targetUrl.toString())); } private static String wrapWithQuotesIfNecessary(String input) { return input.contains(" ") ? String.format("\"%s\"", input) - : input; + : input; } private void setKeyboardShortcuts() { @@ -221,6 +226,7 @@ private void setupAutoCompletion(RSyntaxTextArea textEditor) { } } + private RSyntaxTextArea createSmartTextEditor(String templateYaml) { // TODO https://github.com/bobbylight/RSyntaxTextArea/issues/269 JTextComponent.removeKeymap("RTextAreaKeymap"); @@ -249,9 +255,49 @@ private RSyntaxTextArea createSmartTextEditor(String templateYaml) { setupAutoCompletion(textEditor); + textEditor.addMouseListener(new MouseInputAdapter() { + @Override + public void mouseClicked(MouseEvent e) { + if (e.getClickCount() == 2) { // Trigger on double-click + int offset = textEditor.viewToModel2D(e.getPoint()); + String url = getUrlAtOffset(textEditor, offset); + if (url != null) { + try { + Desktop.getDesktop().browse(new URI(url)); + } catch (IOException | URISyntaxException ex) { + ex.printStackTrace(); + } + } + } + } + }); + return textEditor; } + + private String getUrlAtOffset(RSyntaxTextArea textEditor, int offset) { + try { + int start = offset; + int end = offset; + while (start > 0 && !Character.isWhitespace(textEditor.getText(start - 1, 1).charAt(0))) { + start--; + } + while (end < textEditor.getDocument().getLength() && !Character.isWhitespace(textEditor.getText(end, 1).charAt(0))) { + end++; + } + + String potentialUrl = textEditor.getText(start, end - start); + if (potentialUrl.startsWith("http://") || potentialUrl.startsWith("https://")) { + return potentialUrl; + } + } catch (BadLocationException e) { + e.printStackTrace(); + } + return null; + } + + private JMenu createTemplateEditorMenuItems() { final JMenu templateMenu = new JMenu("Add"); templateMenu.add(createTemplateEditorClassificationMenu()); @@ -476,8 +522,8 @@ public void approveSelection() { final File selectedFile = getSelectedFile(); if (selectedFile.exists() && getDialogType() == SAVE_DIALOG) { final int result = JOptionPane.showConfirmDialog(this, "The selected file already exists. Do you want to overwrite it?", - "Overwrite existing file?", - JOptionPane.YES_NO_CANCEL_OPTION); + "Overwrite existing file?", + JOptionPane.YES_NO_CANCEL_OPTION); switch (result) { case JOptionPane.YES_OPTION: super.approveSelection(); @@ -511,14 +557,14 @@ private void executeButtonClick() { } CommandLineUtils.asyncExecuteCommand(command, - bufferedReader -> bufferedReader.lines() - .map(line -> line + "\n") - .forEach(line -> SwingUtilities.invokeLater(() -> { - this.outputPane.appendText(line, noColor); - this.outputPane.repaint(); - })), - exitCode -> SwingUtilities.invokeLater(() -> this.outputPane.appendText("\nThe process exited with code " + exitCode)), - this.nucleiGeneratorSettings::logError); + bufferedReader -> bufferedReader.lines() + .map(line -> line + "\n") + .forEach(line -> SwingUtilities.invokeLater(() -> { + this.outputPane.appendText(line, noColor); + this.outputPane.repaint(); + })), + exitCode -> SwingUtilities.invokeLater(() -> this.outputPane.appendText("\nThe process exited with code " + exitCode)), + this.nucleiGeneratorSettings::logError); } } } From 948cb7095fa257be08a583328a719db43bf2aab8 Mon Sep 17 00:00:00 2001 From: Ramana Reddy Date: Wed, 11 Sep 2024 10:59:06 +0530 Subject: [PATCH 2/3] make links action to ctrl+click --- .../nuclei/gui/TemplateGeneratorTab.java | 10 ++++------ .../nuclei/gui/TemplateGeneratorWindow.java | 2 ++ 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java index 61d4e2c..fe8fc0d 100644 --- a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java +++ b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorTab.java @@ -226,7 +226,6 @@ private void setupAutoCompletion(RSyntaxTextArea textEditor) { } } - private RSyntaxTextArea createSmartTextEditor(String templateYaml) { // TODO https://github.com/bobbylight/RSyntaxTextArea/issues/269 JTextComponent.removeKeymap("RTextAreaKeymap"); @@ -255,15 +254,16 @@ private RSyntaxTextArea createSmartTextEditor(String templateYaml) { setupAutoCompletion(textEditor); + // Add mouse listener for Ctrl + Click textEditor.addMouseListener(new MouseInputAdapter() { @Override public void mouseClicked(MouseEvent e) { - if (e.getClickCount() == 2) { // Trigger on double-click + if (e.getClickCount() == 1 && e.isControlDown()) { // Trigger on Ctrl + Click int offset = textEditor.viewToModel2D(e.getPoint()); String url = getUrlAtOffset(textEditor, offset); if (url != null) { try { - Desktop.getDesktop().browse(new URI(url)); + SwingUtils.openWebPage(new URI(url).toURL()); } catch (IOException | URISyntaxException ex) { ex.printStackTrace(); } @@ -275,7 +275,6 @@ public void mouseClicked(MouseEvent e) { return textEditor; } - private String getUrlAtOffset(RSyntaxTextArea textEditor, int offset) { try { int start = offset; @@ -297,7 +296,6 @@ private String getUrlAtOffset(RSyntaxTextArea textEditor, int offset) { return null; } - private JMenu createTemplateEditorMenuItems() { final JMenu templateMenu = new JMenu("Add"); templateMenu.add(createTemplateEditorClassificationMenu()); @@ -567,4 +565,4 @@ private void executeButtonClick() { this.nucleiGeneratorSettings::logError); } } -} +} \ No newline at end of file diff --git a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorWindow.java b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorWindow.java index 9085ea6..d7fa187 100644 --- a/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorWindow.java +++ b/src/main/java/io/projectdiscovery/nuclei/gui/TemplateGeneratorWindow.java @@ -113,6 +113,8 @@ public static void main(String[] args) throws Exception { " author: forgedhallpass\n" + " name: Template Name\n" + " severity: info\n" + + "reference:\n"+ + " - https://github.com/projectdiscovery/nuclei-templates\n"+ "http:\n" + " - raw:\n" + " - |\n" + From a50f164de5094f780cd11764b9501b2b39c7f182 Mon Sep 17 00:00:00 2001 From: Ramana Reddy Date: Wed, 11 Sep 2024 11:03:21 +0530 Subject: [PATCH 3/3] update upload artifact version --- .github/workflows/ci.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index 176a0b1..f71c606 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -18,7 +18,7 @@ jobs: run: mvn --batch-mode --update-snapshots verify - name: 'Upload Artifact' - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: nuclei-burp-plugin-SNAPSHOT-build path: target/nuclei-burp-plugin-1.1.3-SNAPSHOT-jar-with-dependencies.jar \ No newline at end of file