Refactor2 See merge request crate3/garfbot!1
GarfBot is a discord bot that uses openai generative pre-trained AI models to produce text and images for your personal entertainment and companionship. JonBot is his owner and MoneyBot is his eccentric friend who plays the classic F2P video game Planetside 2.
To interact: (not case-sensitive)
"hey garfield"
responds with text.
"garfpic"
responds with image.
To get started, clone this repo and create a config.py file in GarfBot's root directory. Open your favorite text editor or IDE and add your various API tokens as such:
GARFBOT_TOKEN = "token"
JONBOT_TOKEN = "token"
MONEYBOT_TOKEN = "token"
OPENAI_TOKEN = "token"
GIF_TOKEN = "token"
If you want to configure a more secure setup, go ahead.
Next, I recommend building a docker image for each bot using the included DockerFile as a template. Run each container binding /usr/src/app to GarfBot's CWD.
Example:
crate@raspberrypi:~/garfbot $ docker build -t garfbot .
crate@raspberrypi:~/garfbot $ docker run -d --restart always -v $PWD:/usr/src/app --name garfbot garfbot
Or if you prefer to install dependencies (from requirements.txt) on a host and run as a systemd service:
[Unit]
Description=garfbot
After=multi-user.target
[Service]
Type=simple
Restart=always
User=pi
WorkingDirectory=/home/crate/garfbot
ExecStart=/usr/bin/python ./garfbot.py
[Install]
WantedBy=multi-user.target