Custom Build
This section details how to build custom build a Merlin Agent using the Make file.
NOTE: Merlin is distributed with pre-compiled agent binaries for all major platforms in the data/bin
directory.
Basic
The provided Make file can be used to build a new agent from source. It is recommended that you first use
go get github.com/Ne0nd0g/merlin-agent
to pull a copy of the Merlin source code to the host. Move into the Merlin root
directory where the Make file is located.
Windows agent:
make windows
Linux agent:
make linux
macOS agent:
make darwin
MIPS agent:
make mips
ARM agent:
make arm
Advanced
Use the provided Make file to build a Merlin Agent with hard coded values. This removes the need for an operator to use commandline arguments and allows the Agent to simply be executed. The table below shows configurable compile options
View the Listeners page for additional information on specific listener configurable options.
Option |
Description |
Notes |
---|---|---|
ADDR |
The interface and port for peer-to-peer agents to bind or connect to |
Overrides the |
AUTH |
The method of Agent authentication to the server |
Overrides the |
HEADERS |
Comma Separated list of HTTP headers to send with every HTTP request. |
Overrides the |
HOST |
HTTP Host header |
Overrides the |
JA3 |
JA3 signature string (not the MD5 hash) |
Overrides the |
KILLDATE |
The date, as a Unix EPOCH timestamp, that the agent will quit running |
Overrides the |
LISTENER |
The UUID of the listener that the peer-to-peer agent is configured to communicate with. |
Overrides the |
RETRY |
The maximum amount of failed checkins before the agent will quit running |
Overrides the |
PAD |
The maximum amount of data that will be randomly selected and appended to every message |
Overrides the |
PARROT |
Configure the HTTP client’s TLS configuration to match the provided browser string |
Overrides the |
PROTO |
Protocol for the agent to connect with [https (HTTP/1.1), http (HTTP/1.1 Clear-Text), h2 (HTTP/2), h2c (HTTP/2 Clear-Text), http3 (QUIC or HTTP/3.0)] (default ‘h2’) |
Overrides the |
PROXY |
Hardcoded proxy to use for http/1.1 traffic only that will override host configuration |
Overrides the |
PSK |
Pre-Shared Key used to encrypt initial communications (default “merlin”) |
Overrides the |
SECURE |
Require TLS certificate validation for HTTP communications |
Overrides the |
SKEW |
Amount of skew, or variance, between agent checkins |
Overrides the |
SLEEP |
The amount of time the Agent will sleep between checkins Must use golang time notation (e.g., |
Overrides the |
TRANSFORMS |
Ordered CSV of transforms to construct a message with |
Overrides the |
URL |
Full URL for agent to connect to (default “https://127.0.0.1:443”) |
Overrides the |
USERAGENT |
The HTTP User-Agent header string that Agent will use while sending traffic |
Overrides the |
An example of creating a new Linux HTTP agent that is using domain fronting through https://merlin.com/c2endpoint.php
using a PSK of SecurePassword1
:
make linux URL=https://merlin.com:443/c2endpoint.php HOST=myendpoint.azureedge.net PROTO=https PSK=SecurePassword1
Windows Agent
The Windows Merlin Agent executable is compiled as a GUI application instead of console application. The Merlin Agent
does not have a GUI component. The reason this is used is so that the Merlin Agent window disappears after it is executed.
This behavior is intentional so that the user will not see the application window. This is done with the LDFLAGS when
building the agent using the -H=windowsgui
option as shown here
This causes problems when a user WANTS to see the Merlin Agent verbose or debug output. To view Merlin verbose/debug
output, use the Makefile windows-debug
target (e.g., make windows-debug
)
Cross-Compiling
The Merlin agent and server can be cross-compiled to any operating system or architecture. A list of golang supported operating systems and architectures can be found here: https://golang.org/doc/install/source#environment
$GOOS |
$GOARCH |
---|---|
android |
arm |
darwin |
386 |
darwin |
amd64 |
darwin |
arm |
darwin |
arm64 |
dragonfly |
amd64 |
freebsd |
386 |
freebsd |
amd64 |
freebsd |
arm |
linux |
386 |
linux |
amd64 |
linux |
arm |
linux |
arm64 |
linux |
ppc64 |
linux |
ppc64le |
linux |
mips |
linux |
mipsle |
linux |
mips64 |
linux |
mips64le |
netbsd |
386 |
netbsd |
amd64 |
netbsd |
arm |
openbsd |
386 |
openbsd |
amd64 |
openbsd |
arm |
plan9 |
386 |
plan9 |
amd64 |
solaris |
amd64 |
windows |
386 |
windows |
amd64 |