Exploit is initially designed and built for college course work (PRJ 666), but is open source and can be used by anyone who wants to learn more about cybersecurity.
Exploit is a educational cybersecurity game that is primarily built with ThreeJS and ExpressJS using Handlebars.
This purpose of this game is to allow people to learn about basic cybersecurity in a fun and engaging way. This is an educational multiple choice questions game that allows people to have fun while they use their judgement to answer the questions. The game describes a fictional city called Cursor City. Users are expected to complete each cybersecurity module to save the city from cyber criminals.
The concept of the game is a 3D robot jumping over buildings after each question displayed has been answered correctly. The game is designed to be a learning tool for cybersecurity and is meant to be played by people who have little to no experience in cybersecurity.
- 3D robot jumping over buildings after each question is answered correctly
- Player gets 3 life span to answer all the questions correctly before the game ends
- If the player answers 3 questions incorrectly, the game ends and robot does a failing animation.
- If the player answers all the questions correctly, the game ends and robot does a winning animation.
- Player can choose to play the game again after the game ends.
- The environment is designed to be a city with buildings and a skybox.
- Each game module (
Ransomware
,Session Hijacking
,Bruteforce Attack
,Trojan Horse
) has a different environment. Colors are unique to each module. - Each game module has a different set of questions.
- Player can create an account and login to save their progress.
- All the scores of the players are saved in a database and can be viewed in the
leaderboard
.
- Clone the repository to your local machine and navigate to the directory.
git clone https://github.com/XpI0It/3xploit && cd 3xploit
- Install the dependencies.
npm install
The following dependencies are installed:
"dependencies": {
"express": "^4.17.1",
"express-handlebars": "^5.3.4",
"express-session": "^1.17.3",
"mongoose": "^6.6.5",
"nodemon": "^2.0.13",
"pg": "^8.8.0",
"pg-hstore": "^2.3.4",
"sequelize": "^6.24.0",
"sessions": "^0.0.2-7"
},
- Start the server on port 8080.
npm run dev
The game has a login
and signup
feature. In local development, you can create a user account by simply clicking the Play
button on the home page. Or you can click on the Register
button on the top right corner to create an account.
For testing purposes, you can use the following credentials to login.
username: coffee
password: coffee123
The game has a leaderboard
feature. In local development, you can view the leaderboard by clicking on the Leaderboard
button on the top right corner.
Note: The leaderboard is only available for users who have created an account and logged in.
The following image is a screenshot of the leaderboard.
The following image is a hierarchical structure of the project and shows a brief description of each directory.
The game has 4 modules. Each module has a different set of questions and a different environment. Hovering over the module will display a brief description of the module and display Play Now
button to start the game.
Clicking on the Play Now
button will display an information page about the module and at the very bottom of the page, there is a Play
button to start the game.