GithubHelp home page GithubHelp logo

k4rt0fl3r / ovisbot Goto Github PK

View Code? Open in Web Editor NEW

This project forked from cybermouflons/ovisbot

0.0 0.0 0.0 644 KB

Discord bot focused on managing and organising CTFs / Security stuff

License: GNU General Public License v3.0

Python 99.57% Dockerfile 0.08% Makefile 0.11% Shell 0.25%

ovisbot's Introduction

drawing

OvisBot

Open source Discord bot for CTF teams


Code Style: Black

OverviewInstallationDocumentationContributionLicense

Overview

OvisBot is a modular, feature-extensive Discord bot for managing CTF teams through discord. It facilitates collaboration and organisation by providing well defined commands to create/delete/update discord category/channels in order to structure CTF problems and provide more efficient team commmunication. In addition the bot provides basic utility functions to assist the solving process of CTF challenges (encoding schemes, etc.. ). Finally, promotes competitiveness amongst team members by providing a aut-synchronised leaderboard to common cybersecurity training platforms such as CryptoHack and Hack The Box,

Note that the majority of the features are provided by isolated plugins and thus they can be enabled/disabled on demand.

This is a self-hosted bot, therefore it requires to be hosted on a private server in order to be used. Further instructions to do so are provided below. It also required a running instance of MongoDB on the server but still, the docker-based installation instructions take care of that.

Installation

There are couple ways to install the bot but generally the installing using docker-compose is the most convenient way to do it. Nevertheless, don't hesitate to use any other methods that suits you.

Installing using pip

To install using pip run the following command

pip install ovisbot

The above will install ovisbot in your python environment and will introduce the ovisbot cli. The cli provides commands to launch and interact with ovisbot.

At runtime, the bot requires a running MongoDB server. An easy way to run a local mongodb server is using docker. You skip this step if you already have one running

docker run -d -p 27017-27019:27017-27019 --name mongodb mongo

Since OvisBot requires some predifined configuration before launch, it is necessary the you set your environment variables accordingly. Alternatively you can create a .env file that defined the required variables. Refer to .env.example for an example.

OvisBot cli provides the setupenv command which assists the creation of a .env file. Therefore to contrinue run and fill in the variables.

ovisbot setupenv

At the end of the process a new .env file will be create in your current directory.

Finally to launch the bot, run:

ovisbot run

Installing using docker

Installation using docker takes care of running mongo db automatically without requiring any extra steps. To achieve this, docker-compose is utilised therefore make sure that you have docker and docker-compose installed on your system.

Firstly clone this repository:

git clone https://github.com/cybermouflons/ovisbot ovisbot && cd ovisbot

For the next step make sure that you have your environment variables configured properly and run:

docker-compose -f docker-compose.yml -f docker-compose.prod.yml up

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Contribution

Have a feature request? Make a GitHub issue and feel free to contribute. To get started with contributing refer to CONTRIBUTE.md.

Current Contributors:

License

Released under the GNU GPL v3 license.

ovisbot's People

Contributors

apogiatzis avatar sikkis avatar xmpf avatar kgeorgiou avatar dependabot[bot] avatar npitsillos avatar cents02 avatar k4rt0fl3r avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.