Skip to content
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

Subscription notifications (demo set up) #910

Open
suryayadavalli opened this issue Mar 1, 2021 · 7 comments
Open

Subscription notifications (demo set up) #910

suryayadavalli opened this issue Mar 1, 2021 · 7 comments
Assignees

Comments

@suryayadavalli
Copy link
Contributor

suryayadavalli commented Mar 1, 2021

  1. PITON App subscribes for notifications via HSLynk
  2. HSLynk registers/ subscribes itself with opencitylabs for notifications (for that specific client)
  3. opencitylabs notifies resthook when criteria is met
  4. HSLynk's resthook writes to websocket
  5. PITON app listens to websocket for notifications from HSLynk's rest hook.

image

Rest hook (to be registered with opencitylabs) : https://api.hslynk.com/hmis-event-service/eventnotifications
Web socket URL that PITON need to listen to : realtime.hslynk.com/hmis-event-service/events-socket
Specific channels (to be listened to from PITON) :
To listen for all / any client's notifications : /clients
To listen to notifications for a specific client using client ID : /clients/{clientid}
To listen to notifications for a specific client using client's Dedup ID : /clients/{dedupclientid}

The body that is received from opencitylabs will be sent as is to the websocket (for demo purposes).

Test implementation of the complete flow
https://realtime.hslynk.com/hmis-event-service/socket-test.html

@suryayadavalli
Copy link
Contributor Author

@suryayadavalli
Copy link
Contributor Author

@eric-jahn
Copy link
Member

@suryayadavalli In the diagram, I thought HSLynk was going to subscribe to alerts. Piton App would just display them when the callback comes in. Can we create a subscription endpoint Piton App can call to tell HSLynk what to subscribe to, for alerts?

@suryayadavalli
Copy link
Contributor Author

@eric-jahn : Will come up with an subscription end point that PITON can call.

@suryayadavalli suryayadavalli self-assigned this Mar 1, 2021
@suryayadavalli
Copy link
Contributor Author

Client subscription API details
URL: https://api.hslynk.com/hmis-event-service/rest/clients/e14b1753-7066-446f-badf-c89b0606ed0e/subscriptions

Request body

{
    "type":"COVID"
}

@eric-jahn
Copy link
Member

We'll have to change this API to "event service" or something more generic, since it isn't really specific to HMIS. Any human services program dealing with COVID could use it.

@suryayadavalli
Copy link
Contributor Author

suryayadavalli commented Mar 9, 2021

@eric-jahn : name change to event-service is done. @logicsandeep and I had a meeting to go through the details of the real time notifications implementation.

Here is what's NOT included in the demo set up

  1. Storing the notifications and exposing an API for PITON to fetch all the notifications. The notifications will be sent to PITON real-time (not in a store/fetch approach)
  2. Ability to subscribe for multiple clients. Currently subscription API need to be called for each client that should be subscribed. As per @Jeni, they are working with the client Sarah at this time, so not sure if we need to have this multi client subscription API in place now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants