Skip to content

Latest commit

 

History

History
164 lines (114 loc) · 10.1 KB

PushNotifications.md

File metadata and controls

164 lines (114 loc) · 10.1 KB

Push Notifications

  • Key definitions can be found here

  • Before you can get started with this, you as the Sponsor need to be onboarded with Evernym's Cloud Service. When you onboard as a Sponsor, you provide an endpoint URL where messages will be forwarded by Evernym’s Cloud Service so that you can notify your customer's app (Sponsee) that there are messages available to be picked up from its cloud agent.

  • You will need to set up your own Push Notification System on your back-end and set up a handler for your Notification endpoint URL that processes messages forwarded from Evernym’s Cloud Service and uses your Push Notification System to notify your customer's app (Sponsee).

  • You as the Sponsor will receive messages via Message Forwarding from Evernym's Cloud Service. These messages will contain enough information to push-notify your cutomer (Sponsee)

Message Forwarding

  • Each instance of the mobile SDK (each Sponsee) has an associated cloud agent which provides a store-and-forward function for messages traffic to and from your app.
  • Evernym does not handle your push notification service because it would require us to hold push notification keys to your app (Sponsee).
  • Instead, you will need to host your own push notification service, and receive forwarded messages from each Sponsee's cloud agent. This is done by registering with Evernym as a Sponsor. See below.

1 Sponsor Registration with Evernym's Cloud Service

  • As mentioned, you as a Sponsor will need to register with Evernym's Cloud Service. An endpoint is provided during this registration.
    This endpoint will be whatever address you (Sponsor) want Evernym's Cloud Service to use to forward, via HTTPs, incoming messages meant for the end customer (Sponsee).
  • Your (Sponsor's) responsibility is to handle these forwarded messages by push notifying your customer's (Sponsee's) app or using some other preferred communication mechanism.
    This means you (Sponsor) will have to implement a communication mechanism (e.g. Push Notification Service) with your customer (Sponsee).

2 Sponsee Provisioning

  • As mentioned here, a customer (Sponsee) will need to provision with Evernym's Cloud Service using a token signed by you (Sponsor).

  • After provisioning and SDK initialization are completed, the customer's application (Sponsee) will need to call MSDK method to set up communication method type with the agent.

    • Android - UtilsApi.vcxUpdateAgentInfo(config) (see example function here)
    • iOS - agentUpdateInfo:config
      where config is JSON: 
      {
          `id`: String - whatever the `Sponsor` uses to identify this specific `Sponsee`.
          `type`: Int - Com Method Type (3 or 4),
          `value`: String 
      }
      

3 Evernym's Cloud Service forwarding messages to the you as the Sponsor

  • The customer's Sponsee's messages are forwarded to you (the Sponsor). value will be the whatever information your (Sponsor's) back-end will need to deliver that message to the customer (Sponsee). You will receive this value in the field sponseeDetails in the message from CAS.

  • When Evernym's Cloud Service receives a message for this entity (through provisioned cloud agent), the cloud agent will forward the message to you (Sponsor) at whichever endpoint that was provided during Onboarding.

  • The cloud agent will forward messages to you (the Sponsor's) back-end via http. No A2A encryption will be added. One thing to note here is that this webhook call does not contain cutomer's message. Your customer's cloud agent is only notifying your endpoint that there is a new message available for your customer. The http message will include:

    1. msgId: This is the id that your customer (Sponsee) will use to actually download the message

    2. sponseeDetails: You (Sponsor) will be forwarded your customer's Sponsee messages. This will be the whatever information your (the Sponsor's) back-end will need to deliver that message to the customer (Sponsee). Contains the value that you sent into update_com_method.

    3. relationshipDid - My DID - the specific relationship I'm interacting on.

    4. metaData - message type and sender's name. This is used mostly to display the message for the customer (Sponsee). These values are optional from the sender's perspective.

      {
          msgId: String,
          sponseeDetails: String, 
          relationshipDid: String,
          metaData: {
          msgType: String,
          msgSenderName: String,
          }
      }
  • You Sponsor will then deliver the message to the customer Sponsee with whatever mechanism you already uses to communicate with your customer.

Push notifications setup

For in more depth information how push notifications works in one of the platforms, you can read official documentation sections for:

From Vcx and cloud agent perspective, you will need to link received push notification token you received on your device with your cloud agent in Vcx, so notifications will be sent to correct device.

  • iOS: After wallet initialization steps (eg. AppDelegate.m) call appDelegate.sdkApi agentUpdateInfo:config function

  • Android: After wallet initialization steps (eg. ConnectMeVCX.java) call UtilsApi.vcxUpdateAgentInfo(config) function

    where config is JSON string:
    {
         `id`: String - `Sponsee's` Id, can be device ID
         `type`: Int - Com Method Type (3 or 4),
         `value`: String - FCM:{pushToken}
    }
    

We also recommend using Firebase Cloud Messaging, since it's provide universal configuration for both platforms (iOS and Android): https://firebase.google.com/docs/cloud-messaging/android/client.

How to link your push notification with VCX cloud agent?

For the moment, sending push notifications should happen from user's cloud agent (which will receive notification from Evernym cloud agent) so all mobile device tokens are stored on your side, safely and securely.

We are working also on improving service related to push notifications, we should have more details soon.

Processing push notifications on mobile device

Once you (Sponsor) receive a message on your webhook. You can send push notification to your customer's app. Inside the app you can use method downloadMessages in ObjC or UtilsApi.vcxGetMessages in Java, for pulling either all messages waiting on cloud agent, or a specific one matching to received notification.

See messages documentation for message download information.

Com Method Types

When setting up a communication method with an agent, you can either use Com Method type 3 or 4.

  1. Type 3- Forward Push

This method is used when the sponsor wants to handle sending of actual push notifications.

Mobile app is supposed to register its own push notification details.

Associated sponsor’s configuration should have been already configured with an endpoint.

In this case, Verity will use the associated sponsor’s configured endpoint and send the meta data (msg type, sponsee details, recipient DID etc.) to the associated sponsor’s endpoint. The sponsor is supposed to notify the mobile app about the message, and then, the mobile app is supposed to download the message from its agent by calling the relevant api.

  1. Type 4- Sponsor Push

If using this method, Verity will handle sending of actual push notifications, and you won't need to register the endpoint.

Associated sponsor’s configuration should have been already configured.

Verity will use the associated sponsor’s configured push notification account detail.

Currently, only Firebase Cloud Messaging is supported.

Firebase Cloud Messaging should have been already set up, connected with the app's back end, and working properly.

You need to send your Firebase account key to [email protected], and Verity will use that key to send messages to your Firebase account.

Message Type from Evernym CAS to App's Push Notification webhook

    {
        "msgId": String, // a unique message ID
        "msgType": String, // message type will be one of the message type strings such as "did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/issue-credential/1.0/offer-credential"
        "sponseeDetails": String, // this is the value that app sends to Evernym in API call for ios: "agentUpdateInfo:config" and for Android: UtilsApi.vcxUpdateAgentInfo. Refer Step #2 second point in this document
        "relationshipDid": String, // DID which is used to identify connection
        // metaData is deperacted, please avoid relying on it
        "metaData": {
            "msgType": Option[String], "msgSenderName": Option[String]
        }
    }