Skip to content

Latest commit

 

History

History
107 lines (70 loc) · 4.76 KB

README.md

File metadata and controls

107 lines (70 loc) · 4.76 KB

CleanShot 2022-11-17 at 03 18 16


Overview 📖

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.

Features 📋 🎉

  • 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.

Local Setup Instructions ⚙️

  1. Clone the repository to your local machine and navigate to the directory.
git clone https://github.com/XpI0It/3xploit && cd 3xploit 
  1. 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"
  },
  1. Start the server on port 8080.
npm run dev

User Accounts 👤

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

Leaderboard 🏆

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.

CleanShot 2022-12-13 at 01 04 52@2x

Hierarchical Structure of the Project 📁

The following image is a hierarchical structure of the project and shows a brief description of each directory.

CleanShot 2022-12-13 at 00 55 25@2x

Game Modules 🎮

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.

CleanShot 2022-12-13 at 00 44 26@2x

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.

CleanShot 2022-12-13 at 00 48 45@2x