Skip to content

Latest commit

 

History

History
244 lines (172 loc) · 10.9 KB

README.md

File metadata and controls

244 lines (172 loc) · 10.9 KB

ᵔᴥᵔ T-Pot CE - Fullscreen Optimized Attack Map

Twitter Follow GitHub issues GitHub closed issues GitHub license GitHub forks GitHub stars

The Web Attackmap currently included in T-Pot CE is not half bad, but it's really not optimized for running 24/7 on a dashboard monitor or big screen tv etc. This is just that. It has been scraped, tuned, optimized for running on big screen TV 24/7 - Perhaps not something most poeple need, but it did! Need that "bling bling" on a Big TV! ʘ‿ʘ

T-Pot Web Attackmap

Table of Contents

Why the need?

We all know this - Especially if you work in a SOC or with security in general. A lot of times to help outsiders or the un-initiated to understand how much noise, filth and unwanted traffic and attacks are going on in the universe at all times. It can be a very good and healty experience for them to see what a "live" attack map like this looks like in action.

This is also why i needed a more reliable and customizable version of this attack map. Simply as i needed to be able to showcase this "separately" from my T-Pot CE installation/host but also as something that needed to run 24/7 on a remote monitor that i would not have to micromanage or hear about breaking :)

Screenshot

This is what it looks like :)

Screenshot 1

Here is the menu i'm talking about, still needs some micro adjustments on style/layout but you get the idea. Connection status, Sound and Pause on right side etc.

Screenshot 2

The menu goes away after 5 sec

What changes have i made ?

I removed a lot of the functionality that was not needed on the fullscreen setup, as usually there are no peripherals connected to it anyway. Only the first time when you're doing the setup etc. Then i added some cool options that you can enable/disable etc on setup.

Things removed

The following things was removed from the "original" attackmap (map_web).

  • Any attempt to make a "update()" function for SVG redraw/3d translation
  • Down scaled the max markers and circles allowed on map
  • Fixed and locked Zoom
  • No movement of map
  • Removed all "popup/panes" for circles and markers

New features

The following new features have been added:

  • Pause or Resume attack animations
  • Enable or Disable sound effects :)
  • Ability to select what sensors you want to show
  • Enable or Disable showing statistical information
  • Enable or Disable anonymization of Source-IP addresses
  • Auto hide menu after 5sec and mouse cursor
  • Automatic map zoom level based on monitor resolution
  • New markers for "Sensors" - Changeable by menu
  • Refresh button (Duuurh, just use F5...)
  • Adjusted max "circles" allowed on screen for better longevity
  • Data usage saving, when not visible or minimized - Pause websocket
  • Connection status indicator
  • Error handling for websocket to be better at surviving disconnects
  • Error handling for redis for be better at surviving disconnects
  • Making sure there are no "mem" leaks or buildups so we can run 24/7

The sound feature is a bit of a novelty! I highly doubt that it will make much sense unless it's some event/forum where you need to be extra flashy with the attackmap :D None the less i have included it and it's kinda fun to use !

Still on the drawing board

This is my todo list

  • Add a systemd service template file for easy implementation
  • Over 500 known services vs port added and colors added
  • Fix styling issues on menus
  • Make IP addresses change color based on IP reputation
  • Make Protocol name in Event log be the color of the animation
  • Even more new cool features ???

Installation

Please note that my installation is T-Pot as distributed (hive+sensors) but I also do not use the ISO. All my servers are already populated with Debian 11 so users/info might vary in your case. I have tried to make it fit standard T-Pot settings.

Prepare T-Pot map redis

First make sure your T-Pot Hive / Standalone installation is running with an exposed map_redis port. This is done by adding the following to tpot.yml on your T-pot CE Standalone / Hive host

ssh -i key.pem tsec@hive.ip -p 64295
sudo su -
nano /opt/tpot/etc/tpot.yml

In nano hit Ctrl^w and search for map_redis
Here you need to add the below lines right after tty: true

ports:
 - "64379:6379"

Now save and restart your installation (Standalone or Hive)
Next lest check to see if the port is forwarded correctly!

ssh -i key.pem tsec@hive.ip -p 64295
sudo /opt/tpot/bin/dps.sh | grep map_redis
map_redis       Up 2 min             0.0.0.0:64379->6379/tcp

Now you can reach map_redis on your T-Pot Hive/Standalone IP. Please be aware that any of the ports above 64000+ should be restricted!! See Security section.

WARNING
Now you can reach map_redis on your T-Pot Hive/Standalone IP. Please be aware that any of the ports above 64000+ should be restricted!! See Security section.

That's why you really should run a distributed solution in order to protect yourself better and have better segmentation on what is management part and what is sensors etc.

SSL/TLS Certificate files

On the server that is going to host the fullscreen t-pot attackmap.

sudo su -
apt install certbot

Install what ever plugin flavor you use!!
Here is AWS Route53 etc.

apt install python3-certbot-dns-route53
mkdir /root/.aws && chmod 700 /root/.aws

cat <<EOF>/root/.aws/credentials
[default]
aws_access_key_id=XXXXXXXXXXXXX
aws_secret_access_key=XXXxxXXXXxXxXxXxXxXX
EOF

Finally generate your SSL / TLS certificate files

certbot certonly --dns-route53 -d mydomain.tld

Download files

On the server that is going to host the fullscreen t-pot attackmap.

sudo su -
cd /opt
git clone https://github.com/kawaiipantsu/tpotce-fullscreen-attackmap.git

Also let's install NodeJS from NodeSource to get 19.x version. The old outdated NodeJS in Debian 11 is meh!

sudo su -
curl -fsSL https://deb.nodesource.com/setup_19.x | bash - &&\
apt-get install -y nodejs

Configuaration

Move the .env.example file to .env and edit it with your Hive IP and Certificate files.

sudo su -
cd /opt/tpotce-fullscreen-attackmap
cp .env.example .env
nano .env

Set the WebSocket Host/FQDN so clients can open a websocket back to the server

sudo su -
cd /opt/tpotce-fullscreen-attackmap
cp static/js/websocket-fqdn.example.js static/js/websocket-fqdn.js
nano static/js/websocket-fqdn.js

Download needed NodeJS modules/Extensions

sudo su -
cd /opt/tpotce-fullscreen-attackmap
npm install

Start the attackmap

You can just start it from command line directly in your ssh/shell like this

sudo su -
cd /opt/tpotce-fullscreen-attackmap
node main.js

[27-02-2023 16:58:38] info: WebSocket initialized, with zlib compression, concurrency limit = 10
[27-02-2023 16:58:38] info: Redis client initialized
[27-02-2023 16:58:38] warn: Web Attack Map - Web Server (https) & Websocket (wss) starting up
[27-02-2023 16:58:38] warn: Web Attack Map - Now listing for connections on port 443

I will add a systemd file in the future, this is todo.
For now i just wanted to get it pushed and out there. But you should absolutely run this via systemd!!

Security

I want to stress that working with any "honeypot" requires some constrain and firewall rules or protection in place. This goes for any infrastructure. But since i'm utilizing the build in (otherwise) protected map_redis container as reachable from outside network this means you will have to protect it.

But you should already have protection in place around your T-Pot CEt installation. Like only allowing "public" access to the installation on port 1 to 64000. And anthing above that should be considered "management" ports and should only be accessible from your trusted IP sources.

Even better you should use the HIVE / Sensor distributed solution so that you can have the Hive inside your internal network and sensors out in the wild!

Credits

This version of T-Pot CE attack map is the one that have been re-vamped by Marco Ochse (t3chn0m4g3) for the purpose of suiting T-Pot CE and their installation process and data collected by the honeypots.

The original attack map was created by Matthew Clark May.
First T-Pot based fork was released by Eddie4.

Licenses / Copyright

Bootstrap, D3, Flagpack, JQuery, Leaflet, OpenStreetMap.