PubSub - Android
PubSub is a short acronym for Publish-Subscribe mechanism. This mechanism is used to send and recieve messages from a particular topic. As the name suggests, for someone to send a message, they have to specify the topic and the message which should be published and for someone to receive a message, they should be subscribed to that topic.
Here is a visual to better understand publish-subscribe mechanism.
pubSub​
In order to use PubSub in meeting, VideoSDK provides a class pubSub
which allows you to subscribe to any topic and publish to any topic allowing to pass on messages and instructions during the meeting easily.
publish()
​
- This method is used for publishing message of specific topic.
- This method can be accessed from the
pubSub
class, which is subclass ofMeeting
class. - This method will accept following parameters as input:
topic
: This will be the topic for which you are publishing a message.message
: This will be the actual message to be published. It has to be inString
format.options
: This is an object ofPubSubPublishOptions
which specifies the options for publish.PubSubPublishOptions
has 2 properties.persist
:persist
offered the option of keeping the message around for the duration of the session. Whenpersist
is set totrue
, that message will be retained for upcoming participants and will be available in VideoSDK Session Dashboard with.CSV
format after completion of session.sendOnly
: If you want to send a message to specific participants, you can pass their respectiveparticipantId
in form ofString[]
. If you don't provide any IDs or pass anull
value, the message will be sent to all participants by default. This is optional parameter.
payload
: If you need to include additional information along with a message, you can pass here asJSONObject
. This is optional parameter.
- Kotlin
- Java
private fun sendMessage() {
// publish message
val options = PubSubPublishOptions()
options.isPersist = true
meeting!!.pubSub.publish("CHAT", "Hello Everyone!", options)
}
protected void sendMessage() {
// publish message
PubSubPublishOptions options = new PubSubPublishOptions();
options.setPersist(true);
meeting.pubSub.publish("CHAT", "Hello Everyone!", options);
}
subscribe()
​
-
This method is used to subscribe for particular topic.
-
This method will accept two parameters as input:
topic
: This will be the topic to be subscribed.listener
: This is an object ofPubSubMessageListener
, which listens for upcoming messages and callsonMessageReceived
function, when new message received.
-
This method will return
List<PubSubMessage>
which is a list of messages which were sent earlier.
The object of PubSubMessage
contains following properties:
senderId
: This represents theparticipantId
of the participant who send the message.senderName
: This represents thedisplayName
of the participant who send the message.message
: This will be the actual message that was send.timestamp
: This wil the timestamp for when the message was published.topic
: This will be the name of the topic message was published to.payload
: This will be the data that you have send with message.
- Kotlin
- Java
var pubSubMessageListener =
PubSubMessageListener { message ->
// New message
Log.v("New Message Received", message.senderName + " says : " + message.message)
}
@Override
protected void onCreate(Bundle savedInstanceState) {
//...
// Subscribe for 'CHAT' topic
val pubSubMessageList = meeting!!.pubSub.subscribe("CHAT", pubSubMessageListener)
// Persisted message list
for (message in pubSubMessageList) {
Log.v("Message List: ", message.senderName + " says : " + message.message)
}
}
PubSubMessageListener pubSubMessageListener = new PubSubMessageListener() {
@Override
public void onMessageReceived(PubSubMessage message) {
// New message
Log.v("New Message Received", message.senderName + " says : " + message.getMessage());
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
//...
// Subscribe for 'CHAT' topic
List<PubSubMessage> pubSubMessageList = meeting.pubSub.subscribe("CHAT",pubSubMessageListener);
// Persisted message list
for(PubSubMessage message : pubSubMessageList){
Log.v("Message List: ", message.senderName + " says : " + message.getMessage());
}
}
unsubscribe()
​
-
This method is used to unsubscribe for particular topic.
-
This method will accept two parameters as input:
topic
: This will be the topic to be unsubscribed.listener
: This is an object ofPubSubMessageListener
, which was passed insubscribe()
.
- Kotlin
- Java
fun unsubscribe() {
// Unsubscribe 'CHAT' topic
meeting!!.pubSub.unsubscribe("CHAT", pubSubMessageListener)
}
public void unsubscribe(){
// Unsubscribe 'CHAT' topic
meeting.pubSub.unsubscribe("CHAT", pubSubMessageListener);
}
Applications of usePubSub​
PubSub is a very powerful mechanism which can be used to do alot of things which can make your meeting experience much more interactive. Some of the most common usecase that we have come across for the PubSub during a meeting are listed below:
Chat
: You can utilise this to develop various Chat features, such as Private Chat and Group Chat. You can follow our chat integration guide here.Raise Hand
: You can allow attendees to raise their hands at any time during the meeting, informing everyone else that someone has done so.Poll
: You may make polls, let users respond to them, and display the results at the end of a poll.Question Answer Session
: You can also design interactive functionality that is question-and-answer based.
Downloading PubSub Messages​
All the messages from the PubSub which were published with persist : true
and can be downloaded as an .csv
file. This file will be available in the VideoSDK dashboard as well as throught the Sessions API.
API Reference​
The API references for all the methods and events utilised in this guide are provided below.
Got a Question? Ask us on discord