Go to file
2024-12-28 05:08:50 +00:00
garfpy Refactor 2024-10-05 16:50:19 +00:00
.gitignore Refactor 2024-10-05 16:50:19 +00:00
Dockerfile Refactor 2024-10-05 16:50:19 +00:00
garfbot.sh update garfbot.sh 2024-10-21 01:51:43 -05:00
garfbot.tf add garfbot.tf 2023-11-19 20:30:49 -06:00
garfmain.py Refactor 2024-10-05 16:50:19 +00:00
jonbot.py fix jonbot and moneybot 2024-10-21 01:39:42 -05:00
LICENSE.txt add license 2023-11-19 16:57:16 -06:00
moneybot.py fix jonbot and moneybot 2024-10-21 01:39:42 -05:00
README.md Update README.md 2024-12-28 05:08:50 +00:00
requirements.txt requirements and model update 2024-08-31 16:02:20 -05:00

Who is GarfBot?

garfield

GarfBot is a discord bot that uses OpenAI's generative pre-trained models to produce text and images for your personal entertainment and companionship. There are a few ways you can interact with him on discord, either in a public server or by direct message:

hey garfield {prompt} Responds with text.

garfpic {prompt} Responds with an image.

garfping {target} Responds with iputils-ping result from target.

garfpic {target} Responds with dns lookup result from target.

garfhack {target} Responds with nmap scan result from target.

garfshop {item} {zip} Responds with 10 grocery {item}s from the nearest Kroger location, listed from least to most expensive.

Installation

To get started, clone this repo and create a config file.

$ git clone https://git.crate.zip/crate/garfbot.git && cd garfbot/ && nano config.py

Add your various API tokens:

GARFBOT_TOKEN = "Discord API token"
OPENAI_TOKEN = "OpenAI API token"
GIF_TOKEN = "tenor.com API token"

I recommend building a docker image using the included DockerFile as a template. Run the container binding /usr/src/app to GarfBot's CWD:

$ docker build -t garfbot .
$ docker run -d --restart always -v $PWD:/usr/src/app --name garfbot garfbot

In case you'd rather not do it manually, a garfbot.tf file has been included to launch GarfBot and his friends' containers.

If you prefer to install dependencies on you own host and run as a systemd service:

$ sudo nano /etc/systemd/system/garfbot.service

Replace {user} with your username:

[Unit]
Description=garfbot
After=multi-user.target

[Service]
Type=simple
Restart=always
User={user}
WorkingDirectory=/home/{user}/garfbot
ExecStart=/usr/bin/python garfbot.py

[Install]
WantedBy=multi-user.target

And finally:

$ sudo systemctl daemon-reload
$ sudo systemctl enable garfbot
$ sudo systemctl start garfbot