Signaling API

There is a new release of the Developer Center! If you'd like to check it out, please click  here

Signaling API

Methods

Note

Only the built-in attributes come after an underscore; the custom attributes do not.

Life Cycle

Get an AgoraAPIOnlySignal Instance (getInstance)

This method gets an AgoraAPIOnlySignal instance.

public static AgoraAPIOnlySignal getInstance(Context context, String appId);
Parameter Description
context Context of the Android activity.
appId The App ID provided by Agora. For more information, see Get an App ID .

Destroy the AgoraAPIOnlySignal Instance (destroy)

This method destroys the AgoraAPIOnlySignal instance.

public void destroy();

Set a Callback (callbackSet)

This method sets a callback.

public native void callbackSet(ICallBack handler);
Parameter Description
handler A handler of ICallBack.

Note

Avoid using synchronous or blocking callback operations. Otherwise, the signaling system may crash.

Get a Callback (callbackGet)

This method gets an ICallBack object.

public ICallBack callbackGet();
Return Value Description
ICallBack An object of ICallBack.

Login

Login (login)

Use this method to login Agora’s signaling system. Users must always login before performing any operation.

public void login(String appId,String account,String token,int uid,String deviceID);
  • When login is successful, the onLoginSuccess callback is triggered.
  • When login fails, the onLoginFailed callback is triggered.
  • When the SDK loses connection with the server, the onLogout callback is triggered.
Parameter Description
appId The App ID provided by Agora. For more information, see Get an App ID .
account User ID defined by the client. It can be up to 128 visible characters (space is not allowed). It can be a uid, nickname, guid, and other content that must be unique. The account parameters in this document follow this rule.
token SignalingToken generated by the App ID and App Certificate. See How to Get and Use a SignalingToken for details.
uid N/A: Set it as 0
deviceID Set it as NULL.

Note

You can skip generating the token in a test environment by setting token to _no_need_token. However, Agora does not recommend this in a production environment. By default, if you are already logged in, the call of login() will be ignored. To cancel the previous login, call logout() beforehand without having to wait until it is successfully executed.

Login (login2)

Use this method to login Agora’s signaling system. Users must always login before performing any operation.

public void login2(String appId,String account,String token,int uid,String deviceID, int retry_time_in_s, int retry_count);
  • When login is successful, the onLoginSuccess callback is triggered.
  • When login fails, the onLoginFailed callback is triggered.
  • When the SDK loses connection with the server, the onLogout callback is triggered.
Parameter Description
appId App ID provided by Agora. For more information, see Get an App ID .
account User ID defined by the client. It can be up to 128 visible characters (space is not allowed). It can be a uid, nickname, guid and other content that is unique. The account parameters in this document follow this rule.
token SignalingToken generated by the App ID and App Certificate. See How to Get and Use a SignalingToken for details.
uid N/A: Set it as 0
deviceID Set it as NULL.
retry_time_in_s Maximum time allowed to re-login, 30 seconds by default.
retry_count Maximum times allowed to re-login, 3 times by default.

Note

You can skip generating the token in a test environment by setting token to _no_need_token. However, Agora does not recommend this in a production environment. onLoginFailed will be triggered when either retry_time_in_s or retry_count is reached.

Logout (logout)

This method triggers the onLogout callback upon a successful execution.

public void logout();

Remote Calling Process (invoke)

This method is used for the remote calling process. When called successfully, it will trigger the onInvokeRet callback.

public void invoke(String name, String req, String callID);
Function Parameter Settings and Returns
Query the user status
  • name: io.agora.signal.user_query_user_status
  • req: {“account”:account of the user}
  • Returns: status(1:online; 0:offline)
Set a user attribute
  • name: io.agora.signal.user_set_attr
  • req: {“name”:attribute name,”value”:attribute value}
Get a user attribute
  • name: io.agora.signal.user_get_attr
  • req: {“account”:account of the user,”name”:attribute name}
  • Returns: {“value”:attribute value}
Get all attributes of a user
  • name: io.agora.signal.user_get_attr_all
  • req: {“account”:account of the user}
  • Returns: The JSON value of all attributes
Retrieve the number of the users in a channel
  • name: io.agora.signal.channel_query_num
  • req: {“name”:channel name}
  • Returns: All users in the channel
Check if a user is in a specific channel
  • name: io.agora.signal.channel_query_user_isin
  • req: {“name”:channel name,”account”:account of the user}
  • Returns: isin(1: in the channel; 0:not in the channel)
Get a list of the users in a channel
  • name: io.agora.signal.channel_query_userlist
  • req: {“name”:channel name}
  • Returns: {“num”:number of the users in the channel,”list”:the latest user}
Get a list of the latest users in a channel
  • name: io.agora.signal.channel_query_userlist_all
  • req: {“name”:channel name,”num”:number (by default 1000*1000)}
  • Returns: {“num”:number of the users in the channel,”list”:the latest users}
  • Agora recommends using it on the server. If using it on the client, pay attention to the limit on the usage frequency.
Clear all attributes of a specific channel
  • name: io.agora.signal.channel_clear_attr
  • req: {“channel”:channel name}
Delete an attribute of a specific channel
  • name: io.agora.signal.channel_del_attr
  • req: {“channel”:channel name,”name”:attribute name}
Set an attribute of a specific channel
  • name: io.agora.signal.channel_set_attr
  • req: {“channel”:channel name,”name”:attribute name,”value”:value name}

Query the User Status (queryUserStatus)

This method checks whether a user is online. Calling this method triggers the onQueryUserStatusResult callback.

public void queryUserStatus(String account);
Parameter Description
account Account of the user.

Set a User Attribute (setAttr)

This method sets the user attributes.

public void setAttr(String name,String value);
Parameter Description
name The attribute name, can be up to 128 visible characters. For example, _conn_timeout is the built-in attribute and refers to the offline timeout in seconds. It is set to 120s by default value and ranges between 20s and 120s. The SDK automatically readjusts settings below 20s to 20s and settings exceeding 120s to 120s.
value Attribute value, can be up to 8096 visible characters.

Get Your Specified Attribute (getAttr)

This method gets your specified attribute. It triggers the onUserAttrResult callback when called successfully.

public void getAttr(String name);
Parameter Description
name

Attribute name.

It can be up to 128 visible characters

Get all of Your Attributes (getAttrAll)

This method gets all of your attributes. You will receive the onUserAttrAllResult callback upon a successful execution.

public void getAttrAll();

Get the Attributes of a Specified User (getUserAttr)

This method allows the user to get the attributes of a specified user. The user will receive the onUserAttrResult callback.

public void getUserAttr(String account,String name);
Parameter Description
account User ID defined by the client.
name

Attribute name.

It can be up to 128 visible characters

Get all Attributes of a Specified User (getUserAttrAll)

This method allows the user to get all the attributes of a specified user. The user will receive the onUserAttrAllResult callback upon a successful execution.

public void getUserAttrAll(String account);
Parameter Description
account User ID defined by the client.

Send a Point-to-point Message (messageInstantSend)

This method sends a point-to-point message to a specified user.

Upon successful execution, the user receives the onMessageSendSuccess callback, and the other user receives the onMessageInstantReceive callback.

If execution fails, the user receives the onMessageSendError callback.

public void messageInstantSend(String account,int uid,String msg,String msgID);
Parameter Description
account User ID defined by the client.
uid N/A: Set as 0.
msg Message body. Each message must not exceed 8196 KB visible characters.
msgID Message ID. Agora recommends setting it to “”, allowing the SDK to generate and assign the msgID and to ensure its uniqueness.

The Channel

Join a Channel (channelJoin)

This method allows the users to join a specified channel.

Once the user joins a channel, he/she receives the onChannelJoined callback, and the other users in the same channel receive the onChannelUserJoined callback. If the user fails to join a specified channel, he/she receives an onChannelJoinFailed callback.

public void channelJoin(String channelID);
Parameter Description
channelID

Channel name. It can be up to 128 visible characters and include the following special channel names and attributes:

  • _agora_user_online: All user-online or user-offline events within the current appID will be sent to this channel.
  • _agora_channel_event: All events about a user joining or leaving a channel within the current appID will be sent to this channel.
  • _auto_update_num: Indicates whether to automatically update the number of users currently in the channel. 0: Disabled (default); 1 to n: Refresh interval (s)
  • _member_num: The number of users currently in the channel, which is refreshed by the SDK at an interval set by _auto_update_num. If no user joins or leaves the channel during the time interval set by _auto_update_num, the onChannelAttrUpdated callback will not be triggered. Note that the onChannelAttrUpdated callback will not be triggered each time a user joins or leaves the channel but triggered at the preset interval when the channel user number changes.
  • _auto_update_total_num: Indicates whether to automatically update the total number of users who have joined the channel. 0: Disabled (default); 1 to n: Refresh interval (s)
  • _total_member_num: Indicates the total number of the users who have joined the channel. Different from _member_num, _auto_update_total_num needs to be enabled by setting both _auto_update_num and _auto_update_total_num to a value between 1 to n.

Note

Special channels are used by servers only to receive login and channel events.

Leave a Channel (channelleave)

This method allows users to leave the current channel. Once the user has left the channel, the other users in the channel receive the onChannelUserLeaved callback.

public void channelLeave(String channelID);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

Query the Number of Users in a Channel (channelQueryUserNum)

This method allows a user to query the number of users in a specified channel. Upon a successful execution, the user will receive the onChannelQueryUserNumResult callback.

public void channelQueryUserNum(String channelID);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

Query if a User is in a Channel (channelQueryUserIsIn)

This method queries if a specified user is in a specified channel. It triggers the onChannelQueryUserIsIn callback upon successful execution.

public void channelQueryUserIsIn(String channelID, String account)
Parameter Description
channelID Channel name. Maximum length is 128 visible characters.
account User ID defined by the client.

Set the Channel Attributes (channelSetAttr)

This method sets the channel attributes. Whenever a change is made to the attributes, all users in the channel will receive the onChannelAttrUpdated callback.

public void channelSetAttr(String channelID,String name,String value);
Parameter Description
channelID Channel name, can be up to 128 visible characters.
name Attribute name, can be up to 128 visible characters.
value Attribute value, can be up to 8096 visible characters.

The following table shows the built-in attributes of the parameter, name:

Attributes Description
_userNotification
  • 1: Default value. The channel sends callbacks that a user has joined or left the channel.
  • 0: The channel does not send callbacks that a user has joined or left the channel.
_channel_ttl Time (s) between the last user leaving a channel and the system destroying the channel. The default value is 7200. A special channel will never be destroyed.
_member_num Number of the users currently in the channel. It is automatically updated by the system.
_auto_update_num

Indicates whether to automatically refresh the number of the users currently in the channel.

  • 0: Disabled (default)
  • 1~n: Refreshing frequency (s)

Delete the Channel Attributes (channelDelAttr)

This method deletes the channel attributes. All users in the channel will receive the onChannelAttrUpdated callback, when the method is called successfully.

public void channelDelAttr(String channelID,String name);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

name

Attribute name.

It can be up to 128 visible characters.

Delete all Channel Attributes (channelClearAttr)

This method deletes all attributes of a specified channel. When it is called successfully, all users in the channel will receive the onChannelAttrUpdated callback.

public void channelClearAttr(String channelID);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

Send a Channel Message (messageChannelSend)

This method sends a channel message, and all users in the same channel receive the onMessageChannelReceive callback.

The user who sent the message receives the onMessageSendSuccess callback upon a successful execution; otherwise, receives the onMessageSendError callback.

public void messageChannelSend(String channelID,String msg,String msgID);
Parameter Description
channelID Channel name. It can be up to 128 visible characters.
msg Message body. Each channel message must not exceed 8196 KB visible characters. Each user cannot send more than 60 messages per second, and the entire channel cannot send more than 1,000 messages per second.
msgID Visible characters. Message ID. Agora recommends setting it to “”, allowing the SDK to generate and assign the msgID and to ensure its uniqueness.

Calling

Initiate a Call (channelInviteUser)

This method initiates a call, that is, invites a user to join a specified channel.

Note

Calling and joining a channel are two separate processes. The user has to call channelJoin() to join the channel. The user can either join the channel before sending a call invitation or send a call invitation before joining the channel (when the counterpart accepts the invitation).

If the call fails, the user will receive the onInviteFailed callback. Possible reasons include:

  • The other user is offline;
  • Local network issues;
  • Server errors;

If the caller gets a confirmation from the callee, the caller will receive the onInviteReceivedByPeer callback, and the callee will receive the onInviteReceived callback.

public void channelInviteUser(String channelID,String account,int uid);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

account User ID of the other user defined by the client.
uid N/A. Set as 0.

Initiate a Call (channelInviteUser2)

Same as channelInviteUser except for the parameters.

public void channelInviteUser2(String channelID,String account,String extra);
Parameter Description
channelID Channel name: It can be up to 128 visible characters.
account User ID of the other user defined by the client.
extra

Extra information to send to the user being called. It can be up to 8196 KB visible characters and must be in the JSON format. For example, it may have the following fields:

  • {“_require_peer_online”:1} If the counterpart is offline, the onInviteFailed callback of the ICallBack class will be triggered immediately.
  • {“_require_peer_online”:0} If the counterpart is offline for more than 20 seconds, the onInviteFailed callback of the ICallBack class will be triggered (default).
  • {“destMediaUid” : “YourMediaUid123”} Specify the uid for joining the corresponding media channel.
  • {“srcNum” : “+123456789”} Specify the phone number to be displayed on the screen of the remote phone.

Note

You do not need to set the _require_peer_online field when making a SIP call.

Send a DTMF (Dual-tone Multi-frequency) Message to the Other User (channelInviteDTMF)

This method sends a DTMF message to the other user by calling through the SIP gateway. The receiver will receive the onInviteMsg callback.

public void channelInviteDTMF(String channelID,String phoneNum,String dtmf);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

phoneNum Phone number of the other user.
dtmf Subsequent analog phone number (DTMF) to be entered after the call gets through.

Accept a Call (channelInviteAccept)

This method accepts the received call request/invitation. Once this API is called, the other user will receive the onInviteAcceptedByPeer callback.

public void channelInviteAccept(String channelID,String account,int uid,String extra);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

account The caller’s user ID.
uid

N/A.

Set as 0.

extra

In JSON format. Can be “”.

User-defined information.

Can be used for a SIP call.

Reject a Call (channelInviteRefuse)

This method rejects a call invitation/request. Once this API is called, the other user receives the onInviteRefusedByPeer callback.

public void channelInviteRefuse(String channelID,String account,int uid, String extra);
Parameter Description
channelID Channel name. It can be up to 128 visible characters.
account User ID of the other user defined by the client.
uid N/A: Set as 0.
extra Extra information. It can be up to 8196 KB visible characters and must be in the JSON format.

End a Call (channelInviteEnd)

This method ends a call after the call has been connected. The user receives the onInviteEndByMyself callback, and the other user receives the onInviteEndByPeer callback.

public void channelInviteEnd(String channelID,String account,int uid);
Parameter Description
channelID

Channel name.

It can be up to 128 visible characters.

account User ID of the other user defined by the client.
uid

N/A.

Set as 0.

Miscellaneous

Get the User Status (getStatus)

This method gets the user status.

public int getStatus();
Return Value Description
LOGIN_STATE_NOT_LOGIN 0: The user has not logged in.
LOGIN_STATE_LOGINING 1: The user is logging in.
LOGIN_STATE_LOGINED 2: The user has logged in.
LOGIN_STATE_RECONNECTING 3: The user is reconnecting.

Get the SDK Version (getSdkVersion)

This method gets the version of the SDK.

public int getSdkVersion();
Return Value Description
The SDK version. For example, 1010104019 means version 1.1.4.19.

Send a Channel Message (messageChannelSendForce)

This method sends a channel message without joining the channel. Agora does not recommend using it at the application level.

public native void messageChannelSendForce(String channelID,String msg,String msgID);
Parameter Description
channelID The channel ID.
msg The message to send.
msgID Message ID. Agora recommends setting it to “”, allowing the SDK to generate and assign the msgID and to ensure its uniqueness.

Obsolete Interfaces

Interfaces Prototype
messageDTMFSend public void messageDTMFSend(int uid,String msg,String msgID);
channelInvitePhone public void channelInvitePhone(String channelID,String phoneNum,int uid);
channelInvitePhone2 public void channelInvitePhone2(String channelID,String phoneNum,String sourcesNum);
channelInvitePhone3 public void channelInvitePhone3(String channelID,String phoneNum,String sourcesNum,String extra);
isOnline public int isOnline();

Callbacks

The following callbacks are related to Agora’s signaling system.

Connection Lost Callback (onReconnecting)

This callback is triggered when the connection to Agora’s signaling system is lost after login.

public void onReconnecting(int nretry);
Parameter Description
nretry The current reconnection number.

Error Callback (onError)

This callback returns a detailed description of the error.

public void onError(String name,int ecode,String desc)
Parameter Description
name Error type.
ecode

Error code. For more information, see Error Codes and Warning Codes.

  • GENERAL_E = 1000: General error.
  • GENERAL_E_FAILED = 1001: Operation failed.
  • GENERAL_E_UNKNOWN = 1002: General unknown error.
  • GENERAL_E_NOT_LOGIN = 1003: User not logged in.
  • GENERAL_E_WRONG_PARAM = 1004: Wrong parameter.
  • GENERAL_E_LARGE_PARAM = 1005: Large parameter.
desc Description of the error.

User Status Query Callback (onQueryUserStatusResult)

This callback returns the query result of the user status. It is triggered when queryUserStatus() is called.

public void onQueryUserStatusResult(String name,String status)
Parameter Description
name Account of the user.
status

Status of the user: Whether the user is online.

  • 1: User is online.
  • 0: User is offline.

Connection Recovered Callback (onReconnected)

This callback is triggered when the application is reconnected to Agora’s signaling system. When the reconnection fails, the onLogout callback will be triggered instead.

public void onReconnected(int fd);
Parameter Description
fd Agora internal use only.

User Online Callback (onLoginSuccess)

This callback is triggered when a user is logged into Agora’s signaling system.

public void onLoginSuccess(int uid,int fd);
Parameter Description
uid N/A. Set as 0.
fd Agora internal use only.

User Offline Callback (onLogout)

This callback is triggered when a user is logged out of Agora’s signaling system.

public void onLogout(int ecode);
Parameter Description
ecode Error code

User Login Failed Callback (onLoginFailed)

This callback is triggered when the user fails to login Agora’s signaling system.

public void onLoginFailed(int ecode);
Parameter Description
ecode Error code

Remote Calling Process Succeeded Callback (onInvokeRet)

This callback is triggered when the remote calling process succeeds.

void onInvokeRet(String callID, String err, String resp);
Parameter Description
callID Call ID introduced by invoke()
err Error code
resp Returned JSON value

User Joined Channel Callback (onChannelJoined)

This callback is triggered when a user has joined a channel.

public void onChannelJoined(String channelID);
Parameter Description
channelID Channel name

User Failed to Join Channel Callback (onChannelJoinFailed)

This callback is triggered when a user fails to join a channel.

public void onChannelJoinFailed(String channelID,int ecode);
Parameter Description
channelID Channel name
ecode Error code

User Left Channel Callback (onChannelLeaved)

This callback is triggered when a user has left a channel.

public void onChannelLeaved(String channelID,int ecode);
Parameter Description
channelID Channel name
ecode error code

Other User Joined Channel Callback (onChannelUserJoined)

This callback is triggered when another user joined the channel.

public void onChannelUserJoined(String account,int uid);
Parameter Description
account User ID defined by the client.
uid N/A: Set as 0.

Other User Left Channel Callback (onChannelUserLeaved)

This callback is triggered when another user has left the channel.

public void onChannelUserLeaved(String account,int uid);
Parameter Description
account User ID defined by the client.
uid N/A: Set as 0.

User List Callback (onChannelUserList)

A user will receive this callback when he/she has joined a channel.

Note

The retrieved user list includes a maximum of 200 users.

public void onChannelUserList(String[] accounts, int[] uids);
Parameter Description
account User ID defined by the client.
uids List of users in the channel.

Number of Users Callback (onChannelQueryUserNumResult)

This callback is triggered when a user queries the number of users in a channel.

public void onChannelQueryUserNumResult(String channelID,int ecode,int num);
Parameter Description
channelID Channel name
ecode Error code
num The query result

Query Whether a User is in a Channel Status Callback (onChannelQueryUserIsIn)

This callback is triggered when a user queries whether he/she is in the channel.

public virtual void onChannelQueryUserIsIn(std::string channelID, std::string account, int isIn){}
Parameter Description
channelID Channel name.
account User ID defined by the client.
isIn

Whether the user is in the channel:

  • 1: In the channel
  • 0: Not in the channel

Channel Attribute Changed Callback (onChannelAttrUpdated)

This callback is triggered when the channel attribute is changed.

public void onChannelAttrUpdated(String channelID,String name,String value,String type);
Parameter Description
channelID Channel name.
name Attribute name.
value Attribute value.
type

Change types:

  • “update”: Update
  • “del”: Delete
  • “clear”: Delete all
  • “set”: N/A

Call Invitation Received Callback (onInviteReceived)

This callback is received by the callee when the callee has received a call invitation/request.

public void onInviteReceived(String channelID,String account,int uid,String extra);
Parameter Description
channelID Channel name.
account User ID of the other user defined by the client.
uid N/A: Set as 0.
extra Extra information to send to the user being called. It can be up to 8196 KB visible characters and must be in the JSON format.

Callee Received Call Callback (onInviteReceivedByPeer)

This callback is received by the caller when the callee has received the call invitation/request.

public void onInviteReceivedByPeer(String channelID,String account,int uid);
Parameter Description
channelID Channel name
account User ID of the callee defined by the client.
uid N/A

Callee Accepted Call Callback (onInviteAcceptedByPeer)

This callback is received by the caller when the callee has accepted the call invitation/request.

public void onInviteAcceptedByPeer(String channelID,String account,int uid, String extra);
Parameter Description
channelID Channel name
account User ID of the callee defined by the client.
uid N/A
extra

Extra information the caller wants to send to the callee.

For example, this is a video call or voice call.

It must be in JSON format.

Callee Rejected Call Callback (onInviteRefusedByPeer)

This callback is received by the caller when the callee rejects the call invitation/request.

public void onInviteRefusedByPeer(String channelID,String account,int uid, String extra);
Parameter Description
channelID Channel name.
account User ID of the callee defined by the client.
uid N/A: Set as 0.
extra Extra information: NULL or in JSON format.

Call Failed Callback (onInviteFailed)

This callback is triggered when a call fails.

public void onInviteFailed(String channelID,String account,int uid,int ecode, String extra);
Parameter Description
channelID Channel name
account User ID of the other user defined by the client.
uid N/A
extra Extra information: NULL or in JSON format.

Other User Ended Call Callback (onInviteEndByPeer)

This callback is triggered when the callee ends the call.

public void onInviteEndByPeer(String channelID,String account,int uid, String extra);
Parameter Description
channelID Channel name.
account User ID of the callee defined by the client.
msg Message body
extra

Extra information the caller wants to send to the callee.

For example, this is a video call or voice call.

It must be in JSON format.

Call Ended Callback (onInviteEndByMyself)

This callback is received by the user when the other user ends the call.

public void onInviteEndByMyself(String channelID,String account,int uid);
Parameter Description
channelID Channel name.
account User ID of the user defined by the client.
uid N/A.

Message Received Callback (onInviteMsg)

This callback is triggered when you have received a DTMF message sent from the other user.

public void onInviteMsg(String channelID, String account, int uid, String msgType, String msgData, String extra)
Parameter Description
channelID Channel name. It can be up to 128 visible characters.
account User ID of the other user defined by the client.
uid N/A.
msgType Message type (DTMF).
msgData Detailed DTMF message. Supported strings include: 0-9, * and #.
extra Extra information of the call, which can be a string, a JSON string, or NULL.

Message Failed Callback (onMessageSendError)

This callback is triggered when a user fails to send a message.

public void onMessageSendError(String messageID,int ecode);
Parameter Description
messageID Message ID
ecode Error code

Message Sent Callback (onMessageSendSuccess)

This callback is triggered when a user sent a message successfully.

public void onMessageSendSuccess(String messageID);
Parameter Description
messageID Message ID

Message Received Callback (onMessageInstantReceive)

This callback notifies a user that he/she has received a message.

public void onMessageInstantReceive(String account,int uid,String msg);
Parameter Description
account User ID defined by the client
uid N/A
msg Message body

Channel Message Received Callback (onMessageChannelReceive)

This callback is triggered when a channel message is received.

public void onMessageChannelReceive(String channelID,String account,int uid,String msg);
Parameter Description
channelID Channel name
account User ID defined by the client
uid N/A
msg Message body

Log Printed Callback (onLog)

This callback is triggered when a line is printed in a log file.

public void onLog(String txt);
Parameter Description
txt Line in the log file

Attribute Received Callback (onUserAttrResult)

This callback is triggered when the user queries an attribute of a specific user.

public void onUserAttrResult(String account,String name,String value);
Parameter Description
account User ID defined by the client.
name Attribute name.
value Value of the attribute.

All Attribute Received Callback (onUserAttrAllResult)

This callback is triggered when the user queries all attributes of a specified user.

public void onUserAttrAllResult(String account,String value);
Parameter Description
account User ID defined by the client.
value JSON values of all attributes of the user.
Is this page helpful?