Investigation into the following Snort signatures uncovered XSS with anti-analysis code.
Snort Signaures:
- ET WEB_SPECIFIC_APPS Microhard Systems 3G/4G Cellular Ethernet and Serial Gateway - Default Credentials
- ET POLICY Incoming Basic Auth Base64 HTTP Password detected unencrypted
- http_inspect: UNESCAPED SPACE IN HTTP URI
The traffic was actually various WordPress XSS attempts targeting vulnerabilities released primarily in the later half of 2019:
- FV Flowplayer Video Player <= 7.3.13.727 - Unauthenticated Stored XSS
- Simple Fields <= 1.4.11 - Unauthenticated Stored XSS
- WordPress Plugin Poll, Survey, Quiz & Form by OpinionStage XSS Vulnerability
- Coming Soon Page & Maintenance Mode v1.8.0 Unauthenticated Persistent XSS Injection
Sample Payload:
data:image/s3,"s3://crabby-images/73a23/73a230b32dcd81308d573a73dae951e2dd107921" alt=""
data:image/s3,"s3://crabby-images/6af27/6af27c9eaad0be7e6c201511c8d3e947f33be5cf" alt=""
For the above URL's (minus the JPG), CURL returns XSS JavaScript armed with an anti-analysis check. When the URL's are opened in a browser a redirect chain is initiated to a landing page attempting to gain "allow" permission in Chrome.
Sample of obfuscated XSS Javascript:
data:image/s3,"s3://crabby-images/cbe5e/cbe5e3b4abf6726a9bde54e34475e4538984cb01" alt=""
data:image/s3,"s3://crabby-images/b53c2/b53c2cc600f885e1ae76950301f86c961a96ec71" alt=""
data:image/s3,"s3://crabby-images/3e8a0/3e8a0711f6fee59b54e9f78bdacab0ff5a1cc70f" alt=""
data:image/s3,"s3://crabby-images/c7023/c70237dbb6c2ed1a1b97f4843befed1a9e3b2fb0" alt=""
Deobfuscated JavaScript:
data:image/s3,"s3://crabby-images/6ba72/6ba722b48ec88e202e37016529b06dd8f5c19ccf" alt=""
JavaScript function checkone() logic:
- If a cookie named "_logged_in" is found, the XSS JavaScript is returned.
- If a cookie named "_logged_in" is not found but the URL contains the string "/wp-admin", the XSS JavaScript is returned.
- If a cookie named "_logged_in" is not found and the URL doesn't contain the string "/wp-admin", the URL is replaced with "hxxps://request.admarketlocation[.]com/go.php?p=313422455290017394&n=7986r8t6r56n5bwvfdehr&id=5478&sid=9"
The XSS JavaScript would create a new user in the context of a logged in admin user.
XSS JavaScript with Anti-Analysis Technique