-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: add docs and assets to main readme.
- Loading branch information
1 parent
ac944ba
commit 1d18187
Showing
3 changed files
with
53 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# About | ||
The AI-Powered Slack Bot integrates [Hugging Face's](https://huggingface.co/) models into Slack, enabling AI-driven conversations within your workspace. Built with Python, it uses the Slack SDK and OpenAI's API to facilitate natural language interactions. | ||
|
||
## Stack | ||
|
||
data:image/s3,"s3://crabby-images/cd419/cd419aae644258c93a6f3cefc927c7975bbd0b5b" alt="python" | ||
data:image/s3,"s3://crabby-images/a4f86/a4f86fc734cd27d882f621091ad226ece7df1aaa" alt="flask" | ||
data:image/s3,"s3://crabby-images/9d36f/9d36fa761bd703c9ee694ef8cfa497e29b0a44ea" alt="huggingface" | ||
data:image/s3,"s3://crabby-images/dcb3d/dcb3da314585b0bad8e48ee032d2e79c0ac3fc33" alt="slack" | ||
data:image/s3,"s3://crabby-images/89eff/89eff8699fd5602b0e1442cf7191905c41534439" alt="redis" | ||
data:image/s3,"s3://crabby-images/81d74/81d74853a54d4266bbb15264ed2be11e66406946" alt="ngrok" | ||
data:image/s3,"s3://crabby-images/6827b/6827b21a68ac124d9f0565c02f7b21241971a0d4" alt="docker" | ||
data:image/s3,"s3://crabby-images/2397f/2397f2f5f0ed6ce8278725a89380571612802ccb" alt="git" | ||
data:image/s3,"s3://crabby-images/88823/88823ce0fa7ba4353317aa4e5949b21ed298c57e" alt="guthub" | ||
|
||
## How to run | ||
### Create an app | ||
- at first you need to create and app with the slack [app manager](https://api.slack.com/slack-apps) | ||
- with your app created, in "Yours apps" session you will be able to get all theses env vars: | ||
|
||
data:image/s3,"s3://crabby-images/9df12/9df12ad889925b10d1bf586fb8f2939661b7644f" alt="slack_env_vars" | ||
|
||
data:image/s3,"s3://crabby-images/a520a/a520a41535ae0eba35e65efb227e05f73d9246d0" alt="slack_app_credentials" | ||
|
||
- to be able to install your app in any workspace you need to set an redirect url, in case of testing i just used `https://localhost:5000`, with this feature we can create an 'add to slack' button to distribute our app, for more details read [this](https://api.slack.com/authentication/oauth-v2) | ||
|
||
IMPORTANT: | ||
- Slack only accepts https protocol so you need to create ssl certificates and run in the flask [application](./backend/app.py) | ||
- To handle event subscriptions you need to pass an url in order to enable slacks to making post requests for our app, so ive used [ngrok](https://ngrok.com/docs/) too create a temporary test domain, you only need to worry about running the flask app in https, generate a domain with ngrok, enable events, subscribe bot to the events that you need and voilá...app is not configured yet lol. | ||
|
||
|
||
### AI | ||
- Create on account in [Hugging Face](https://huggingface.co/) and generate an HF token to put in the env var. | ||
- its a simple prompt that generate what do you want, u can change the default prompt in [llm_service.py](./backend/services/llm_service.py) | ||
|
||
### Installing dependencies | ||
```bash | ||
python -m venv .venv | ||
source .venv/bin/activate | ||
pip install poetry | ||
poetry install --no-root | ||
``` | ||
|
||
### Running | ||
- docker: | ||
```bash | ||
docker docker compose -f .\docker-compose.yml up -d --build | ||
``` | ||
|
||
- locally: remember setting up the FLASK_APP env var and [creating ssl certificates](https://www.youtube.com/watch?v=VqnSenJAheU) to run the app in https | ||
```python | ||
python backend/app.py | ||
``` |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.