Preamble
Idea: 086
Title: Push Notifications v2
Status: Draft
Created: 2018-03-01
Q2 Objective: 1.2
Summary
The current push notification system is sort of in an MVP stage. It works, but there are lots of important improvements which we need to accomplish in order to meet basic expectations from end users, such as supporting group chats and previewing the message sender and content on the notification itself.
Swarm Participants
- Lead Contributor: @PombeirP (~20h/week)
- Testing & Evaluation: @nastya
- Contributor (Go): @adriacidre (24h/week)
- Contributor (Clojure): @yenda
- Contributor (QA): @nastya
Product Overview
The user expects push notifications to be reliable and helpful while maintaining security. Some familiar behaviors illustrate some fundamental inter-connected qualities:
- Reliable:
- A user expects to receive a notification in the following scenarios:
- His screen is turned off, and he receives a message.
- His screen is on, and the app is running in the background.
- The app is in the foreground, and he receives a new message in a chat room which is not visible.
- A user expects his conversation partners to be notified in a timely manner.
- A user expects that the notifications he finds on his device accurately reflect unread messages.
- A user expects to receive a notification in the following scenarios:
- Helpful:
- A user expects that the notifications he finds on his device accurately reflect unread messages. If he has browsed through a conversation that included messages mentioned in a PN, the PN should be updated accordingly, so the user is not misled and can trust the notification system.
- A user expects to be able to see message details from notifications without needing to open the app (perhaps configurable due to privacy concerns?).
- A user expects to be able to be able to ping other users selectively user @-type addressing (individual and group notifications), to reduce unnecessary noise.
- Timely:
- A user expects that relevant events are received as notifications in a timely fashion (i.e., < 15 seconds from actual event).
- Secure:
- A user expects that by receiving PNs, he is not giving up the degrees of anonymity and plausible deniability which are afforded by the app's underlying communication protocol.
We want to end up with a notification system which works on as many devices as possible and is resistant to censorship. There are countries which block certain notification providers (an example being China blocking Google Cloud Messaging). For that to be possible, we need to allow users to select their notification provider (with a reasonable default being Pushy or FCM), and to incentivize the creation of a paid notification provider economy. Per Oskar’s description:
“Alice and Bob are chatting with Eve the masternode/mailserver listening. Bob uses F-Droid / lives in Cuba and thus can't/doesn't want to use Firebase/GCM (see whitepaper). Eve sees this as an opportunity to host a node which can serve Bob. Alice does not know any of this. Bob registers their method of choice for PN with Eve, so that when Alice sends a message to Bob, Eve also picks it up and triggers a push notification on Bob's device. Eve cannot inspect the payload.”
We also want a solution that doesn’t involve talking directly to the notification provider, as that would require keeping authentication elements embedded in the app (currently the case), and might expose us to quota theft.
Flow Diagram
Goals
At a high-level, we want to move up the current solution a notch regarding some of the critical qualities mentioned in the Product Overview which are currently lagging behind. The specific steps to reach that goal are:
-
Improve usability of notifications by:
- Allowing the app to match a push notification with a specific chat message. That way we can:
- [
P1
] support navigating to the correct chat when the user taps on the message, and conversely. - [
P2
] support dismissing notification when user has seen the respective message in a chat.
- [
- [
P3
] adding "quick actions" buttons on mobile notifications, so the user can directly "mark as read" or "delete" specific messages.
- Allowing the app to match a push notification with a specific chat message. That way we can:
-
Improve helpfulness by:
- [
P0
] retrieving the message body and displaying it in the notification body so that the user can see who is talking and what is being said without needing to unlock the phone or opening the app. - [
P2
] supporting simplistic deep-linking. Clicking on a push notification should take you to the specific chat that is mentioned. We could achieve this functionality by looking for the message in all chats that match the ID from the notification. - [
P3
] making Push Notifications work in group chats. By default, participants would only receive notifications when being mentioned with an@
symbol, to avoid creating a noisy environment that would degrade the whole experience. - [
P3
] supporting full deep-linking. Support for it might require mapping screens to specific URLs. Useful beyond push notifications.
- [
-
Improve security of the solution by:
- [
P0
] not embedding FCM (Firebase Cloud Messaging) server key in source code or app binary. - [
P4
] building a pluggable model for Push Notifications so that 3rd party providers can have a convincing economic model to host their own Push Notification servers.
- [
Requirements & Dependencies
- status-im/ideas#87: In order to build on a stable foundation, we should make sure we start addressing this after the new communication protocol has landed.
- status-im/status-react#3451: Preview notifications using background app refresh.
- status-im/status-react#3488: Clicking message notification does not open the chat
- status-im/status-react#3487: Notifications about previous messages should disappear when chat is opened
Exit criteria
There are undoubtedly enough issues identified to span several months of effort, so it seems reasonable to have a Swarm that tackles the problems which have the most impact on the user in the short term and leave the rest for a future Swarm to form around. There is value however in documenting the shortcomings of the current implementation, even if they are too far away on the horizon to be addressed in this Swarm (e.g., 3rd party PN provider support).
With that in mind, the exit criteria are as follows:
- The swarm has addressed all
P0
andP1
goals mentioned in the goals section.
Success Metrics
KRs:
- 100% of the messages that should generate a notification on the receiving device do so within 15 seconds, under different network conditions (i.e. Wi-Fi, cellular).
- Network and battery consumption values are same or less than current values.
MVP(s)
- Single notification provider phase:
- Iteration 1: Show more information on notification (date: Beginning Of Work/BOW + 2w)
- Send only envelope hash on PN to destination device so that it knows to refresh messages and to match them to the notification.
- Update message body from retrieved Whisper message.
- Iteration 2: Implement notification server mode on
statusd
(date: BOW + 4w)- Connects to FCM, only 1 instance, no load-balancing.
- Add logic to statusd (accept special P2P messages from clients, and trigger notifications in response).
- Deploy service with Ansible.
- Change client so that it communicates with notification server to send notifications indirectly to contact.
- Iteration 3: Support simple deep-linking (date: BOW + 6w)
- Open respective chat when taping on a notification.
- Hide notification when the user views the respective message in chat.
- Iteration X: TBD
- Iteration 1: Show more information on notification (date: Beginning Of Work/BOW + 2w)
- "Multiple notification provider" phase:
- TBD
Supporting Role Communication
TBD
Useful Links
- v1 Push notifications proposal
- Whisper Push Notifications wiki
- Work notes
- Gorush, a push notification server written in Go
Copyright
Copyright and related rights waived via CC0.