Skip to content

Commit

Permalink
Upgrade to Montoya API
Browse files Browse the repository at this point in the history
  • Loading branch information
CoreyD97 committed Dec 2, 2022
1 parent 109d95f commit 0b0da49
Show file tree
Hide file tree
Showing 58 changed files with 859 additions and 1,090 deletions.
29 changes: 15 additions & 14 deletions build.gradle
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
apply plugin: 'java'
plugins {
id 'java'
id "io.freefair.lombok" version "6.5.1"
}

sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17

sourceCompatibility = 15
targetCompatibility = 15

repositories {
mavenCentral()
Expand All @@ -11,18 +15,15 @@ repositories {
}

dependencies {
compileOnly 'net.portswigger.burp.extender:burp-extender-api:2.3'
// compileOnly 'net.portswigger.burp.extender:montoya-api:0.9.5'
compileOnly 'org.projectlombok:lombok:1.18.24'
annotationProcessor 'org.projectlombok:lombok:1.18.24'

implementation 'net.portswigger.burp.extensions:montoya-api:0.10.1'
implementation 'org.swinglabs:swingx:1.6.1'
implementation 'com.github.CoreyD97:BurpExtenderUtilities:e800fd2d'
implementation 'com.google.code.gson:gson:2.8.2'
implementation 'org.elasticsearch.client:elasticsearch-rest-high-level-client:7.5.2'
implementation 'org.apache.httpcomponents:httpclient:4.5.6'
implementation 'org.apache.commons:commons-text:1.7'
implementation 'org.apache.logging.log4j:log4j-core:2.17.1'
implementation 'com.github.CoreyD97:BurpExtenderUtilities:896a540db7'
implementation 'org.elasticsearch.client:elasticsearch-rest-high-level-client:7.15.2'
implementation 'org.apache.httpcomponents:httpclient:4.5.13'
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")
}

jar {
Expand Down
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
23 changes: 0 additions & 23 deletions src/main/java/burp/BurpExtender.java

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
package com.nccgroup.loggerplusplus;

import burp.IContextMenuFactory;
import burp.IContextMenuInvocation;
import burp.api.montoya.core.Range;
import burp.api.montoya.http.message.HttpMessage;
import burp.api.montoya.ui.contextmenu.ContextMenuEvent;
import burp.api.montoya.ui.contextmenu.ContextMenuItemsProvider;
import burp.api.montoya.ui.contextmenu.MessageEditorHttpRequestResponse;
import com.nccgroup.loggerplusplus.filter.colorfilter.ColorFilter;
import com.nccgroup.loggerplusplus.filter.logfilter.LogFilter;
import com.nccgroup.loggerplusplus.filter.parser.ParseException;
Expand All @@ -19,53 +22,50 @@

import static com.nccgroup.loggerplusplus.util.Globals.PREF_COLOR_FILTERS;

public class LoggerContextMenuFactory implements IContextMenuFactory {

private final LoggerPlusPlus loggerPlusPlus;
public class LoggerContextMenuFactory implements ContextMenuItemsProvider {

public LoggerContextMenuFactory(LoggerPlusPlus loggerPlusPlus){
this.loggerPlusPlus = loggerPlusPlus;
public LoggerContextMenuFactory(){
}

@Override
public List<JMenuItem> createMenuItems(IContextMenuInvocation invocation) {
if(invocation == null) return null;
public List<JMenuItem> provideMenuItems(ContextMenuEvent event) {
JMenuItem filterMenu = new JMenu("Logger++");

if (invocation.getSelectedMessages().length == 0 ||
invocation.getSelectionBounds()[0] == invocation.getSelectionBounds()[1]) {
return null;
}
//We're handling a message editor context menu
//And we have a selection
MessageEditorHttpRequestResponse requestResponse = event.messageEditorRequestResponse().orElseThrow();
Range selectedRange = requestResponse.selectionOffsets().orElseThrow();
HttpMessage target;

final LogEntryField context;
final byte[] selectedBytes;
switch (invocation.getInvocationContext()){
case IContextMenuInvocation.CONTEXT_MESSAGE_EDITOR_REQUEST:
case IContextMenuInvocation.CONTEXT_MESSAGE_VIEWER_REQUEST: {
switch (event.invocationType()){
case MESSAGE_EDITOR_REQUEST:
case MESSAGE_VIEWER_REQUEST: {
target = requestResponse.getRequestResponse().httpRequest();
try {
byte[] msg = invocation.getSelectedMessages()[0].getRequest();
if (LoggerPlusPlus.callbacks.getHelpers().analyzeRequest(msg).getBodyOffset() > invocation.getSelectionBounds()[0]) {
if (selectedRange.startIndexInclusive() <= target.bodyOffset()) {
context = LogEntryField.REQUEST_HEADERS;
} else {
context = LogEntryField.REQUEST_BODY;
}
selectedBytes = Arrays.copyOfRange(invocation.getSelectedMessages()[0].getRequest(),
invocation.getSelectionBounds()[0],invocation.getSelectionBounds()[1]);
selectedBytes = Arrays.copyOfRange(target.asBytes().getBytes(), selectedRange.startIndexInclusive(),
selectedRange.endIndexExclusive());
}catch (NullPointerException nPException){ return null; }
break;
}

case IContextMenuInvocation.CONTEXT_MESSAGE_EDITOR_RESPONSE:
case IContextMenuInvocation.CONTEXT_MESSAGE_VIEWER_RESPONSE: {
case MESSAGE_EDITOR_RESPONSE:
case MESSAGE_VIEWER_RESPONSE: {
target = requestResponse.getRequestResponse().httpResponse();
try {
byte[] msg = invocation.getSelectedMessages()[0].getResponse();
if (LoggerPlusPlus.callbacks.getHelpers().analyzeRequest(msg).getBodyOffset() > invocation.getSelectionBounds()[0]) {
if (selectedRange.startIndexInclusive() <= target.bodyOffset()) {
context = LogEntryField.RESPONSE_HEADERS;
} else {
context = LogEntryField.RESPONSE_BODY;
}
selectedBytes = Arrays.copyOfRange(invocation.getSelectedMessages()[0].getResponse(),
invocation.getSelectionBounds()[0], invocation.getSelectionBounds()[1]);
selectedBytes = Arrays.copyOfRange(target.asBytes().getBytes(), selectedRange.startIndexInclusive(),
selectedRange.endIndexExclusive());
} catch (NullPointerException nPException) {
return null;
}
Expand All @@ -75,15 +75,13 @@ public List<JMenuItem> createMenuItems(IContextMenuInvocation invocation) {
return null;
}

if (selectedBytes != null) System.out.println(new String(selectedBytes));

final LogTable logTable = loggerPlusPlus.getLogViewController().getLogTableController().getLogTable();
final LogTable logTable = LoggerPlusPlus.instance.getLogViewController().getLogTableController().getLogTable();
String selectedText = StringEscapeUtils.escapeJava(new String(selectedBytes));

JMenuItem useAsFilter = new JMenuItem(new AbstractAction("Use Selection As LogFilter") {
@Override
public void actionPerformed(ActionEvent actionEvent) {
loggerPlusPlus.getLogViewController().getLogFilterController().setFilter(context.getFullLabel() +
LoggerPlusPlus.instance.getLogViewController().getLogFilterController().setFilter(context.getFullLabel() +
" CONTAINS \"" + selectedText + "\"");
}
});
Expand All @@ -95,23 +93,23 @@ public void actionPerformed(ActionEvent actionEvent) {
JMenuItem andFilter = new JMenuItem(new AbstractAction("AND") {
@Override
public void actionPerformed(ActionEvent actionEvent) {
loggerPlusPlus.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " && "
LoggerPlusPlus.instance.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " && "
+ "" + context.getFullLabel() + " CONTAINS \"" + selectedText + "\"");
}
});

JMenuItem andNotFilter = new JMenuItem(new AbstractAction("AND NOT") {
@Override
public void actionPerformed(ActionEvent actionEvent) {
loggerPlusPlus.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " && !("
LoggerPlusPlus.instance.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " && !("
+ "" + context.getFullLabel() + " CONTAINS \"" + selectedText + "\")");
}
});

JMenuItem orFilter = new JMenuItem(new AbstractAction("OR") {
@Override
public void actionPerformed(ActionEvent actionEvent) {
loggerPlusPlus.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " || "
LoggerPlusPlus.instance.getLogViewController().getLogFilterController().setFilter(logTable.getCurrentFilter().toString() + " || "
+ context.getFullLabel() + " CONTAINS \"" + selectedText + "\"");
}
});
Expand All @@ -126,11 +124,11 @@ public void actionPerformed(ActionEvent actionEvent) {
public void actionPerformed(ActionEvent actionEvent) {
try {
ColorFilter colorFilter = new ColorFilter();
colorFilter.setFilter(new LogFilter(loggerPlusPlus.getLibraryController(),
colorFilter.setFilter(new LogFilter(LoggerPlusPlus.instance.getLibraryController(),
context.getFullLabel() + " CONTAINS \"" + selectedText + "\""));
HashMap<UUID,ColorFilter> colorFilters = loggerPlusPlus.getPreferencesController().getPreferences().getSetting(PREF_COLOR_FILTERS);
HashMap<UUID,ColorFilter> colorFilters = LoggerPlusPlus.instance.getPreferencesController().getPreferences().getSetting(PREF_COLOR_FILTERS);
colorFilters.put(colorFilter.getUUID(), colorFilter);
new ColorFilterDialog(loggerPlusPlus.getLibraryController()).setVisible(true);
new ColorFilterDialog(LoggerPlusPlus.instance.getLibraryController()).setVisible(true);
} catch (ParseException e) {
return;
}
Expand Down
Loading

0 comments on commit 0b0da49

Please sign in to comment.