Skip to content

Traffic Encoders

Joe edited this page Jan 21, 2023 · 18 revisions

⚠️ This page describes an unreleased feature from an upcoming version ⚠️

As of v1.6.0 Sliver supports user-defined "Traffic Encoders," which can be used to arbitrarily modify the Sliver implant's network communication patterns. Traffic Encoders are WASM-based callback functions that encode/decode network traffic between the implant and the server. Traffic encoders can be written in any language that compiles to WASM.

Example are provided in this repository of a Rust-based and a TinyGo-based encoder. For performance reasons we recommend implementing Traffic Encoders in Rust.

For performance reasons, by default C2 messages over 2Mb are NOT passed through user-defined Traffic Encoders, but instead always use a native built-in encoder.

Traffic Encoder Specification

Traffic encoders are implemented in WASM, and must export the following functions:

decode(ptr, size uint32) (ptrSize uint64)
encode(ptr, size uint32) (ptrSize uint64)

malloc(size uint64)
free(ptr uint64)

The encode function takes a uint32 pointer to a buffer and the uint32 size of the buffer, and returns a uint64 value where the upper 32 bits are a pointer to the address of the buffer and the lower 32 bits are the size of the buffer.

The decode function takes a uint32 pointer to a buffer and the uint32 size of the buffer, and returns a uint64 value where the upper 32 bits are a pointer to the address of the buffer and the lower 32 bits are the size of the buffer.

For example, a return value in Go may look like:

return (uint64(ptr) << uint64(32)) | uint64(size)

Where ptr is a pointer to the buffer and size is the size of the buffer.

Debug Log

Optionally, the following import may be used:

log(ptr uint32, size uint32)

This function takes a pointer to a buffer and the size of the buffer, and logs the contents of the buffer to the console if the implant is in debug mode. On the server will also log the contents if configured to log at the DEBUG level or higher.

Clone this wiki locally