Arbitrary code execution Discord bot
Find a file
2020-06-17 04:37:06 -04:00
src update dependencies 2020-06-17 04:37:06 -04:00
.eslintrc.json update dependencies 2020-06-17 04:37:06 -04:00
.gitattributes Initial commit 2019-03-12 05:09:46 -04:00
.gitignore Initial commit 2019-03-12 05:09:46 -04:00
CHANGELOG.md Port Comp_iler to Myriad (#8) 2019-07-11 02:27:17 -04:00
config.example.json Port Comp_iler to Myriad (#8) 2019-07-11 02:27:17 -04:00
CONTRIBUTING.md Update CONTRIBUTING.md 2020-01-03 05:25:58 -05:00
LICENSE Initial commit 2019-03-12 05:09:46 -04:00
package-lock.json update dependencies 2020-06-17 04:37:06 -04:00
package.json update dependencies 2020-06-17 04:37:06 -04:00
README.md Update readme 2019-09-05 10:32:26 -04:00

Comp_iler

Sandboxed code execution discord bot.

Invite the bot!
Not all languages are enabled on the public bot.

Usage

>```cpp
#include <iostream>

int main()
{
    std::cout << "Hello World!" << std::endl;
}
```
>`py print('hello world')`

Supported Languages and Options

One of the following language codes is set in lang.
You can see all the possible codes using the languages command in the bot.

  • apl APL
  • bash Bash
  • bf Brainfuck
  • c C
  • clj Clojure
  • cpp C++
  • cs C#
  • elixir Elixir
  • fs F#
  • go Go
  • hs Haskell
  • idr Idris
  • java Java
  • js JavaScript
  • julia Julia
  • lisp Racket
  • lua Lua
  • ocaml OCaml
  • pas Pascal
  • php PHP
  • pl Perl5
  • prolog Prolog
  • py Python
  • rb Ruby
  • rs Rust

How it Works

For every language there is a docker image which spins up a docker container.
The container is used for all evaluations of code, restarting if something goes wrong.
The container is locked down, so there is no networking, limited memory and CPU usage, and a time limit.

Setup

  1. Install Docker 18+
  2. Install Node 10+
  3. Install Myriad
    • This will require GHC and Cabal.
    • You will also have to configure Myriad, see its repository.
  4. Fill out config.json
    • owner The owner(s) of the bot. Use an array for multiple owners.
    • token The bot token.
    • prefix The prefix for commands.
    • codePrefix The prefix for code evaluation.
    • myriad The port that Myriad is running on.
  5. Run npm i

Running

  1. Run myriad --config /path/to/config.dhall --languages /path/to/languages/
  2. Run node .