Skip to content

Commit

Permalink
Feedback management microservice component (#581)
Browse files Browse the repository at this point in the history
* comps: Implement feedback_management component

Implement feedback_management component with following endpoint:
- /v1/feedback/create: Create and save user feedback data from mongo
  database.
- /v1/feedback/get: Retrieve user feedback data from mongo database.
- /v1/feedback/delete: Delete user feedback data from mongo database
  entry.

Signed-off-by: Yeoh, Hoong Tee <[email protected]>

* feedback_management: Include README

Include steps to build feedback_management microservice.
Include example to invoke API endpoint for the microservice.

Signed-off-by: Yeoh, Hoong Tee <[email protected]>

* Include test for feedback_management microservice

Signed-off-by: Yeoh, Hoong Tee <[email protected]>

* feedback_management: Update schema

Update endpoint schema for data to be collected and stored in database.
Updated README and test script for the same.

Signed-off-by: Yeoh, Hoong Tee <[email protected]>

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Fix typo in test_feedback_management_mongo

Signed-off-by: Yeoh, Hoong Tee <[email protected]>

---------

Signed-off-by: Yeoh, Hoong Tee <[email protected]>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
  • Loading branch information
hteeyeoh and pre-commit-ci[bot] authored Sep 4, 2024
1 parent 0bb69ac commit 72123b2
Show file tree
Hide file tree
Showing 9 changed files with 680 additions and 0 deletions.
157 changes: 157 additions & 0 deletions comps/feedback_management/mongo/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
# Feedback Management Microservice

The Feedback Management microservice facilitates the storage and retrieval of users'feedback data by establishing a connection with the database.

## Setup Environment Variables

```bash
export http_proxy=${your_http_proxy}
export https_proxy=${your_http_proxy}
export MONGO_HOST=${MONGO_HOST}
export MONGO_HOST=27017
export DB_NAME=${DB_NAME}
export COLLECTION_NAME=${COLLECTION_NAME}
```

## Start Feedback Management microservice for MongoDB with Python script

Start document preparation microservice for Milvus with below command.

```bash
python feedback.py
```

## 🚀Start Microservice with Docker

### Build Docker Image

```bash
cd ~/GenAIComps
docker build -t opea/feedbackmanagement-mongo-server:latest --build-arg https_proxy=$https_proxy --build-arg http_proxy=$http_proxy -f comps/feedback_management/mongo/docker/Dockerfile .
```

### Run Docker with CLI

1. Run mongoDB image

```bash
docker run -d -p 27017:27017 --name=mongo mongo:latest
```

2. Run Feedback Management service

```bash
docker run -d --name="feedbackmanagement-mongo-server" -p 6016:6016 -e http_proxy=$http_proxy -e https_proxy=$https_proxy -e no_proxy=$no_proxy -e MONGO_HOST=${MONGO_HOST} -e MONGO_PORT=${MONGO_PORT} -e DB_NAME=${DB_NAME} -e COLLECTION_NAME=${COLLECTION_NAME} opea/feedbackmanagement-mongo-server:latest
```

### Invoke Microservice

Once feedback management service is up and running, user can access the database by using API endpoint below. Each API serves different purpose and return appropriate response.

- Save feedback data into database.

```bash
curl -X 'POST' \
http://{host_ip}:6016/v1/feedback/create \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"chat_id": "66445d4f71c7eff23d44f78d",
"chat_data": {
"user": "test",
"messages": [
{
"role": "system",
"content": "You are helpful assistant"
},
{
"role": "user",
"content": "hi",
"time": "1724915247"
},
{
"role": "assistant",
"content": "Hi, may I help you?",
"time": "1724915249"
}
]
},
"feedback_data": {
"comment": "Moderate",
"rating": 3,
"is_thumbs_up": true
}}'


# Take note that chat_id here would be the id get from chathistory_mongo service
# If you do not wish to maintain chat history via chathistory_mongo service, you may generate some random uuid for it or just leave it empty.
```

- Update the feedback data of specified feedback_id

```bash
curl -X 'POST' \
http://{host_ip}:6016/v1/feedback/create \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"chat_id": "66445d4f71c7eff23d44f78d",
"chat_data": {
"user": "test",
"messages": [
{
"role": "system",
"content": "You are helpful assistant"
},
{
"role": "user",
"content": "hi",
"time": "1724915247"
},
{
"role": "assistant",
"content": "Hi, may I help you?",
"time": "1724915249"
}
]
},
"feedback_data": {
"comment": "Fair and Moderate answer",
"rating": 2,
"is_thumbs_up": true
},
"feedback_id": "{feedback_id of the data that wanted to update}"}'

# Just include any feedback_data field value that you wanted to update.
```

- Retrieve feedback data from database based on user or feedback_id

```bash
curl -X 'POST' \
http://{host_ip}:6016/v1/feedback/get \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"user": "test"}'
```

```bash
curl -X 'POST' \
http://{host_ip}:6016/v1/feedback/get \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"user": "test", "feedback_id":"{feedback_id returned from save feedback route above}"}'
```

- Delete feedback data from database based on feedback_id provided

```bash
curl -X 'POST' \
http://{host_ip}:6016/v1/feedback/delete \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"user": "test", "feedback_id":"{feedback_id to be deleted}"}'
```
10 changes: 10 additions & 0 deletions comps/feedback_management/mongo/config.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
# Copyright (C) 2024 Intel Corporation
# SPDX-License-Identifier: Apache-2.0

import os

# MONGO configuration
MONGO_HOST = os.getenv("MONGO_HOST", "localhost")
MONGO_PORT = os.getenv("MONGO_PORT", 27017)
DB_NAME = os.getenv("DB_NAME", "OPEA")
COLLECTION_NAME = os.getenv("COLLECTION_NAME", "Feedback")
31 changes: 31 additions & 0 deletions comps/feedback_management/mongo/docker/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Copyright (C) 2024 Intel Corporation
# SPDX-License-Identifier: Apache-2.0

FROM python:3.11-slim

ENV LANG=C.UTF-8

RUN apt-get update -y && apt-get install -y --no-install-recommends --fix-missing \
build-essential \
libgl1-mesa-glx \
libjemalloc-dev \
vim

RUN useradd -m -s /bin/bash user && \
mkdir -p /home/user && \
chown -R user /home/user/

USER user

COPY comps /home/user/comps
COPY requirements.txt /home/user/

RUN pip install --no-cache-dir --upgrade pip && \
pip install --no-cache-dir -r /home/user/comps/feedback_management/mongo/requirements.txt && \
pip install --no-cache-dir -r /home/user/requirements.txt

ENV PYTHONPATH=$PYTHONPATH:/home/user

WORKDIR /home/user/comps/feedback_management/mongo

ENTRYPOINT ["python", "feedback.py"]
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# Copyright (C) 2024 Intel Corporation
# SPDX-License-Identifier: Apache-2.0

version: "3"
services:
mongo:
image: mongo:7.0.11
container_name: mongodb
ports:
- 27017:27017
environment:
http_proxy: ${http_proxy}
https_proxy: ${https_proxy}
no_proxy: ${no_proxy}
command: mongod --quiet --logpath /dev/null

feedbackmanagement-mongo:
image: opea/feedbackmanagement-mongo:latest
container_name: feedbackmanagement-mongo-server
ports:
- "6016:6016"
ipc: host
environment:
http_proxy: ${http_proxy}
https_proxy: ${https_proxy}
no_proxy: ${no_proxy}
MONGO_HOST: ${MONGO_HOST}
MONGO_PORT: ${MONGO_PORT}
DB_NAME: ${DB_NAME}
COLLECTION_NAME: ${COLLECTION_NAME}
restart: unless-stopped

networks:
default:
driver: bridge
Loading

0 comments on commit 72123b2

Please sign in to comment.