/DDALITE

Proof of Concept for a Distributed Dictionary Attack for MGSV StrCode hashes

Primary LanguageGo

Disregard everything written below - I'm reducing the scope of this project to a simple collision tool. no kubernetes or networking or that sort of thing.

Overview

Jaeik, Jessey, Ken and Joseph Z's implementation of Project-2 for 200106-uta-go. This project is an automated provisioning system for instantiating multiple AWS EC2 machines as worker "collider" nodes, as well as building a Controller which distributes the workload evenly among the workers. The user can then request a decimal-formatted StrCode64 hash to be decrypted into its original string value.

Colliders are tasked with finding a StrCode64 hash collision for the user's inquiry. Upon recognizing a matching hash, the successful collider will return the hash - unhash pair to the Controller, who then returns the information to the client. The Collider Container is embedded with a literal dictionary for the Collider to reference as candidate, unhashed strings. StrCode64 is a particularly seeded cityhash64 function, and hashes can be generated using BobDoleOwndU's QuickHash tool. More details on StrCode64 can be found here. And, Although Colliders are designed to seek StrCode64 hashes, the logic can be swapped out with other hashing functions as necessity demands.

Instructions before build.

AWS IAM Information and Credintials stroage SETUP

  • create secrets directory in project terraform directory
  • create a creds.json file in the secrets directory use this as a template

creds.json

{

"access_key" : "value of access key",
"secret_key" : "value of secret key"

}
  • copy the access_key (from your AWS account Security Credential page) and secret_key (from the first time you created your AWS account) into the creds.json file.
  • next, create a EC2 Key Pair (How to create a key-pair can be found here and instructions on how to retrieve your public key can be found here)
  • place the private key in secrets directory call it private.pem
  • place the public key in secrets directory call it public.pub

Setup Image ID before Deployment Prior to deploying, an image needs to be created to act as a default machine for the tool.

  • change directory to the project root
  • run the make command in terminal: make image (NOTE: if you're using a virtual machine, make sure that the VM's time is correct!)
  • terraform will build the core image with docker, kubernetes and all depedencies
  • once finished navagate to AWS website and go to running ec2 instance
  • select the check on the newly spun ec2
  • with it checked click the action button drop down to image then slide over to create image.
  • name your image, list a discription, and create image
  • once the image has finished copy its ami number
  • place the copy of the ami number in both master and worker_id of the var.json file

var.json Default values

{
"WORKER_image_id": "ami-0fc20dd1da406780b",
"MASTER_image_id": "ami-0fc20dd1da406780b",
"user_count": "3"
}
  • user_count is the default number of worker nodes that the terraform configuration will use. This is overriden when using the tool.
  • once the image is AMI is saved, the EC2 can be destroyed. Run the following make command in terminal at project root: make destroy_image

Setup Master Instance

  • run make command in terminal: make master
  • wait for the setup, estimated time is usually 2-4min
  • once ssh connected follow the steps below to setup program:
sudo snap install go --classic
go get -u -d github.com/JosephZoeller/cityhash
go get -u -d github.com/JosephZoeller/DDALITE
go build -o ./sdnc ./go/src/github.com/JosephZoeller/DDALITE/cmd/sdnc
sudo ./sdnc
  • Wait for the Terminal to read "SDN Controller now listening on port 8080", then hash requests can be sent to the master's Public DNS on port 8080.
  • For example: ec2-3-15-220-41.us-east-2.compute.amazonaws.com:8080/?hash=85894109417755