/appjaillauncher-rs

AppJailLauncher in Rust

Primary LanguageRustMIT LicenseMIT

AppJailLauncher (Rust)

AppJailLauncher is akin to a simple version of xinetd for Windows but with sandboxing enabled for the spawned child processes. The sandboxing is accomplished via AppContainers. This project is a rewrite of an earlier version in C.

Tested Platforms

  • Windows 10 Professional x64 (build 14393.1198)
  • Windows 10 Professional x64 (build 15063.296)

Supported Platforms

  • Windows 8 and above
  • Windows Server 2012 and above

Creating Challenges

There is an example challenge template in example/ that can be built using CMake.

To build the example challenge:

> cd example
> mkdir build
> cd build
> cmake ..
> cmake --build .

After building the example challenge, you serve the challenge via the following command in the root of the repository:

> .\target\debug\appjaillauncher-rs.exe run --key .\unittest_support\pub\key2.txt .\example\build\Debug\example_challenge.exe

Frequently Asked Questions

In the example challenge, what does InitChallenge do?

The InitChallenge function will create an timer that will terminate the process after a specified amount of milliseconds and set stdout buffering options to work better with network sockets. The first part is essential for countering griefing operations directed at your challenges by malicious actors.

I think I broke something. Is there a way to get more logging?

AppJailLauncher uses env_logger for logging. This means you can get more debug logging by setting the RUST_LOG environment variable to debug. For example, in PowerShell, the following command would be sufficient:

> $env:RUST_LOG="debug"

How do I target x86 Windows from x64 Windows with Rust?

rustup should be part of the default Rust install. First, use rustup to add the new x86 target:

> rustup target add i686-pc-windows-msvc

After installation, add --target=i686-pc-windows-msvc to the cargo build, cargo test commands to build for x86.

I have a complex ACL setup for my key, why won't things work?

Our ACL implementation is simple and should work on most configurations. However, it is entirely possible that for complex ACL setups, this will not work as intended. If you run into any issues, file an issue.

cargo build complains that msvc targets depend on msvc linker but "link.exe" was not found

You need to install the Visual C++ 2015 Build Tools or newer.

Development

Install Rust, then:

Build AppJailLauncher: cargo build

Run the unit tests: cargo test

Authors