Skip to content

Docker container built to be one click runnable Hashtopolis agent on VastAI.

License

Notifications You must be signed in to change notification settings

ThatOnePasswordWas40Passwords/vast-hashtopolis-runner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vast-hashtopolis-runner

Based off Thenaaaa forked off of original Milz0 repo.

TODO:

  • Github CI + container publish

Requirements

  • docker cli
  • Container engine (tested with colima on macOS)
  • GNU Make and GNU utils

Build

make

... verbosely:

make VERBOSE=y

... with arbitrary docker CLI args, use envar EXTRA_DOCKER_ARGS:

make VERBOSE=y EXTRA_DOCKER_ARGS="--no-cache <etc.>"

Publish

Need access to Github Container Registry set up, then:

make PUBLISH=y

Github Container Registry setup

TODO

Running

Local CLI:

docker run --rm \
    -it \
    --platform linux/amd64 \
    ghcr.io/thatonepasswordwas40passwords/vast-hashtopolis-runner

Via Vast.ai

Edit Image & Config and use ghcr.io/thatonepasswordwas40passwords/vast-hashtopolis-runner as your custom image.

Your onstart-script should be written out as so in vast.ai, not before replacing both values <server> and <voucher_id> with your own:

cd htpclient
python3 hashtopolis.zip --url <server> --voucher <voucher_id>

Hashtopolis, Hashcat v6.x.x, Vast.ai

This container is useful for quickly! deploying lots of agents from vast.ai to your hashtopolis server with single clicks for an on-demand hash cracking session.

You should be familiar with the prerequisites for hashcat and hashtopolis, this isn't a step-by-step guide as such, It's half the battle is if you already have access to a hashtopolis server.

Prerequisites

In order to fully utilise this container you'll require the following...

Usage and Information

This is a one click set-up with vast.ai. Just click "Rent" button and your client will auto register with your hashtopolis server and will instantly start working on any available tasks you have waiting.

This container takes the pain out of manually checking boxes and adding in additional parameters for each agent if you want to register a lot of agents at one time.

Hashtopolis Modifications

You'll notice that each time you register an agent to your HTP server that you need to manually update the Agent Trust Status and you'll also receive a hashcat error clGetPlatformIDs(): CL_PLATFORM_NOT_FOUND_KHR, but we can fix this easily in hashtopolis the whitelist feature for errors.

Normally hashcat itself will ignore this error and continue but in hashtopolis's case it will take the error as fatal and halt the agent as by default the agent is set to be deactivated on any errors returned by hashcat.

whitelist this error in hashtopolis server settings. Enter clGetPlatformIDs(): CL_PLATFORM_NOT_FOUND_KHR in Server Settings page config.php where it says Ignore error messages from crackers which contain given strings (multiple values are separated by comma)

Workaround for Trust Agent

Add a cron script on your hashtopolis server to periodically update the your hashtopolis MySQL database every 1 minute or so to set new agents as trusted. modify this line to suit your own environment if need be.

cd ~/
echo mysql -D your_hashtopolis_db -e \"UPDATE Agent SET isTrusted = '1'\" > set_trust.sh && chmod +x set_trust.sh

type crontab -e and add...

* * * * * /root/set_trust.sh >/dev/null 2>&1

Alt text

config.json

You need to have reusable voucher codes checked in your hashtopolis install. Go to https://{your_domain}/config.php?view=5 and check box to allow vouchers to be use multiple times.

Vast.ai

Edit Image & Config and use ghcr.io/thatonepasswordwas40passwords/vast-hashtopolis-runner as your custom image

Your onstart-script should be written out as so in vast.ai, not before replacing both values {server} and {voucher_id} with your own:

cd htpclient
python3 hashtopolis.zip --url {server} --voucher {voucher_id}

Alt text

Miscellaneous

For additional parameters like -w4 (workload) and -O (optimized kernels), You can set these globally per task in the command box #HL#

Demo

Demo

Enjoy!

About

Docker container built to be one click runnable Hashtopolis agent on VastAI.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages