diff --git a/docs/wallet/push-notification.md b/docs/wallet/push-notification.md new file mode 100644 index 00000000..ed727667 --- /dev/null +++ b/docs/wallet/push-notification.md @@ -0,0 +1,126 @@ +--- +id: push-notification +title: Push Notifications +sidebar_label: Push Notifications +description: Implement push notifications on your app. +keywords: + - docs + - polygon id + - wallet + - push notification +--- + +import useBaseUrl from '@docusaurus/useBaseUrl'; + +## Guide + +Currently, to be able to implement a notification flow for a certain app, this app must be registered in the push gateway config. This can result in a centralization point for developers who want to use such feature and some expenses and efforts on support of the current gateway. + +For the Polygon ID wallet, this push service is used: [http://push.polygonid.me](http://push.polygonid.me). + +Current notification flow: + +![push](/img/wallet/push.png) + +1. User creates a device push token. After scanning the authorization request, the user must prepare an authorization response according to the current rules, but with an addition: the inclusion of the DID document. This +DID document contains the user DID and service to send push notifications. The user encrypts the device push token with the Push Gateway public encryption key and embeds it onto the DID document. +2. Verifier sends a message to Push Gateway with information from the user DID document. +3. Push Gateway decrypts push token, stores messages, and sends the push notification to the wallet. +4. The wallet gets the message with the message ID and PPG URL. The application fetches notifications from the service, handles protocol messages and asks the user if he wants to perform a needed action, e.g. fetch credential. + +**Glossary:** + +- *wallet* - mobile application published by Polygon. +- *verifier* - backend for Polygon Verify application that verifies user documents. +- *Push Gateway (PG)* - service to deliver push notifications to the wallet app. +- *Push notification* - notification that contains a link to protocol message or protocol message itself that is delivered through the notification provider. + +## How to run a server + +1. Go to [this link](https://github.com/iden3/notification-service) and follow the instructions to run your own push notification service. + 1. For a Push Gateway service a sygnal is used. Sygnals can send notifications to Android and Apple devices. For Android devices, a sygnal has integration with FCM; for Apple devices, the sygnal has APNS integration. Also, we can add any other provider like SNS. For this we must implement the next flow. + 2. Default algorithm for encryption is `RSA-OAEP-512` +2. Register your application on a Firebase provider and update config. +3. Get public key of notification service for further encryption actions. + +## How to send an AuthorizationResponse from mobile with push information + +1. Create a simple DID document + +```json +{ + "@context": [ + "https://www.w3.org/ns/did/v1" + ], + "id": "did:polygonid:polygon:mumbai:2qDj9EDytmvtQP1or3FxykXGEaqSA1ss479MYHDMJc" +} +``` + +You can add information about keys / authentication info optionally. Follow [this specification](https://github.com/0xPolygonID/did-polygonid/blob/main/did-polygonid-method-draft.md) + +2. Create encrypted device information. +Device information must be a valid JSON and encrypted with the public key of the Push Gateway. Apply base64 encoding to encrypted byte array. +An encryption key must be used from the notification service. + +```json +{ + "app_id": "...", + "pushkey": "push key", +} +``` + +3. Add push service for DID document to service section + + ```json + { + "@context": [ + "https://www.w3.org/ns/did/v1", + "https://schema.iden3.io/core/jsonld/auth.jsonld" + ], + "id": "did:polygonid:polygon:mumbai:2qDj9EDytmvtQP1or3FxykXGEaqSA1ss479MYHDMJc", + "service": { + "id": "did:polygonid:polygon:mumbai:2qDj9EDytmvtQP1or3FxykXGEaqSA1ss479MYHDMJc#push", + "type": "push-notification", + "serviceEndpoint": "https://push.polygonid.me", + "metadata": { + "devices": [ + { + "ciphertext": "sIyhw8MsRzFTMXnPvvPnjpj38vVHK9z7w/DvHzX+i/68hSjWfSDjXUA49KopWexyoVsAhenS+AS7+JkatJ3+OTlNxUD+lFrAIJUE51qBiM7l7mmkAuryybUQmOgWJCbuUU2nsWFKzIvk2ZTxcMh5EoUxYV2/0HaTmYYTDkzCKQr/oVePlHbiKwG6XjjMCuNaooSAO7UlLduEZY9CjCWBahiJ7LPHq5+SMCSpA9DdxlYe5IDY7ZT0Yg8fmEAq5+ZGvPVDzk1SdXvZNtG/2yygb3ILrSHXN81ztJRPdsEjzctqWwIhP1zEncSMnNEY4vtxEc1red4PuNT6QX0EoP/aX4LdSGIgfM3KB6yjqKBOqgIGoTFih0h/YzcC42lv4oJw0t5obX+32FM8pzQBUoXMvV0F9WpNgDcN04F3/Su9GGRLFNLXApCtj2Mh4H0qnkjMzRMO42RTd3258HYH7U8xK48hpO0Wolt+rn3jrk/JXrVQqO/9EnhCu/PJL1+AoeVtTYL0zp57OWnIAXbW98MGg0pm0MpYwH51hmHx0YLH+4Fkqj30ydcZQhV3xtAVgvKfxQOwwNz2WhIefm+fwYLVAQB4SjUMOrRQYAos7PWgoc21I0QFu52dIA4IvYYBws2Vjb1LvssdFnrd4kUYbC7THdlWONfunbp9xgofzXTrj2g=", + "alg": "RSA-OAEP-512" + } + ] + } + } + } + ``` + +4. Include the DID document as a `did_doc` field in the authorization response message [https://iden3-communication.io/authorization/1.0/response/](https://iden3-communication.io/authorization/1.0/response/) +Notification message format that is expected to be sent to mobile. URL field is a valid URL to fetch a message. Fetch request must be HTTP GET request with no authorization required. The message is available for 24 hours on Push gateway or deleted after the fetch request. + +```json +{ + "id": "...", + "url": "..." +} +``` + +## How to send a push from verifier + +1. Parse a dDIDd document from the authorization response +2. Proxy device info to push service using serviceEndpoint using the following format + 1. Message is the protocol message that is meant to be delivered to users + 2. Devices is an object from the push notification service from user DID document + + ```json + { + "message": "JSON stringlied message", + "metadata": { + "devices": [ + { + "ciphertext": "...", + "alg": "..." + } + ] + } + } + ``` diff --git a/sidebars.js b/sidebars.js index c1f81359..f873b00d 100644 --- a/sidebars.js +++ b/sidebars.js @@ -285,7 +285,8 @@ module.exports = { "wallet/wallet-sdk/polygonid-app", "wallet/features" ] - } + }, + "wallet/push-notification" ], }, "smart-contracts", diff --git a/static/img/wallet/push.png b/static/img/wallet/push.png new file mode 100644 index 00000000..22bbec0b Binary files /dev/null and b/static/img/wallet/push.png differ