Skip to content

sover02/honey_net

Repository files navigation

honey_net

Github action and docker container to deploy a honeypot network in AWS.

Powers: https://intercept.sh/threatlists/

Data retrieved, formatted, and uploaded by: https://github.com/sover02/honey_net_update_threatlists/actions

Using the Github Action

Example:

on:
  schedule:
    # Run at 5am UTC, midnight EST
    - cron:  '0 5 * * *'

jobs:
  cycle_honeypot_servers:
    runs-on: ubuntu-latest
    name: Cycle All Honeypot Servers
    steps:
    
    - name: honey_net
      uses: sover02/honey_net@master
      with:
        SSH_PUBLIC_KEY: ${{ secrets.SSH_PUBLIC_KEY }}
        SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
        AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
        AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
        AWS_DEFAULT_REGION: 'us-east-1'
        ELASTICSEARCH_HOST: ${{ secrets.ELASTICSEARCH_HOST }}
        ELASTICSEARCH_PORT: ${{ secrets.ELASTICSEARCH_PORT }}
        ELASTICSEARCH_SCHEME: ${{ secrets.ELASTICSEARCH_SCHEME }}
        ELASTICSEARCH_USER: ${{ secrets.ELASTICSEARCH_USER }}
        ELASTICSEARCH_PASSWORD: ${{ secrets.ELASTICSEARCH_PASSWORD }}
        ELASTICSEARCH_INDEX_PREFIX: 'honey-net'

Running Locally

To start, build the image straight from git, create an ssh keypair, copy and edit the env.list sample, and then run.

docker build git@github.com:sover02/honey_net.git#v1.5 -t sover02/honey_net:v1.5
ssh-keygen -t rsa -b 4096 -f ~/.ssh/honey_net_id_rsa
vim env.list # populate environment variables – sample: https://github.com/sover02/honey_net/blob/v1.5/env.list.sample
docker run --rm --env-file env.list -e "INPUT_SSH_PRIVATE_KEY=$(cat ~/.ssh/honeypot_ec2-user.pem)" -e "INPUT_SSH_PUBLIC_KEY=$(cat ~/.ssh/honeypot_ec2-user.pub)" sover02/honey_net:v1.5

Teardown

You can destroy all servers without rebuilding them by passing the "INPUT_TERRAFORM_DESTROY_ONLY" flag to the docker container.

Just add -e "INPUT_TERRAFORM_DESTROY_ONLY=true" as one of the variables to the above command.