Self implementing Web Push into a Svelte Kit App
hartenfellerdev
32 min, 58 sec
A detailed guide on implementing push notifications for a web application without third-party services.
Summary
- The process involves sending notifications from a server to Apple or Google servers, which then push the notification to the appropriate device.
- A demonstration is provided using an example music store web application called 'escalet demo app'.
- The video covers setting up the backend for notifications, handling user permissions, creating a service worker, and testing notifications.
- The code for the implementation is available on GitHub and the process does not rely on third-party services, making it cost-effective.
Chapter 1
data:image/s3,"s3://crabby-images/4f251/4f2510230dbeb0bd5411909c2510d2947090a20a" alt="Introduction to the concept and utility of push notifications for web applications."
Introduction to the concept and utility of push notifications for web applications.
- The goal is to send notifications from a server directly to a user's device, which can be a phone or a computer.
- These notifications are useful for immediate alerts, such as when a new message arrives from a messaging app.
- The website does not need to be open; only the browser needs to be active for notifications to work.
data:image/s3,"s3://crabby-images/4f251/4f2510230dbeb0bd5411909c2510d2947090a20a" alt="Introduction to the concept and utility of push notifications for web applications."
Chapter 2
data:image/s3,"s3://crabby-images/1fd21/1fd21b644956beaafb8715b5e7dbe160a7f8db56" alt="Setting up and explaining the escalet demo app used for the push notification example."
Setting up and explaining the escalet demo app used for the push notification example.
- The demo app is a music store application built for demonstration purposes, with its code available on GitHub.
- A settings page allows logged-in users to enable push notifications for new album updates.
- Users must give permission for the browser to send notifications to reduce spam.
data:image/s3,"s3://crabby-images/1fd21/1fd21b644956beaafb8715b5e7dbe160a7f8db56" alt="Setting up and explaining the escalet demo app used for the push notification example."
Chapter 3
data:image/s3,"s3://crabby-images/d9136/d9136ea0a5d5684e0dbe15b90b55ac9b421a3fe7" alt="Handling user permissions for receiving notifications."
Handling user permissions for receiving notifications.
- A check is performed on page load to see if notification permissions have been granted by the user.
- If not already granted, the app displays a button that, when clicked, requests permission to send notifications.
- The user can manually allow or block notifications from the browser prompt.
data:image/s3,"s3://crabby-images/d9136/d9136ea0a5d5684e0dbe15b90b55ac9b421a3fe7" alt="Handling user permissions for receiving notifications."
Chapter 4
data:image/s3,"s3://crabby-images/2aaf3/2aaf373c69301b531e9d35eb04983c6df9666846" alt="Implementation of push notifications includes generating keys and creating subscriptions."
Implementation of push notifications includes generating keys and creating subscriptions.
- A private-public key pair called VAPID keys is generated for secure communication.
- The public key is shared with the front end, while the private key is kept secret in the backend environment.
- The app requests the public key from the backend and then subscribes the user through the service worker.
data:image/s3,"s3://crabby-images/2aaf3/2aaf373c69301b531e9d35eb04983c6df9666846" alt="Implementation of push notifications includes generating keys and creating subscriptions."
Chapter 5
data:image/s3,"s3://crabby-images/a95a8/a95a852f1fed8f98e2b750314a7f20a341da22d6" alt="Backend setup includes adding new dependencies and generating VAPID keys."
Backend setup includes adding new dependencies and generating VAPID keys.
- New dependencies like 'web-push' are added to the backend to facilitate notification management.
- The VAPID keys are generated using a command-line utility and stored in the environment file for later use.
- An endpoint is created to provide the public key to the front end.
data:image/s3,"s3://crabby-images/a95a8/a95a852f1fed8f98e2b750314a7f20a341da22d6" alt="Backend setup includes adding new dependencies and generating VAPID keys."
Chapter 6
data:image/s3,"s3://crabby-images/a11f5/a11f53ecaba1829f17885d3c005b057575cd2eae" alt="Explaining the service worker's role and the subscription flow in push notifications."
Explaining the service worker's role and the subscription flow in push notifications.
- A service worker script is used to run background tasks like notifications.
- The app asks the service worker to create a push subscription using the public key.
- Subscription details are then sent back to the server to be stored for future notification pushes.
data:image/s3,"s3://crabby-images/a11f5/a11f53ecaba1829f17885d3c005b057575cd2eae" alt="Explaining the service worker's role and the subscription flow in push notifications."
Chapter 7
data:image/s3,"s3://crabby-images/420e5/420e55c15a847cefe183673fcf2931ae5beae37d" alt="Building the front end logic to handle notification subscription and unsubscription."
Building the front end logic to handle notification subscription and unsubscription.
- The settings page is updated to include functionality to generate a subscription with the public key.
- Functions are added to check the subscription status and to allow users to unsubscribe.
- When a subscription is created or found, it is sent to the backend for storage.
data:image/s3,"s3://crabby-images/420e5/420e55c15a847cefe183673fcf2931ae5beae37d" alt="Building the front end logic to handle notification subscription and unsubscription."
Chapter 8
data:image/s3,"s3://crabby-images/8c038/8c03865144258f44a1d317e214e5bf54a32c8841" alt="Testing the notification system with the service worker and handling failed notifications."
Testing the notification system with the service worker and handling failed notifications.
- The service worker is updated with an event listener for push events to display notifications.
- Testing the notification system ensures that it works as expected.
- A logic is added to delete subscriptions if multiple notification attempts fail, to avoid redundant data.
data:image/s3,"s3://crabby-images/8c038/8c03865144258f44a1d317e214e5bf54a32c8841" alt="Testing the notification system with the service worker and handling failed notifications."
Chapter 9
data:image/s3,"s3://crabby-images/35933/35933ce33bec82518b2fa8fccea61950be086ffd" alt="Final steps of implementing and testing notifications, including adding users to notification channels."
Final steps of implementing and testing notifications, including adding users to notification channels.
- A test notification is implemented and a button is added to trigger it.
- Notifications are successfully sent and received across different browsers and devices.
- The tutorial concludes with a demonstration of the working notification system.
data:image/s3,"s3://crabby-images/35933/35933ce33bec82518b2fa8fccea61950be086ffd" alt="Final steps of implementing and testing notifications, including adding users to notification channels."