frigate/frigate/data_processing/post/review_descriptions.py

87 lines
2.9 KiB
Python
Raw Normal View History

"""Post processor for review items to get descriptions."""
import logging
2025-08-07 14:52:51 +03:00
import shutil
2025-08-03 19:06:38 +03:00
import cv2
from frigate.config import FrigateConfig
from frigate.data_processing.types import PostProcessDataEnum
2025-08-09 01:57:43 +03:00
from frigate.genai import GenAIClient
from ..post.api import PostProcessorApi
logger = logging.getLogger(__name__)
class ReviewDescriptionProcessor(PostProcessorApi):
2025-08-09 01:57:43 +03:00
def __init__(self, config: FrigateConfig, metrics, client: GenAIClient):
super().__init__(config, metrics, None)
2025-08-03 19:06:38 +03:00
self.tracked_review_items: dict[str, list[tuple[int, bytes]]] = {}
2025-08-09 01:57:43 +03:00
self.genai_client = client
def process_data(self, data, data_type):
if data_type != PostProcessDataEnum.review:
return
2025-08-03 22:47:46 +03:00
logger.info(f"processing review {data['type']} on {data['after']['camera']}")
2025-08-03 19:06:38 +03:00
id = data["after"]["id"]
if data["type"] == "new" or data["type"] == "update":
if id not in self.tracked_review_items:
self.tracked_review_items[id] = []
thumb_time = data["after"]["data"]["thumb_time"]
thumb_path = data["after"]["thumb_path"]
if thumb_time and thumb_path:
2025-08-03 22:47:46 +03:00
if (
len(self.tracked_review_items[id]) > 0
and self.tracked_review_items[id][0] == thumb_time
):
# we have already processed this thumbnail
return
2025-08-07 14:52:51 +03:00
shutil.copy(thumb_path, f"/media/frigate/frames/{thumb_time}.webp")
2025-08-03 19:06:38 +03:00
thumb_data = cv2.imread(thumb_path)
ret, jpg = cv2.imencode(
".jpg", thumb_data, [int(cv2.IMWRITE_JPEG_QUALITY), 100]
)
if ret:
self.tracked_review_items[id].append((thumb_time, jpg.tobytes()))
else:
2025-08-03 22:47:46 +03:00
if id not in self.tracked_review_items:
return
final_data = data["after"]
2025-08-09 01:53:54 +03:00
camera = final_data["camera"]
2025-08-09 01:57:43 +03:00
if (
data["type"] == "alert"
and not self.config.cameras[camera].review.genai.alerts
):
2025-08-09 01:53:54 +03:00
self.tracked_review_items.pop(id)
return
2025-08-09 01:57:43 +03:00
elif (
data["type"] == "detection"
and not self.config.cameras[camera].review.detections
):
2025-08-09 01:53:54 +03:00
self.tracked_review_items.pop(id)
return
2025-08-03 22:47:46 +03:00
self.genai_client.generate_review_description(
{
2025-08-09 01:53:54 +03:00
"camera": camera,
2025-08-07 14:37:19 +03:00
"objects": final_data["data"]["objects"],
"recognized_objects": final_data["data"]["sub_labels"],
2025-08-03 22:47:46 +03:00
"zones": final_data["data"]["zones"],
},
[r[1] for r in self.tracked_review_items[id]],
2025-08-03 19:06:38 +03:00
)
self.tracked_review_items.pop(id)
def handle_request(self, request_data):
pass