data:image/s3,"s3://crabby-images/eae6e/eae6ec9722c7239baf426e11b376f0a76f0bde20" alt="Logo"
UofTHacks 12 Winner 🏆
Understand the qualms of password selection and phishing tactics through a hacker's lens -
deducing a victim's password through their personal data.
Try to remember some of your first passwords. Most likely, they were passwords that were built around something memorable in your life, like your school, family, pet names, hobbies, and more. Ah, how naive and unassuming you were. Unfortunately, your very own passwords that you thought you grew and nurtured so well might as well be heaps of gold, piles of treasures for any reasonably skilled hacker around the globe. At a first glance, you may not imagine that a password above 8 characters could be easily cracked. After all, you can't even figure out a reasonable combination in the wardrobe. However, millions of users are phished for their personal data every year, lying defenseless as hackers prey down upon their data and finances.
Now you might wonder, what do these chronically online hackers do with their day? How long do they struggle in your emails, texts, and calls just to glean a morsel of information? Why don't they touch grass? Well, we'll say that these are completely valid questions. Sometimes, you just have to see the other side - what it's truly like to phish for information and what tactics phishers employ in their daily activities. Only when you view the world in a different lens do you truly learn what's behind the Phish-Eye.
By playing the role of the sneaky phisher, you explore a victim's device and examine their personal data, finding key information that could lead you to cracking their RBC Bank password. Using generative AI and some very clever prompt engineering, we designed intricate, logical puzzles with key information that slowly leads you towards breaking bad. Keep your magnifying glasses peeled folks, dive deep into the world of phishing and develop a new perspective.
BK Kang |
Mike Gao |
Gabriel You |
Karanjot Gaidu |
- Interactive chat simulation with AI-generated responses
- Email and text message simulation
- Realistic RBC Online Banking login page
- Password attempt history
- Note taking feature for collecting clues
To set up the project locally and get a local copy up and running:
-
npm
npm install npm@latest -g
-
Clone the repository:
git clone https://github.com/bkctrl/phisheye-lens
-
Navigate to the project directory & install the dependencies:
cd phisheyelens && npm install
-
Install the dependencies for the backend API:
cd src/backend && npm install
You could test the backend both locally or by using a deployed API. The following is on testing locally.
-
Navigate to
src/backend/apis/server.js
and run the server. Assuming you are at the root directory:cd src/backend/apis/server.js && nodemon server.js
-
Open a new terminal and run the frontend. On the new terminal:
npm run dev
-
Navigate to
localhost:3000
on your browser and see the project demo!
Our API leverages Google's Gemini API! Check out how it is done:
Navigate to generate_data.js
:
cd src/backend/apis/generate_data.js
The process of setting up the game contents for each round can be broadly seperated into 2 groups: creating fictional details and then generating passwords. Careful thought was put in for both processes to make a challenging but finishable game that reflects the dynamicism of password cracking.
Creating Fictional Details
To generate details we designed fictional character profiles and catagorized individual characteristics using the JSON format such as the example below of personal_details catagory below. Each character profile was associated with a seed value to tie future events to the profile and allow for easier database integration.
These profiles were manually designed and checked for quality control and testing purposes.
"personal_details": {
"first_name": "Sophia",
"last_name": "Smith",
"middle_name": "Grace",
"date_of_birth": "1992-11-04",
"age": 32,
"nickname": "Sophie",
"pet_name": "Whiskers"
}
To generate fictional emails, several random details were then selected from each catagory and independently fed into the Gemini 1.5 flash API memoryless to reduce bias and increase independence of each email. The prompt was designed so the gemini API would role play the sender and plant the details as subtle clues for any potential reader. It was made sure through the prompt tuning that the emails collectively contained enough clues to solve the password.
The generation of fictional texts was done differently since with the text feature it brings in the introduction of player interaction with the Gemini model and a stored text log history. To initialize the text history chain of thought prompting was used to generate a cohesive background text history which the player can choose to build off of. The history for all texts are stored and used as context for future messages the player may text to phish for data. The data for the history is stored in a redis database which is regularly updated when players make a text and receive a response from the Gemini API. Similarly to the emails the AI model is designed to plant clues in conversation and roleplays the role of the character of the person being phished.
Generating Passwords
To generate passwords a regex-like system was developed using inspiration from common password patterns that have been found in password leaks in the past. The regex system combines the details with common string patterns used in passwords like 'password_' or '+key' and combines them with some of the details generated earlier to create the password.
// Loop through all details to assign them to detail1 or detail2 based on category match
for (let i = 0; i < all_details[seed].length; i++) {
const { category, detail } = all_details[seed][i]; // Destructure category and detail from the current detail object
// Check if the category matches either of the random_two categories
if (category === activity1) {
detail1 = detail; // Assign to detail1 if it matches activity1Category
}
if (category === activity2) {
detail2 = detail; // Assign to detail2 if it matches activity2Category
}
}
// Replace placeholders in the pattern with actual details
let finalPattern = randomPattern[0].replace(activity1, detail1).replace(activity2, detail2);
finalPattern = finalPattern.replace(/\s+/g, ''); // This removes all spaces
const newPattern = [finalPattern]; // Store the final password pattern filled with details
The player is given the generalized form of the regex that has been filled in with categories to assist them with cracking the password while the real password is stored with filled in values. The choice was taken to design a password independently of the AI model by black boxing the the password generation from the model. This means the model has no context to the password that is stored which prevents leaks of the password in the text feature and incentivizes fairness in all the details being given to the player while increasing the challenge of cracking the password.
Navigate to server.js
:
cd src/backend/apis/server.js
Our API serves the following endpoints:
This is where the emails and chat history genearted with Gemini in generate_data.js
can be fetched.
This is where the user's guess is posted and compared with the correct password. It also includes the correct password for easier debugging.
This is run when a new game is started, re-generating emails, chat histories, regexes, profiles, and passwords.
This is where the user's interactions with the chatbot is posted. The user's input is posted to our backend, which in turns returns a Gemini-generated answer.
The frontend is built with Next.js and Tailwind CSS. The main components include:
Landing Page:
- Simple landing page with Typewriter effect
- Uses
react-typewriter-effect
library - Explains game concept and instructions
Game Page:
- Phone interface using
react-device-mockup
library - Contains home screen, chat interface, email interface, and RBC interface
- Draggable notepad for taking notes about clues and details
- Draggable instructions card showing password regex pattern
When the correct password is guessed, the user sees a confetti animation using react-confetti
library and is redirected to the RBC dashboard.
- Start the game by clicking on the "Start Game" button.
- You will have access to three main interfaces:
- Text messages
- Emails
- RBC Online Banking login page
- Interact with the character by sending messages to the character. The character will respond to the user's messages.
- Collect personal information from the character's messages and emails to help you guess the password.
- Use the note-taking feature to record potential clues and personal information.
- Open the RBC Online Banking login page and enter the correct password to win the game.
- Store the previous guesses in a history and use it to guess the password.
- Utilize the regex feature to help you guess the password.
- You can end the game at any time by clicking on the "End Game" button.