-
Notifications
You must be signed in to change notification settings - Fork 328
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
Proposal: Support Windows Push Notifications for Unpackaged Apps and Non-Store Apps #334
Comments
Will this API include support for Live Tiles or updating the App or the App's Pinned Tiles? |
@mdtauk this proposal is primarily focused on visual toast notifications and raw push notifications (where your app gets woken up in the background and can execute code). You'll notice support for push tile notifications is currently listed as a "Could" priority. If you need push tile notifications can you give a specific example of your use case, and the type of app (UWP, WPF, Win32), and whether it's distributed through the Store or not? |
@andrewleader With UWP there was a level of synchronicity with the Notification Channels being used to update tiles. Whilst I no longer have an app out in the store, I did have with Windows Phone 7 - and so it should probably be considered in terms of the use of payloads, and call into the Tile Update Manager. With Apple finally adopting the concept of a Live Tile like Widget - making it easy to support the same kind of functionality which is already there in Windows, is worth doing, even if its not there in an initial first wave. What the Windows team may have in mind for the future of Live Tiles, may play more of a role in when or if it is supported in Reunion - and Windows 8 has Live Tiles which could be supported also. |
My company have several clients that would benefits from this feature (they deploy Non-Store version of our Apps internally and can not leverage the Push Notification feature). Thanks for considering this enhancement. |
Awesome! @ccauquelin are your clients building UWP apps or Win32 MSIX apps or normal Win32 apps? |
They are using our UWP app, installed via sideloading. We are signing our UWP app for sideloading with a genuine code signing certificate, but unfortunately this "breaks" the Push Notification feature in our app. |
@ccauquelin -- one can support push notifications in sideloaded UWP apps today using WNS alternate push channels. This requires using an alternate mechanism (VAPID, etc.) to push notifications to the WNS servers...but it works outside the Store. @andrewleader -- we currently use APNs for push notifications on macOS (in a notarized application we distribute outside the app store). And we're currently planning to mirror that push notification support in our Windows WPF application using the new Project Reunion push notification functionality. Is there a master list of WNS-related PRs (i.e. the various prerequisites/APIs for Project Reunion push notification)? We'd be happy to test them out in both MSIx and unpackaged WPF scenarios--as each of them are developed and lit up--if that would be helpful. |
A related bug report, in case it's helpful: TL;DR: Hopefully we can get both options for WNS push notifications working 100% under .NET 5/6 (alternate channel using sparse packages via a TFM bug fix, plus traditional channel via the cool new Windows App SDK). |
Hi, is there any update on this? I have been monitoring it for a while. We currently have to have a UWP front end that we use desktop bridge however it causes quite a few complications. We want to be able to receive raw notifications from the Azure Notification Hub directly to our WPF application. |
Windows App SDK preview 1.3 should have the changes you need to consume the Push APIs for Unpackaged @vaheeshta has put that into Release notes I believe? The feature unfortunately is broken in Preview 1.2 due to a last minute bug that we identified. |
That is great and I appreciate the quick response! Do you have any sample code or documentation yet on how we can test this? I also appreciate this is still preview however is there any thoughts on when this would be GA? More for our planning than anything else at this point. many thanks |
@hulumane did you mean WinAppSDK 1.1-preview2 / 1.1-preview3, or specifically WinAppSDK 1.3 (for which I don't think we've announced a featureset or release date...) |
Correct. Sorry that was my bad. Yes. I meant 1.1 - preview 3 |
@adamcosby85 We have some documentation on the Client APIs along with sample code here: Please note that Unpackaged apps won't work with Preview 2. They will work with Preview 3 which has addressed the issue at hand. But this should help you get a start on ramping up. |
Correct, unpackaged app support is coming to Windows App SDK 1.1-preview3 after a regression in Windows App SDK 1.1-preview2. Please see the official release notes for the most up-to-date information:
Keep an eye out on https://github.com/microsoft/WindowsAppSDK/discussions/categories/announcements and the stable release notes for when the feature will hit the stable release/GA! |
Proposal has been addressed with the latest Windows App SDK 1.1 APIs. See https://learn.microsoft.com/en-us/windows/apps/windows-app-sdk/notifications/push-notifications/push-quickstart for how to use the push notification APIs to support unpackaged apps. Closing the issue! |
The referenced page is no longer available. Is there an alternate source of the steps required to use Vapid in a side-loaded UWP app, or is this no longer supported? Again to re-iterate, in order to get notifications through WNS with a UWP app you have to distribute a certificate that is issued when uploading the app to the MS Store, whether you distribute the app through the store or not. But, if you are side-loading the app (making the app available to download outside of the store), the store certificate won't work as you need a specific side-loading certificate, but that means notifications don't authenticate. It's not possible for us to convert our project to a Window App SDK project at this time, so I can't use the update announced in this thread. |
@scarabdesign - the instructions on alternate channel notifications (VAPID) appear to have been moved to another page. I am guessing that WNS is probably the recommended path forward. Of note, for alternate channel, "as of July 1, 2021 applications that want to use the web push channel or the alternate channel to send browser based notifications through WNS will need to be onboarded to the Microsoft Store." I don't know if that applies to applications that use the alternate channel to send non-browser based notifications or not. New apps probably needs to be onboarded with the Microsoft Store (rather than in the old partner app registrations) to use VAPID push notifications. I don't work for Microsoft, so this is largely conjecture. Hopefully someone from the push notifications team can chime in. |
Does anyone know what "onboarded to the Microsoft Store" means in the context of a sideloaded LOB app? |
Customer / job-to-be-done: App developers need to keep their users informed about new information even when their app is currently open, ideally in the most battery-efficient way
Problem: Non-store apps cannot use push notifications, so they must keep their app running with a socket open to their server
How does our solution make things easier? All types of apps will be able to use push notifications, and setting up push will be relatively straightforward
🔄 Docs
✅ API spec (#458)
🔄 Dev spec
🔄 Solution validation
🔄 Implementation
❌ Samples
Target customer
✅ Unpackaged apps
✅ Win32 (C++)
✅ WinForms
✅ Console
⚠ Cross-plat (Electron, MAUI, React Native, etc)
⚠ PowerShell
While this work should be consumable by cross-platform platforms to improve experiences there, we should have a separate feature specifically for ensuring push notifications are built in "natively" and developers don't have to do additional custom work to access the Windows native layer.
Customer's job-to-be-done
Problems that exist today
Summary
Currently, only Microsoft Store distributed UWP/ MSIX packaged applications can use Windows Push Notifications due to the explicit dependency to the Microsoft Store identity. This feature's goal is to allow all Windows Applications, including unpackaged Win32 applications and non-Microsoft Store identity apps, to utilize push notifications.
Scope
Important Notes
API Usage Experience
1. Getting Credentials to use Push Notifications
In order to get started using push notification you need to get an identity from the Azure Active Directory App Registration more info here.
2. Application Requesting WNS Channel
Handling Channel Request Retries
3. Sending Push Notifications
This code would exist in your application server and would connect to WNS.
The text was updated successfully, but these errors were encountered: