mirror of
https://github.com/blakeblackshear/frigate.git
synced 2026-02-13 14:45:25 +03:00
Add fields
This commit is contained in:
parent
c918382d19
commit
4fd9a38be7
@ -28,7 +28,6 @@ class FirebaseClient(Communicator): # type: ignore[misc]
|
|||||||
|
|
||||||
def publish(self, topic: str, payload: Any, retain: bool = False) -> None:
|
def publish(self, topic: str, payload: Any, retain: bool = False) -> None:
|
||||||
"""Wrapper for publishing when client is in valid state."""
|
"""Wrapper for publishing when client is in valid state."""
|
||||||
logger.info(f"got a message on {topic}")
|
|
||||||
if topic == "reviews":
|
if topic == "reviews":
|
||||||
self.messenger.send_message(json.loads(payload))
|
self.messenger.send_message(json.loads(payload))
|
||||||
|
|
||||||
@ -44,7 +43,16 @@ class FirebaseMessenger(threading.Thread):
|
|||||||
self.stop_event = stop_event
|
self.stop_event = stop_event
|
||||||
|
|
||||||
def send_message(self, payload: dict[str, any]) -> None:
|
def send_message(self, payload: dict[str, any]) -> None:
|
||||||
|
# Only notify for alerts
|
||||||
|
if payload["after"]["severity"] != "alert":
|
||||||
|
return
|
||||||
|
|
||||||
state = payload["type"]
|
state = payload["type"]
|
||||||
|
|
||||||
|
# Don't notify if message is an update and important fields don't have an update
|
||||||
|
if state == "update" and len(payload["before"]["objects"]) == len(payload["after"]["objects"]) and len(payload["before"]["zones"]) == len(payload["after"]["zones"]):
|
||||||
|
return
|
||||||
|
|
||||||
sorted_objects: set[str] = set()
|
sorted_objects: set[str] = set()
|
||||||
|
|
||||||
for obj in payload["after"]["data"]["objects"]:
|
for obj in payload["after"]["data"]["objects"]:
|
||||||
@ -53,12 +61,10 @@ class FirebaseMessenger(threading.Thread):
|
|||||||
|
|
||||||
sorted_objects.update(payload["after"]["data"]["sub_labels"])
|
sorted_objects.update(payload["after"]["data"]["sub_labels"])
|
||||||
|
|
||||||
title = f"{', '.join(sorted_objects).replace('_', ' ')}{' was' if state == 'end' else ''} detected in {', '.join(payload['after']['data']['zones']).replace('_', ' ')}"
|
|
||||||
logger.info(f"sending message with title {title}")
|
|
||||||
message = messaging.MulticastMessage(
|
message = messaging.MulticastMessage(
|
||||||
notification=messaging.Notification(
|
notification=messaging.Notification(
|
||||||
title=f"{', '.join(sorted_objects).replace('_', ' ')}{' was' if state == 'end' else ''} detected in {', '.join(payload['after']['data']['zones']).replace('_', ' ')}",
|
title=f"{', '.join(sorted_objects).replace('_', ' ').title()}{' was' if state == 'end' else ''} detected in {', '.join(payload['after']['data']['zones']).replace('_', ' ').title()}",
|
||||||
body=f"Detected on {payload['after']['camera']}",
|
body=f"Detected on {payload['after']['camera'].replace('_', ' ').title()}",
|
||||||
),
|
),
|
||||||
tokens=[
|
tokens=[
|
||||||
"cNNicZp6S92qn4kAVJnzd7:APA91bGv-MvDmNoZ2xqJTkPyCTmyv2WG0tfwIqWUuNtq3SXlpQJpdPCCjTEehOLDa0Yphv__KdxOQYEfaFvYfTW2qQevX-tSnRCVa_sJazQ_rfTervpo_zBVJD1T5GfYaY6kr41Wr_fP"
|
"cNNicZp6S92qn4kAVJnzd7:APA91bGv-MvDmNoZ2xqJTkPyCTmyv2WG0tfwIqWUuNtq3SXlpQJpdPCCjTEehOLDa0Yphv__KdxOQYEfaFvYfTW2qQevX-tSnRCVa_sJazQ_rfTervpo_zBVJD1T5GfYaY6kr41Wr_fP"
|
||||||
@ -67,16 +73,12 @@ class FirebaseMessenger(threading.Thread):
|
|||||||
messaging.send_multicast(message)
|
messaging.send_multicast(message)
|
||||||
|
|
||||||
def run(self) -> None:
|
def run(self) -> None:
|
||||||
logger.info("Starting notifications setup")
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
firebase_admin.get_app()
|
firebase_admin.get_app()
|
||||||
except ValueError:
|
except ValueError:
|
||||||
cred = credentials.Certificate("/config/firebase-priv-key.json")
|
cred = credentials.Certificate("/config/firebase-priv-key.json")
|
||||||
firebase_admin.initialize_app(credential=cred)
|
firebase_admin.initialize_app(credential=cred)
|
||||||
|
|
||||||
logger.info("finished notifications startup")
|
|
||||||
|
|
||||||
while self.stop_event.wait(0.1):
|
while self.stop_event.wait(0.1):
|
||||||
# TODO check for a delete invalid tokens
|
# TODO check for a delete invalid tokens
|
||||||
pass
|
pass
|
||||||
|
|||||||
@ -1,8 +1,8 @@
|
|||||||
// Give the service worker access to Firebase Messaging.
|
// Give the service worker access to Firebase Messaging.
|
||||||
// Note that you can only use Firebase Messaging here. Other Firebase libraries
|
// Note that you can only use Firebase Messaging here. Other Firebase libraries
|
||||||
// are not available in the service worker.
|
// are not available in the service worker.
|
||||||
importScripts('https://www.gstatic.com/firebasejs/8.10.1/firebase-app.js');
|
importScripts("https://www.gstatic.com/firebasejs/8.10.1/firebase-app.js");
|
||||||
importScripts('https://www.gstatic.com/firebasejs/8.10.1/firebase-messaging.js');
|
importScripts("https://www.gstatic.com/firebasejs/8.10.1/firebase-messaging.js");
|
||||||
|
|
||||||
// Initialize the Firebase app in the service worker by passing in
|
// Initialize the Firebase app in the service worker by passing in
|
||||||
// your app's Firebase config object.
|
// your app's Firebase config object.
|
||||||
@ -23,15 +23,17 @@ const messaging = firebase.messaging();
|
|||||||
|
|
||||||
messaging.onBackgroundMessage((payload) => {
|
messaging.onBackgroundMessage((payload) => {
|
||||||
console.log(
|
console.log(
|
||||||
'[firebase-messaging-sw.js] Received background message ',
|
"[firebase-messaging-sw.js] Received background message ",
|
||||||
payload
|
payload
|
||||||
);
|
);
|
||||||
// Customize notification here
|
// Customize notification here
|
||||||
const notificationTitle = 'Background Message Title';
|
|
||||||
const notificationOptions = {
|
const notificationOptions = {
|
||||||
body: 'Background Message body.',
|
body: payload.notification.body,
|
||||||
icon: '/images/maskable-icon.png',
|
icon: '/images/maskable-icon.png',
|
||||||
};
|
};
|
||||||
|
|
||||||
self.registration.showNotification(notificationTitle, notificationOptions);
|
self.registration.showNotification(
|
||||||
|
payload.notification.title,
|
||||||
|
notificationOptions
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user