Discord Cyber Scenario, Quiz, And Cyber Awareness Training Bot.
You can skip to ๐ Quick Start to add CyberScenarioBot
to your server now.
See the Bot in Action!
- CyberScenarioBot
This bot may be useful in a cybersecurity training or awareness program, where users can be exposed to various cybersecurity scenarios and learn how to prevent or respond to them. By using a Discord bot, the scenarios can be easily shared with users in a server environment, and the bot can be customized to include additional commands or functionality as needed. Additionally, the bot can be run in a Docker container, making it easy to deploy and manage in various environments.
Assuming you are using a Unix-based system, open a terminal and navigate to the directory where the bot.py script is located. Then, run the following command:
export BOT_TOKEN="INSERT YOUR BOT TOKEN HERE"
export GUILD_ID="INSERT YOUR GUILD ID HERE (only needed for timed quizes and leaderboard)"
export LEADERBOARD_CHANNEL_ID="INSERT YOUR LEADERBOARD CHANNEL ID HERE (Only needed for leaderboard for prompts)"
export CHANNEL_ID="INSERT YOUR CHANNEL ID HERE (only needed for timed quizes)"
export APLUSROLE="INSERT YOUR A+ ROLE ID HERE (only needed for timed quizes)"
export NETPLUSROLE="INSERT YOUR Network+ ROLE ID HERE (only needed for timed quizes)"
export SECPLUSROLE="INSERT YOUR Security+ ROLE ID HERE (only needed for timed quizes)"
export QUIZROLE="INSERT YOUR QUIZ ROLE ID HERE (only needed for timed quizes)"
python bot.py
Note that if you are using a Windows-based system, you'll need to use a slightly different command to set the environment variable. Here's an example command that should work on Windows:
set BOT_TOKEN="INSERT YOUR BOT TOKEN HERE"
set GUILD_ID="INSERT YOUR GUILD ID HERE (only needed for timed quizes)"
set LEADERBOARD_CHANNEL_ID="INSERT YOUR LEADERBOARD CHANNEL ID HERE (Only needed for leaderboard for prompts)"
set LEADERBOARD_PERSIST_CHANNEL_ID="INSERT YOUR LEADERBOARD PERSIST CHANNEL ID HERE (Only needed for leaderboard for prompts)"
set CHANNEL_ID="INSERT YOUR CHANNEL ID HERE (only needed for timed quizes)"
set APLUSROLE="INSERT YOUR A+ ROLE ID HERE (only needed for timed quizes)"
set NETPLUSROLE="INSERT YOUR Network+ ROLE ID HERE (only needed for timed quizes)"
set SECPLUSROLE="INSERT YOUR Security+ ROLE ID HERE (only needed for timed quizes)"
set QUIZROLE="INSERT YOUR QUIZ ROLE ID HERE (only needed for timed quizes)"
python bot.py
When running the Docker container, you can pass in the BOT_TOKEN environment variable using the -e flag as follows:
docker run -e BOT_TOKEN="INSERT YOUR BOT TOKEN HERE" -it --rm simeononsecurity/discord-cyber-scenario-bot:latest
To run the bot in the background:
docker run -td --name scenario-bot -e BOT_TOKEN="INSERT YOUR BOT TOKEN HERE" simeononsecurity/discord-cyber-scenario-bot:latest
To run the bot in the background with all scheduled prompts and roles:
docker run -td --name scenario-bot \
-e BOT_TOKEN="INSERT YOUR BOT TOKEN HERE" \
-e GUILD_ID="INSERT YOUR GUILD ID HERE" \
-e LEADERBOARD_CHANNEL_ID="INSERT YOUR LEADERBOARD CHANNEL ID HERE" \
-e LEADERBOARD_PERSIST_CHANNEL_ID="INSERT YOUR LEADERBOARD PERSIST CHANNEL ID HERE" \
-e CHANNEL_ID="INSERT YOUR CHANNEL ID HERE" \
-e APLUSROLE="INSERT YOUR A+ ROLE ID HERE" \
-e NETPLUSROLE="INSERT YOUR NET+ ROLE ID HERE" \
-e SECPLUSROLE="INSERT YOUR SEC+ ROLE ID HERE" \
-e QUIZROLE="INSERT YOUR QUIZ ROLE ID HERE" \
simeononsecurity/discord-cyber-scenario-bot:latest
Command prefix: '!', '/'****
- Aplus: Replies with CompTIA's A+ related prompt.
- Bluescenario: Replies with a blue team scenario.
- CCNA: Replies with Cisco's CCNA multiple choice prompt.
- CEH: Replies with EC-Council's CEH multiple choice prompt.
- CISSP: Replies with ISC2's CISSP multiple choice prompt.
- Linuxplus: Replies with CompTIA's Linux+ multiple choice prompt.
- Netplus: Replies with CompTIA's Network+ related prompt.
- Quiz: Replies with a random Cyber Security Awareness Question.
- Redscenario: Replies with a redteam scenario.
- Secplus: Replies with CompTIA's Security+ related prompt.
Multiple-choice questions are dynamically weighted similar to the real exams based on if they are answered correctly or incorrectly
- Track your progress over time and see how you compare against others in your server
- See scores for each quiz category as well as overall
- Dns: Takes in a
domain name
and returns A, AAAA, NS, TXT, etc. records. - Hash: Takes in
1 of 4 supported algos
and astring
and outputs a corresponding hash. - Ping: Takes in an
IP address
and returns with a success message and average latency or a failure message. - Phonelookup: Takes in a
phone number
and outputs the carrier and location. - Shodanip: Takes in an
IP address
and outputs useful information from https://internetdb.shodan.io/. - Subnet: Takes in an
IP address
and aSubnet Mask
and outputs the Range, Usable IPs, Gateway Address, Broadcast Address, and Number of Supported Hosts. - Whois: Takes in a
domain name
and outputs domain whois information.
- Commands: Replies with this message.
- Socials: Replies with the various bot social media accounts and websites.
- See ๐ Quick Start
These features have planned date of implementation, but we're tracking them and we'd love contributions for them.
- Advanced leaderboard features, including weekly and monthly rankings.
- Customizable prompts and quizzes to cater to specific cybersecurity training needs.
- Advanced reporting and analytics for tracking user progress and performance.
The CyberScenarioBot offers various commands and features to enhance your cybersecurity training and awareness program. Here are some common use cases:
-
Quizzes and Scenarios: Use the
/quiz
command to get a random cybersecurity awareness question. Use commands like/aplus
,/netplus
,/secplus
to access specific prompts related to CompTIA certifications. Use commands like/bluescenario
and/redscenario
to get blue team and red team scenarios, respectively. -
Leaderboard: Keep track of user progress and compare scores with others in your server by answering the quiz and certification questions.
-
Tool Commands: Utilize various tool commands to perform tasks related to DNS, hashing, ping, phone number lookup, Shodan IP search, subnet calculations, and domain WHOIS lookup. Use commands like
/dns
,/hash
,/ping
,/phonelookup
,/shodanip
,/subnet
, and/whois
followed by the appropriate arguments. -
Informational Commands: Use the
/commands
command to get a list of available commands. Use the/socials
command to get information about the bot's social media accounts and websites.
Feel free to explore and experiment with the available commands to enhance your cybersecurity training and engage your server members.
If users encounter any issues or have suggestions for improvements, they can open a GitHub issue to report them. Encourage users to provide detailed information about the problem and steps to reproduce it.
To open an issue, follow these steps:
- Go to the Issues tab on the project's GitHub repository: Issues
- Click on the "New Issue" button.
- Provide a descriptive title and a clear description of the issue.
- Include any relevant logs, screenshots, or code snippets to help with troubleshooting.
- Submit the issue and await further communication from the project maintainers.
We welcome all contributions. This project was meant to be a development and learning effort by the CyberSentinels club and we'd love to help you contribute and answer any questions you may have.
This repo includes automated testing, you can see examples on how to implement that here
For testing changes and implementing features, you'll need a few things.
You can discuss development efforts in the community discord server here.
ย ย