Skip to content

pathway-labs/drive-alert

Repository files navigation

Build a real-time alerting app with Pathway

This repo demontrates how to build real-time alerts in your LLM app. The app reacts to document changes in Google Docs and sends notifications to Slack when some relevant information is modified. Read more in this article: Use LLMs for notifications

How to run the project

Follow the steps to install and get started using the sample app.

Step 1: Open the project

Choose one of these environments to open the project:

  1. GitHub Codespaces.

  2. VS Code Dev Containers.

  3. Local environment.

Open in GitHub Codespaces

Click here to open in GitHub Codespaces

Open in GitHub Codespaces

Open in Dev Container

Click here to open in Dev Container

Open in Dev Container

Open in Local environment

Prerequisites
  1. Make sure that Python 3.10 or above installed on your machine.
  2. Download and Install Pip to manage project packages.

Step 2: Create a new project in the Google API console

Before running the app, you will need to give the app access to the Google Drive folder, we follow the steps below.

In order to access files on your Google Drive from the Pathway app, you will need a Google Cloud project and a service user.

Rename this JSON file to secrets.json and put it under examples/pipelines/drive_alert next to app.py so that it is easily reachable from the app.

You can now share desired Google Drive resources with the created user. Note the email ending with gserviceaccount.com we will share the folder with this email.

Once you've done it, you will need an ID of some file or directory. You can obtain it manually by right-clicking on the file -> share -> copy link. It will be part of the URL.

https://drive.google.com/file/d/[FILE_ID]/view?usp=drive_link

For folders, First, right-click on the folder and click share, link will be of the format: https://drive.google.com/drive/folders/[folder_id]?usp=drive_link Copy the folder_id from the URL. Second, click on share and share the folder with the email ending with gserviceaccount.com

Step 3: Setup Slack notifications

For this demo, Slack notifications are optional and notifications will be printed if no Slack API keys are provided. See: Slack Apps and Getting a token. Your Slack application will need at least chat:write.public scope enabled.

Step 4: Setup environment variables

Set your env variables in the .env file placed in the root of the repo.

PATHWAY_REST_CONNECTOR_HOST=localhost
OPENAI_API_KEY=sk-...
SLACK_ALERT_CHANNEL_ID=  # If unset, alerts will be printed to the terminal
SLACK_ALERT_TOKEN=
FILE_OR_DIRECTORY_ID=  # file or folder ID that you want to track that we have retrieved earlier
GOOGLE_CREDS=examples/pipelines/drive_alert/secrets.json  # Default location of Google Drive authorization secrets

Step 5: Run the project

Install the app dependencies

Install the required packages:

pip install --upgrade -r requirements_dev.txt

Run the Pathway API

You start the application by navigating to backend foler and running api.py:

cd backend
python api.py

Run Streamlit UI

You can run the UI separately by running Streamlit app streamlit run ui.py command. It connects to the Pathway's backend API automatically and you will see the UI frontend is running on your browser.

(Optional) Connect to a remote backend API

The app has default connection setup to localhost:8080. If you use the remote backend API address, you set a host address in Streamlit UI.

About

Use LLMs for notifications: crafting a RAG app with real-time alerting

Resources

License

Stars

Watchers

Forks

Languages