mirror of
https://github.com/blakeblackshear/frigate.git
synced 2026-02-05 10:45:21 +03:00
migrate external event handlers from http.py
This commit is contained in:
parent
9e531b0b5b
commit
080a2f5bc8
@ -8,7 +8,11 @@ import random
|
|||||||
import string
|
import string
|
||||||
from multiprocessing.queues import Queue
|
from multiprocessing.queues import Queue
|
||||||
from typing import Optional
|
from typing import Optional
|
||||||
|
from flask import (
|
||||||
|
current_app,
|
||||||
|
jsonify,
|
||||||
|
request,
|
||||||
|
)
|
||||||
import cv2
|
import cv2
|
||||||
|
|
||||||
from frigate.config import CameraConfig, FrigateConfig
|
from frigate.config import CameraConfig, FrigateConfig
|
||||||
@ -128,3 +132,56 @@ class ExternalEventProcessor:
|
|||||||
thumb = cv2.resize(img_frame, dsize=(width, 175), interpolation=cv2.INTER_AREA)
|
thumb = cv2.resize(img_frame, dsize=(width, 175), interpolation=cv2.INTER_AREA)
|
||||||
ret, jpg = cv2.imencode(".jpg", thumb)
|
ret, jpg = cv2.imencode(".jpg", thumb)
|
||||||
return base64.b64encode(jpg.tobytes()).decode("utf-8")
|
return base64.b64encode(jpg.tobytes()).decode("utf-8")
|
||||||
|
|
||||||
|
|
||||||
|
def create_event(camera_name, label):
|
||||||
|
if not camera_name or not current_app.frigate_config.cameras.get(camera_name):
|
||||||
|
return jsonify(
|
||||||
|
{"success": False, "message": f"{camera_name} is not a valid camera."}, 404
|
||||||
|
)
|
||||||
|
|
||||||
|
if not label:
|
||||||
|
return jsonify({"success": False, "message": f"{label} must be set."}, 404)
|
||||||
|
|
||||||
|
json: dict[str, any] = request.get_json(silent=True) or {}
|
||||||
|
|
||||||
|
try:
|
||||||
|
frame = current_app.detected_frames_processor.get_current_frame(camera_name)
|
||||||
|
|
||||||
|
event_id = current_app.external_processor.create_manual_event(
|
||||||
|
camera_name,
|
||||||
|
label,
|
||||||
|
json.get("sub_label", None),
|
||||||
|
json.get("duration", 30),
|
||||||
|
json.get("include_recording", True),
|
||||||
|
json.get("draw", {}),
|
||||||
|
frame,
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
logger.error(f"The error is {e}")
|
||||||
|
return jsonify(
|
||||||
|
{"success": False, "message": f"An unknown error occurred: {e}"}, 404
|
||||||
|
)
|
||||||
|
|
||||||
|
return jsonify(
|
||||||
|
{
|
||||||
|
"success": True,
|
||||||
|
"message": "Successfully created event.",
|
||||||
|
"event_id": event_id,
|
||||||
|
},
|
||||||
|
200,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def end_event(event_id):
|
||||||
|
json: dict[str, any] = request.get_json(silent=True) or {}
|
||||||
|
|
||||||
|
try:
|
||||||
|
end_time = json.get("end_time", datetime.now().timestamp())
|
||||||
|
current_app.external_processor.finish_manual_event(event_id, end_time)
|
||||||
|
except Exception:
|
||||||
|
return jsonify(
|
||||||
|
{"success": False, "message": f"{event_id} must be set and valid."}, 404
|
||||||
|
)
|
||||||
|
|
||||||
|
return jsonify({"success": True, "message": "Event successfully ended."}, 200)
|
||||||
|
|||||||
@ -30,7 +30,7 @@ from tzlocal import get_localzone_name
|
|||||||
|
|
||||||
from frigate.config import FrigateConfig
|
from frigate.config import FrigateConfig
|
||||||
from frigate.const import CLIPS_DIR, MAX_SEGMENT_DURATION, RECORD_DIR
|
from frigate.const import CLIPS_DIR, MAX_SEGMENT_DURATION, RECORD_DIR
|
||||||
from frigate.events.external import ExternalEventProcessor
|
from frigate.events.external import ExternalEventProcessor, create_event, end_event
|
||||||
from frigate.models import Event, Recordings, Timeline
|
from frigate.models import Event, Recordings, Timeline
|
||||||
from frigate.object_processing import TrackedObject
|
from frigate.object_processing import TrackedObject
|
||||||
from frigate.plus import PlusApi
|
from frigate.plus import PlusApi
|
||||||
@ -849,55 +849,13 @@ def events():
|
|||||||
|
|
||||||
|
|
||||||
@bp.route("/events/<camera_name>/<label>/create", methods=["POST"])
|
@bp.route("/events/<camera_name>/<label>/create", methods=["POST"])
|
||||||
def create_event(camera_name, label):
|
def create_event_handler(camera_name, label):
|
||||||
if not camera_name or not current_app.frigate_config.cameras.get(camera_name):
|
return create_event(camera_name, label)
|
||||||
return jsonify(
|
|
||||||
{"success": False, "message": f"{camera_name} is not a valid camera."}, 404
|
|
||||||
)
|
|
||||||
|
|
||||||
if not label:
|
|
||||||
return jsonify({"success": False, "message": f"{label} must be set."}, 404)
|
|
||||||
|
|
||||||
json: dict[str, any] = request.get_json(silent=True) or {}
|
|
||||||
|
|
||||||
try:
|
|
||||||
frame = current_app.detected_frames_processor.get_current_frame(camera_name)
|
|
||||||
|
|
||||||
event_id = current_app.external_processor.create_manual_event(
|
|
||||||
camera_name,
|
|
||||||
label,
|
|
||||||
json.get("sub_label", None),
|
|
||||||
json.get("duration", 30),
|
|
||||||
json.get("include_recording", True),
|
|
||||||
json.get("draw", {}),
|
|
||||||
frame,
|
|
||||||
)
|
|
||||||
except Exception as e:
|
|
||||||
logger.error(f"The error is {e}")
|
|
||||||
return jsonify(
|
|
||||||
{"success": False, "message": f"An unknown error occurred: {e}"}, 404
|
|
||||||
)
|
|
||||||
|
|
||||||
return jsonify(
|
|
||||||
{
|
|
||||||
"success": True,
|
|
||||||
"message": "Successfully created event.",
|
|
||||||
"event_id": event_id,
|
|
||||||
},
|
|
||||||
200,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/events/<event_id>/end", methods=["PUT"])
|
@bp.route("/events/<event_id>/end", methods=["PUT"])
|
||||||
def end_event(event_id):
|
def end_event_handler(event_id):
|
||||||
try:
|
return end_event(event_id)
|
||||||
current_app.external_processor.finish_manual_event(event_id)
|
|
||||||
except Exception:
|
|
||||||
return jsonify(
|
|
||||||
{"success": False, "message": f"{event_id} must be set and valid."}, 404
|
|
||||||
)
|
|
||||||
|
|
||||||
return jsonify({"success": True, "message": "Event successfully ended."}, 200)
|
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/config")
|
@bp.route("/config")
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user