Live Widgets Updates
How to subscribe to data channels to receive live widget updates
All live updates for widgets are delivered by PubNub's publish/subscribe. These updates are received by initializing a PubNub SDK instance and then subscribing to channels associated with the widgets you are interested in receiving updates for. The updates are delivered as PubNub messages with two properties:
event
is the string name of the event, ex.text-poll-results
payload
is an object containing data related to the event
Configuring PubNub
The PubNub SDK must be initialized with an origin and a subscribe key in order to subscribe to channels. The configuration details are available on the Application Resource for your application. The origin is inside the pubnub_origin
property, and the subscribe key is inside the property pubnub_subscribe_key
.
var pubnub = new PubNub({
origin: livelikeAppResource.pubnub_origin,
subscribeKey: livelikeAppResource.pubnub_subscribe_key
})
Make sure to use the specified origin and subscribe key!
Your client won't receive updates unless both the LiveLike origin and the subscribe key are configured in the PubNub client.
Subscribing to Channels
Any resource that can be subscribed to will have a subscribe_channel
property in its resource response. Subscribing to that channel with the PubNub SDK will start listening for updates to that resource.
Poll Result Updates
Poll widgets have results updates published periodically while they are active. The update is a message delivered over the PubNub channel associated with the widget. It has an event
named "text-poll-results"
for Text Polls, and "image-poll-results"
for Image Polls. The payload is a list of objects containing an ID of an option and its current vote count.
{
"event": "text-poll-results",
"payload": {
"id": "b02f5c9a-f365-44dd-8a9c-8aec9cd84fee",
"kind": "text-poll",
"options": [
{
"id": "579c15f2-4cec-418f-926b-ed2a770e2c1a",
"vote_count": 1
},
{
"id": "9c72e228-906f-4b5d-a649-ec8e93e09028",
"vote_count": 0
}
]
}
}
{
"event": "image-poll-results",
"payload": {
"options": [
{
"id": "579c15f2-4cec-418f-926b-ed2a770e2c1a",
"vote_count": 1
},
{
"id": "9c72e228-906f-4b5d-a649-ec8e93e09028",
"vote_count": 0
}
]
}
}
Quiz Result Updates
Quiz widgets have results updates published periodically while they are active. The update is a message delivered over the PubNub channel associated with the widget. It has an event
named "text-quiz-results"
for Text Quizzes, and "image-quiz-results"
for Image Quizzes. The payload is a list of objects containing an ID of a choice and its current answer count.
{
"event": "text-quiz-results",
"payload": {
"id" "a02f5c9a-f365-44dd-8a9c-8aec9cd84fee",
"kind": "text-quiz",
"choices": [
{
"id": "579c15f2-4cec-418f-926b-ed2a770e2c1a",
"answer_count": 1
},
{
"id": "9c72e228-906f-4b5d-a649-ec8e93e09028",
"answer_count": 0
}
]
}
}
{
"event": "image-quiz-results",
"payload": {
"choices": [
{
"id": "579c15f2-4cec-418f-926b-ed2a770e2c1a",
"answer_count": 1
},
{
"id": "9c72e228-906f-4b5d-a649-ec8e93e09028",
"answer_count": 0
}
]
}
}
Cheer Meter Updates
{
"event": "cheer-meter-results",
"payload": {
"id": "d02f5c9a-f365-44dd-8a9c-8aec9cd84fee",
"kind": "cheer-meter",
"options": [
{
"id": "579c15f2-4cec-418f-926b-ed2a770e2c1a",
"vote_count": 1
},
{
"id": "9c72e228-906f-4b5d-a649-ec8e93e09028",
"vote_count": 0
}
]
}
}
Updated 12 months ago