Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dbut2/slackgpt
AI Slack chat bot using models from OpenAI
https://github.com/dbut2/slackgpt
ai bot chatbot cloud-functions gcp go openai pubsub slack slack-bot
Last synced: about 1 month ago
JSON representation
AI Slack chat bot using models from OpenAI
- Host: GitHub
- URL: https://github.com/dbut2/slackgpt
- Owner: dbut2
- License: mit
- Created: 2023-02-20T05:26:47.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T12:34:45.000Z (3 months ago)
- Last Synced: 2024-10-29T12:37:35.354Z (3 months ago)
- Topics: ai, bot, chatbot, cloud-functions, gcp, go, openai, pubsub, slack, slack-bot
- Language: Go
- Homepage:
- Size: 314 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SlackGPT
Slack bot for generating chats or text completions using OpenAI's range of [models](https://platform.openai.com/docs/models).
SlackGPT is built on top of [Slack Bot Users](https://api.slack.com/bot-users) for bot interactions and messages, [OpenAI APIs](https://platform.openai.com/docs/api-reference/introduction) for AI text completion, and GCP for sewing everything together, notably [Cloud Functions](https://cloud.google.com/functions) and [Pub/Sub](https://cloud.google.com/pubsub/docs/overview).
SlackGPT can be direct messaged privately if you need a listening ear, or added to a channel for a team's worth of fun.
![](image.png)
## Usage
There's 2 ways of running SlackGPT. Firstly through GCP using Cloud Functions and PubSub, this is the preferred method as Cloud Functions can manage scaling for you and be generally cheaper, and PubSub also helps handle error correction and retry for generation. The other option is to run in socket mode which is also useful for testing purposes.
Either way, you'll need to ensure you have the following resources:
- OpenAI:
- [API Key](https://platform.openai.com/account/api-keys)- Slack:
- [Bot Token](https://api.slack.com/authentication/token-types)
- [App Token](https://api.slack.com/authentication/token-types) (if using socket mode)- GCP (if using pubsub mode):
- [Project ID](https://cloud.google.com/resource-manager/docs/creating-managing-projects)
- [PubSub Topic](https://cloud.google.com/pubsub/docs/create-topic)### PubSub mode
Create generating function from [`pubsub.go;PubSubGenerate`](pubsub.go#L10)
This function should be triggered from pubsub topic push and should have the following env vars set:
```
OPENAI_TOKEN=(OpenAI API Key)
SLACK_BOT_TOKEN=(Slack Bot token)
MODEL=(Optional. Model for text generation. Defaults to "gpt-3.5-turbo")
```Create slack event receiver function from [`event.go;SlackEvent`](event.go#L11)
This function should be triggered from HTTP, provide the trigger URL to Slack event subscriptions and should have the following env vars set:
```
SLACK_SINGING_SECRET=(Signing Secret from Slack app)
PROJECT_ID=(GCP Project ID)
PUBSUB_TOPIC=(GCP PubSub Topic)
```### Socket mode
Set the following env vars:
```
export OPENAI_TOKEN=(Slack API Key)
export SLACK_APP_TOKEN=(Slack App Token)
export SLACK_BOT_TOKEN=(Slack Bot Token)
export MODEL=(Optional. Model for text generation. Defaults to "gpt-3.5-turbo")
```Run socket mode application:
```
go run cmd/socket/main.go
```Enable socket mode in Slack app settings