Repository for Cracking the Enigma project, developed during a Java course in The Academic College of Tel Aviv, Yaffo. July 2022.
This project consisted of the development of an Enigma machine, capable of encrypting and decrypting messages, and utilizing code cracking techniques.
There are 3 Versions to this project.
The latest version includes the enigma machine base in an HTTP-based client-server architecture, with a fun code breaking game, demonstrating web app and multithreading capabilities.
The basic Enigma machine, wrapped in a smart engine.
User interface through console.
Machine input through XML files (Examples in relevant Source Code).
Capabilities:
- Load machine from XML file.
- Show current loaded machine state.
- Set the machine configuration manually.
- Set the machine configuration randomly.
- Process input (encrypt text).
- Reset the machine configuration.
- Show the machine history and statistics.
- Save the machine to Magic file (custom serialization of the machine, with history and current configuration).
- Load the machine from Magic file.
*Machine configuration is shown as following:
- Chosen rotor ids in order, separated by commas (Example: <45,27,94>).
- Rotor positions (with distance from notch in parenthesis) in order, characters separated by commas (Example: <A(2),O(5),!(20)>).
- Reflector id in Roman letters (Example: ).
- Plugs separated by commas, each plug is separated by a pipe(|) (Example: <A|Z,D|E>).
The basic Enigma machine, wrapped in a smart engine.
This time the app includes the ability to crack encrypted text, and decrypt it using Brute Force.
The decryption process uses multi-threading to make the job a lot quicker.
User interface through Java FX application.
Machine input through XML files (Examples in relevant Source Code).
*Encrypted text must be a part of the dictionary of allowed words (defined in the XML file).
Capabilities:
All previous capabilities plus:
- Visual keyboard.
- Automatic text decryption using Brute Force (with real time process view + statistics).
*The JavaFX application JAR file requires Java 1.8 to run.
This version takes the brute force decryption one step further and introduces a mini game.
The Enigma machine and the engine are now accessible through a web application.
There are now 3 applications:
- UBoat - The German submarine in charge of setting the machine configuration, and encrypting the text.
Essentially, the UBoat starts a contest. - Ally - The decryption team participating in the UBoat's contest, attempting to be the first to decrypt the text. There are multiple allies competing in the contest.
- Agent - A member of the Ally's team. In charge of doing the actual brute force work required to decrypt the text.
The web application (uses Tomcat) allows synchronization of the contests between those entities.
The server side logic included dealing with vast multithreading aspects (such as: thread pools manipulation, internal blocking queue management, threads synchronization, ETC).
The front end included 3 types of clients, developed as 3 independent desktop applications (Java FX).
Data delivery between the server and clients was based on various pull techniques.
The project included intergration and working with 3rd parties:
- GSON for json handling
- OKHttp for the client app.
*The JavaFX applications JAR files require Java 1.8 to run.
**The web application WAR file requires Tomcat to run.