-
-
Notifications
You must be signed in to change notification settings - Fork 310
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Harmonizing and improving notifications across platforms #176
Comments
I think I'm in favour of pretty much all of this. The following I think are hugely positive
That will allow us to implement a new type of automation block
I'm a little worried about
I'm keen to hear more on the new blocking event, we have a lot of users who send a notification to all members of say a household and then clear for all when an action (no necessarily in HAC) is taken. I think this could neaten that up a lot |
NotificationsActions"actions": [
{
"title": "Action 1",
"id": "action_one"
}
] When implementing the actions for android I modeled them off the existing html5 standard, maybe stay in line with that? https://developer.mozilla.org/en-US/docs/Web/API/NotificationAction Light Settings"light_settings": "" This isn't just a string, it's a full object: https://firebase.google.com/docs/reference/admin/node/admin.messaging.LightSettings.html Vibration"vibrate_timings": ["1s", "3.5s"] Because we are using the admin sdk to send the notifications we should stick with what it accepts as values: https://firebase.google.com/docs/reference/admin/node/admin.messaging.AndroidNotification.html#optional-vibrate-timings-millis Action EventsWhere does that "actions":
[
{
"title": "Action 1",
"id": "action_one",
"action_data": { }
}
] End to end encrypted notificationsI think this is a great idea overall, however, we need to be careful. FCM has a limit to the payload size. If we aren't careful we might be allowing people to go above the limit causing failed messages. I agree that we might need to identify some meta data about the messages that is send so that we can correctly send the message ( |
This is amazing thank you @robbiet480 for putting this together! I think that the main features that people would want shared between the 2 platforms will be aligned with this proposal. It will allow for users to use |
This might also be a good time to maybe enforce some of these standards through the https://www.home-assistant.io/integrations/slack#slack-service-data |
Looks like someone else brought up the notification delema in architecture as well. It would be nice if all notifications were a little more consistent. |
I've updated the suggested payload to cover most suggestions made by @JBassett. I also moved Specific responses for Justin:
I'm torn on matching the Changing HAC behavior to unify notifications for anything other than the official apps is outside the scope of this proposal. |
I still haven't come up with a good way to let users provide values that must be sent in the clear, e.g. APNS headers, |
I have to say that the new HA |
So with the upcoming Blueprints feature in Home Assistant, a lot of people are going to be building re-usable and shareable automations that contain notifications involving Mobile App. Some examples that come to mind:
For those above examples, it would be useful to simply tap the notification and get taken to an Amazon product page for the relevant product, so that the user doesn't have to go up on a ladder just to find out their door sensor takes a CR2032 battery or whatever. But you cannot make Blueprints like this currently (with tappable link notifications), because the way the iOS and Android companion apps handle URL's are inconsistent. Other popular blueprints will likely be "water leak detected" and "smoke detected" etc where you'd want to receive a critical notification, but critical notifications differ too depending on platform. Same goes for things like images etc. With Blueprints just around the corner, unifying these as much as possible would be extremely beneficial, that way the community can create shareable automations that work regardless of what mobile platform they use. This proposal was a great idea before, but it'd be even more useful now in the Blueprint era. |
Revisiting this... we’re finally doing it. Moving away from FCM to SNS and switching to e2e notifications. Discussing with @zacwest now. |
Revising an old issue here. For a very long time I used scripts and an automation to normalize schema of sending notifications and receiving notification actions. I audited it this month to see what all I could drop after the efforts to harmonize notifications. I dropped a lot but as of
Since I made the list I thought I would share to capture the current state here. |
Please note, I wrote this while very tired and lacking sleep. It will receive updates over the next few days.
Right now, we live in a similar yet divided world. Home Assistant Companion (hereinafter HAC) for iOS came first and had many years to mature before HAC Android was even a glint in our eyes. Due to that time and somewhat limited thought for the future, iOS made some decisions that don't work well in the Android world. Android is starting to make decisions that will also affect iOS. We should try to cut down on as many differences between the two apps as possible. This will allow us to simplify our documentation but more importantly make it easier for users in households with both Androids and iPhones, in addition to making config sharing easier.
Notifications
The first place to start with is notifications. Right now, both apps support different functionalities. Some functionalities exist because of work developers have done, some will never exist due to OS specific limitations. As much as possible though, we should make it possible for a user to send a notification and 90% of the time it will appear similar across platform. The way that we do this is deriving a schema that both apps can hew to while also providing allowances for platform specific functionality that users want.
As a first step towards that goal, I have come up with this:
As you can see, we have generic fields at the top level (under the
notification
dictionary) and OS specific fields in their own dictionaries. I also made a spreadsheet that shows common features and their availability across both platforms. We should conform both apps to accept this schema. It will be a pain for users to adapt to one time but will have other benefits to be explained later. The change will be opt in for existing users, at least on iOS. We also have added a UUID to the notification payload to provide lifecycle tracking. The UUID should be generated and stored by Home Assistant Core and used in all follow up events and actions. The actions are now also defined in the notification, whereas previously iOS required defining all possible actions in advance. Actions are now registered with iOS just-in-time before displaying the notification.Action Events
The next place the apps deviate significantly to the detriment of the user is Notification Action Events. On iOS, this is the event named
ios.notification_action_fired
. On Android it ismobile_app_notification_action
. To start, iOS should adapt the more genericmobile_app_notification_action
event name. However, the payloads sent in the events are also very different between platforms and deserve to be unified into oneMy proposal is this:
This provides everything we need to let users determine where the event came from, as well as provides them flexibility to customize by providing the
action_data
dictionary, a totally user controlled space. They can fill theaction_data
dict when sending the notification. Theid
is the same one from the notification example above.Providing turnkey automation support
Great, so notifications and events are well defined and traceable. That will allow us to implement a new type of automation block which will allow pausing an automation until such time as a user responds to a notification by tapping an action. Users will no longer have to worry about setting up two automations (one to send the notification and one to catch the response event), it will just be handled seamlessly by Home Assistant Core. @balloob came up with this idea and can expand more on it.
Notification Lifecycle Tracking
Now that notifications have unique IDs attached to them, we can monitor them through their entire lifecycle. I propose adding the following new events:
In addition, I propose that Home Assistant Core start storing these notifications and providing a API to
mobile_app
implementors to allow viewing notification history.End to end encrypted notifications
As somewhat of a carrot to get iOS users to opt in to the new notification and event formats, we will begin offering end to end encryption of push notifications on both platforms. On iOS, this is made possible by UNNotificationServiceExtension which will decrypt and map the notification payload before displaying the notification to the user. On Android, we already are in a position where the app is the one processing and displaying the notification, not the OS.
mobile_app
will be modified to encrypt outgoing notifications using libsodium with the same webhook secret the apps already have. A very minimal forwarder has already been developed and deployed and is available for review here. Here's everything that the forwarder receives:and what it sends to the device:
Obviously our servers are unable to break the encryption and the secret is only ever exchanged directly via app and Home Assistant Core. iOS requires alert and mutable-content to be set to engage our UNNotificationServiceExtension. The user should never actually see that text except if decryption fails for some reason.
The identified downsides to e2e encryption are the following:
ttl
orpriority
fields or APNS headers such asapns-collapse-id
orapns-priority
. Modifications could be made tonotify.mobile_app
to allow sending certain whitelisted parameters in the clear.I'm excited to hear the communities thoughts on this proposal. Thanks for reading.
The text was updated successfully, but these errors were encountered: