Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/humanloop/coworker
AI Coworker that lives in slack
https://github.com/humanloop/coworker
bot bot-framework chatbot gpt-4 openai slack
Last synced: 2 months ago
JSON representation
AI Coworker that lives in slack
- Host: GitHub
- URL: https://github.com/humanloop/coworker
- Owner: humanloop
- Created: 2023-09-05T09:05:20.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-06-07T22:09:54.000Z (7 months ago)
- Last Synced: 2024-08-14T07:07:40.532Z (5 months ago)
- Topics: bot, bot-framework, chatbot, gpt-4, openai, slack
- Language: Python
- Homepage:
- Size: 1.37 MB
- Stars: 33
- Watchers: 3
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- jimsghstars - humanloop/coworker - AI Coworker that lives in slack (Python)
README
# Coworker
![Logo](./logo.png)
Your AI Coworker that lives in Slack.
Coworker is an open source framework for practical, helpful AI assistants. It lives in Slack, will have access to your docs (as you allow) and can take actions in your various tools.
## Principles
1. **Context Aware** - Unlike other AI chatbots, it should have knowledge of your context. The conversation your having, the background goals at your company etc.
2. **Extensible** - It should be extremely easy for a developer to add a new capability to the coworker that's relevant for their company.
3. **Human in the loop** - We want to give Coworker really powerful capabilities. To do that in a way that maintains trust, it should be transparent to a user what the AI is doing and always get approval for its actions.## Setup
To get this working, you need to setup a new Slack App, get API keys for any tools you want to use e.g. Linear, Notion etc, and get Humanloop/OpenAI keys for the AI.
Slack App Setup
1. Create a New App:
1. Go to https://api.slack.com/apps and click on “Create New App”.
2. Give it a name and select the workspace you want to install it to.
3. Click “Create App”.
2. Permissions:
1. In the sidebar, navigate to “OAuth & Permissions”.
2. Under “Scopes”, add the following bot token scopes: `app_mentions:read`, `channels:history`, `chat:write`, `im:history`
3. Install the app to your workspace by clicking “Install App”.
4. Find the “Bot User OAuth Token”. This is your `SLACK_BOT_TOKEN` which starts with `xoxb-`.
3. Enable Socket Mode: 1. In the sidebar, navigate to “Socket Mode”. 2. Turn on “Enable Socket Mode”. 3. Generate a new token under “App-Level Tokens”. This is your `SLACK_APP_TOKEN` which starts with `xapp-`.Set up a Humanloop / OpenAI account for the AI
1. Go to https://humanloop.com/signup, and start a free trial
2. Get your `HUMANLOOP_API_TOKEN` from `https://app.humanloop.com/account/api-keys`
3. Get your `OPENAI_API_TOKEN` from https://platform.openai.com/account/api-keys##### Adding new tools for the AI
To add a new action, create a python function in `/tools` with type annotations and a good dosctring (this is important as it's what the AI uses to know when to call it). Then import it and add it to `ENABLED_TOOLS` variable in `main.py`.
By default the app will be in all channels. You can change this by editing the `ENABLED_CHANNELS` variable in `main.py`
## Running locally
### Setup
1. Clone this repo
2. Copy `.env.example` to `.env` and fill in the values
3. `poetry install`### Running
1. `poetry run python main.py`
## Deployment
You can run this locally indefintely, but if you want to deploy, we recommend using Railway.app.
Just fork this repo, and create a new deployment in Railway linked to that repo.
You will need to set up your Environment variables only.
## Privacy
You set this up yourself, with your own Humanloop account and your own OpenAI (or other LLM provider) keys. The data is private to you
and as this will be using the OpenAI API, this is actually a more privacy preserving approach than using ChatGPT directly as
you data will not be used in future training runs of OpenAI's models.## Road Map
- [x] GPT-4 bot that can read all messages in slack and responds when appropriate
- [x] Ability to recognise conversation about a bug and offer to write a Linear ticket then do it
- [x] Ability to recognise conversation about user feedback and save it to a central place
- [x] Make the AI responses be in threads so as to avoid cluttering the main feed
- [ ] Ask for permission to do things
- [ ] Add more knowledge sources like Notion, Drive or Email (could use something like SID to handle access permissions)
- [ ] Daily/Weekly summaries of the most important conversations had for engineering, product and sales
- [ ] Integrations with meeting note-takes like Fathom or Otter so that the AI can answer questions
- [ ] Integration with a vector database or similar that the model can read and write from to maintain long term memory