Skip to content

Latest commit

 

History

History
89 lines (79 loc) · 3.5 KB

README.md

File metadata and controls

89 lines (79 loc) · 3.5 KB

Slack Chat-GPT3 Bot, powered by OpenAI

This little project is to run your own OpenAI assistant right in your Slack.

image

Git Repo: https://github.com/maktouch/slack-chatgpt

Dockerhub: https://hub.docker.com/r/maktouch/slack-chatgpt

Requirements

  • OpenAI API Key
  • Slack App with the following App Manifest
  display_information:
    name: ChatGPT
    description: ChatGPT Bot
    background_color: "#10a37f"
  features:
    bot_user:
      display_name: ChatGPT
      always_online: true
  oauth_config:
    scopes:
      bot:
        - app_mentions:read
        - channels:history
        - channels:read
        - chat:write
        - groups:history
        - im:history
        - mpim:history
  settings:
    event_subscriptions:
      bot_events:
        - app_mention
        - message.channels
        - message.groups
        - message.im
        - message.mpim
    interactivity:
      is_enabled: true
    org_deploy_enabled: false
    socket_mode_enabled: true
    token_rotation_enabled: false
  • MySQL (I just use Planetscale)
    • A table called "prompts" with the schema below
CREATE TABLE `prompts` (
  `id` int NOT NULL AUTO_INCREMENT,
  `ts` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
  `dialog` text CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
  `from` varchar(20) DEFAULT NULL,
  `channel` varchar(20) DEFAULT NULL,
  `team` varchar(20) DEFAULT NULL,
  `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  KEY `prompts_ts_idx` (`ts`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

Installation

This is nicely packaged in a Docker container hosted on Dockerhub! docker pull maktouch/slack-chatgpt:latest

The available env configurations are

env description required default
SLACK_BOT_TOKEN The Slack Bot token (starts with xoxb) yes -
SLACK_SIGNING_TOKEN The Slack signing token yes -
SLACK_APP_TOKEN The Slack App token (starts with xapp) yes -
MYSQL_HOST MySQL Host yes -
MYSQL_DATABASE MySQL Database Name yes -
MYSQL_USERNAME MySQL Username yes -
MYSQL_PASSWORD MySQL Password yes -
MYSQL_PORT MySQL Port no 3306
PORT The port that Slack Bolt will use no 3120
OPENAI_API_KEY The OpenAI API Key yes -
OPENAI_MODEL Docs no text-davinci-003
OPENAI_TEMPERATURE Docs no 0.9
OPENAI_MAX_TOKEN Docs no 150
OPENAI_TOP_P Docs no 1
OPENAI_FREQUENCY_PENALTY Docs no 0
OPENAI_PRESENCE_PENALTY Docs no 0.6
OPENAI_AI_SETUP The initial text that will be prepended before being sent to ChatGPT no The following is a conversation with an AI assistant on Slack. The assistant is helpful, creative, clever, very friendly, and always wraps code with backticks.