# Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one # or more contributor license agreements. Licensed under the Elastic License # 2.0; you may not use this file except in compliance with the Elastic License # 2.0. # Name: msxsl.exe Network # RTA: msxsl_network.py # ATT&CK: T1127 # Description: Generates network traffic from msxsl.exe from . import common from . import RtaMetadata metadata = RtaMetadata( uuid="a8331ff5-2199-48cf-9284-88351c859835", platforms=["windows"], endpoint=[], siem=[{"rule_id": "b86afe07-0d98-4738-b15d-8d7465f95ff5", "rule_name": "Network Connection via MsXsl"}], techniques=["T1220"], ) MS_XSL = common.get_path("bin", "msxsl.exe") XML_FILE = common.get_path("bin", "customers.xml") XSL_FILE = common.get_path("bin", "cscript.xsl") @common.requires_os(*metadata.platforms) @common.dependencies(MS_XSL, XML_FILE, XSL_FILE) def main(): common.log("MsXsl Beacon") server, ip, port = common.serve_web() common.clear_web_cache() new_callback = "http://%s:%d" % (ip, port) common.log("Updating the callback to %s" % new_callback) common.patch_regex(XSL_FILE, common.CALLBACK_REGEX, new_callback) common.execute([MS_XSL, XML_FILE, XSL_FILE]) server.shutdown() if __name__ == "__main__": exit(main())