/wscript

Primary LanguageJavaScriptMIT LicenseMIT

WScript Emulator

Build Status Coverage Status

WScript Emulator is an emulator/tracer of the Windows Script Host functionality. It provides a full Javascript equivalent of WScript, so most valid scripts running against it will work as if they were running in the regular WScript environment. Most components have been ported, though some are lacking because of scope (f.e. Microsoft.XMLDOM, ApplicationObject). But nearly all common functionality is present in the object. For a full list of supported functionality, see the supported objects section.

Because WScript Emulator is pure Javascript, it will run in any recent browser on any platform. And because we actually run the original script against the emulator, javascript-obfuscation of the original file is irrelevant. The emulator does not modify the provided script in any way, it runs as-is.

Warnings

If you were to use the WScript Emulator to analyse WScript-based malware downloaders, take all necessary precautions as you would for any other analysis. The emulator does not execute any HTTP-requests, registry changes or filesystem modifications, but you are still running a malicious file. Use only if you are confident (or confidently suspect) that the file is a WScript file, and always at your own risk.

Tracer

The WScript Emulator contains a full code tracer, listing every class-construct, function call, getters & setters that occur while running a script. Even when the original script is 100% triple-obfuscated with JSFuck, it will trace all functions as if it weren't obfuscated at all.

VFS

In order to track creating/modifying/deleting files that would normally occur on the filesystem, the emulator contains a mock filesystem. This helps to easily see what the script would do to your filesystem if it was running in the normal WScript environment.

Supported objects

Additional objects:

Helpers:

Not supported:

Limitations

It currently only supports JScript variants of WScript, not the VBScript variant. WScript originally supports both the VB and JS syntax, but emulating VB syntax in pure Javascript is out of scope for this project.

The emulator does not download any files when the original script calls for it. This is done for security reasons. It does show which URL is being requested and where the file would've been saved to in the VFS (but without the file's contents).

In addition to this, the emulator page removes XMLHTTPRequest and fetch from the global window-object. It is easily replacable with other JS functionality though

WScript/JScript quirks

JScript is Microsoft's flavour of the ECMAscript standard. This means that most ECMAscript rules still apply, but JScript's implementation in WScript is a bit different:

JScript in WScript is case-insensitive.

Regular JScript, like all ECMAscript variants, is case-sensitive (there is a difference between getValue and getvalue). But VBScript is not case-sensitive. Because WScript supports both VB and JS, Microsoft opted to make JScript in WScript case-insensitive as well. For more information on how the emulator handles case-insensitive functions in Javascript, see this blogpost.

true === -1

In WScript, false === 0, but true === ~false (-1). Because we cannot redefine true in javascript, this cannot be circumvented. If you find scripts relying on true === -1, please let me know.

Requirements

  • For use: any recent browser that supports the ES6 syntax and Proxy & Reflect objects. (Chrome >= 49.0, Firefox >= 42, Edge >= 14, Safari >= 10)
  • For development: NodeJS >= 6.4

Developement

This package contains a full emulated version of WScript with 100% test coverage. Every file has been named as expected, every documented method has a link to the official WScript documentation describing what the feature should do. If you want to contribute to this project, please keep the following in mind:

  • Every method should behave as identical as possible to original WScript code. See Microsoft's documentation for this
  • Everything must be covered by tests

Development setup

git clone https://github.com/mrpapercut/wscript.git
cd wscript
npm install
npm run test-coverage
npm run build

The HTML emulator can then be found in /dist/