Spaces:
Runtime error
Runtime error
Create app.py
Browse files
app.py
ADDED
@@ -0,0 +1,66 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# CREDIT: generated by GPT-4
|
2 |
+
import streamlit as st
|
3 |
+
from enigma_machine import EnigmaMachine # Assuming the EnigmaMachine class is in enigma_machine.py
|
4 |
+
|
5 |
+
# style - hide footer and menu
|
6 |
+
style = """
|
7 |
+
<style>
|
8 |
+
#MainMenu {visibility: hidden;}
|
9 |
+
footer {visibility: hidden;}
|
10 |
+
</style>
|
11 |
+
"""
|
12 |
+
st.markdown(style, unsafe_allow_html=True)
|
13 |
+
|
14 |
+
# Set up the web app's title and introductory text.
|
15 |
+
st.title("Enigma Machine Simulator")
|
16 |
+
st.write("""
|
17 |
+
This app simulates a very simplified version of the historical Enigma machine.
|
18 |
+
Set the initial rotor settings and input a message to see the encoded results.
|
19 |
+
""")
|
20 |
+
|
21 |
+
# Create columns for the rotor settings so they can be side by side.
|
22 |
+
col1, col2, col3 = st.columns(3) # Use the newer 'columns' layout
|
23 |
+
|
24 |
+
# Create a number input (a counter) for each rotor in each column.
|
25 |
+
# These will ensure users can only input numbers, and we limit them to valid rotor positions (0-25).
|
26 |
+
rotor1 = col1.number_input("Rotor 1 Setting", min_value=0, max_value=25, value=0)
|
27 |
+
rotor2 = col2.number_input("Rotor 2 Setting", min_value=0, max_value=25, value=0)
|
28 |
+
rotor3 = col3.number_input("Rotor 3 Setting", min_value=0, max_value=25, value=0)
|
29 |
+
|
30 |
+
# User input for the message to encode.
|
31 |
+
message = st.text_area("Message to encode:")
|
32 |
+
|
33 |
+
# The message is encoded as soon as the user types, based on the current settings.
|
34 |
+
if message: # Check if the message is not empty.
|
35 |
+
# Initialize the Enigma machine with the given settings.
|
36 |
+
enigma = EnigmaMachine([rotor1, rotor2, rotor3])
|
37 |
+
encoded_message = enigma.encode_message(message)
|
38 |
+
|
39 |
+
# Display the encoded message in a code box for easy copying.
|
40 |
+
st.caption("Encoded Message")
|
41 |
+
st.write(encoded_message) # This will display the message in a more readable format (without the code box
|
42 |
+
|
43 |
+
# Instructions to run remain the same. Users can execute 'streamlit run app.py' in the terminal.
|
44 |
+
|
45 |
+
|
46 |
+
# enigma description
|
47 |
+
with st.expander("Enigma Machine Description"):
|
48 |
+
"""
|
49 |
+
## How the Enigma Machine Works
|
50 |
+
|
51 |
+
The Enigma machine, developed in the early 20th century, was used primarily by the Germans during World War II for encrypting communications. This electro-mechanical apparatus allowed an operator to type in a message and scramble it, so it appeared as a completely different set of characters, according to the machine's current configuration.
|
52 |
+
|
53 |
+
### Basic Principles
|
54 |
+
|
55 |
+
1. **Rotors**: The machine had a series of rotors (three in our simulation, although the original had more options). Each rotor was a disc with the 26 letters of the alphabet arranged around it, and it could be set to a starting position. As each letter was typed, the rotors would move, altering the electrical circuit and hence the resulting letter.
|
56 |
+
|
57 |
+
2. **Scrambling**: When a key was pressed, the electrical signal would go through the rotors, and each rotor would change the signal's path. This meant that even if the same letter was typed twice in a row, it could be encoded differently each time, depending on the machine's configuration and the rotors' movement.
|
58 |
+
|
59 |
+
3. **Reflector**: After passing through the rotors, the signal reached a "reflector," sending it back through the rotors again, providing another layer of scrambling.
|
60 |
+
|
61 |
+
4. **Decoding**: The process was reversible. If the receiving party had an Enigma machine and knew the original settings, they could type the coded message and see the plain text.
|
62 |
+
|
63 |
+
In our simplified simulator, we capture the essence of the rotor mechanism. You can set initial positions for each rotor and type messages to see how they would be encoded. For educational purposes and simplicity, our model doesn't simulate all the historical machine's complexities, like the plugboard or different rotor wirings.
|
64 |
+
|
65 |
+
> Source _GPT-4_
|
66 |
+
"""
|