Methods
0.7.0#
Constructor#
class SyncStage implements ISyncStage{
    constructor(
        userDelegate: ISyncStageUserDelegate | null,
        connectivityDelegate: ISyncStageConnectivityDelegate | null,
        discoveryDelegate: ISyncStageDiscoveryDelegate | null,
        desktopAgentDelegate: ISyncStageDesktopAgentDelegate | null,
        onTokenExpired: (() => Promise<string>) | null,
    );
}
Constructor parameters:
- 
userDelegate- delegate object to receive events about users in session state
- 
connectivityDelegate- delegate object to receive events with information about stream connection to Studio Server state
- 
desktopAgentDelegate- delegate object to receive events with information of desktop agent acquisition and release to prevent users from using SyncStage in multiple browser tabs at once
- 
onTokenExpired- callback to be called whenjwtexpires, callback should return new refetchedjwt
Check compatibility#
Checks if SyncStage SDK is compatible with currently installed Desktop Agent
Parameters:
- currentOS- operating system should be provided. Accepted values from list:- ['Windows', 'macOS']
Get latest Compatible Desktop Agent version#
Parameters:
- currentOS- operating system should be provided. Accepted values from list:- ['Windows', 'macOS']
Initialize#
Initializes and provisions the SDK SyncStage object.
Parameters:
- jwt- token obtained in the provisioning process.
Check if SyncStage Agent is provisioned#
Returns if Desktop Agent has been already provisioned.
Update JWT#
You can update JWT anytime you want, even before expiration takes place.
- jwt- token obtained in the provisioning process.
Get is desktop agent connected#
Checks if desktop agent is running and available on the localhost.
Get SDK version#
Gets SDK version.
Gets autoselected Studio Server#
Get autoselected server instance info
Get best available Studio Server#
Get best available server, where a session can be created
Update SDK to SyncStage backend connected callback#
Parameters:
- onDesktopAgentReconnected- method to be called when the browser SDK reconnects to Desktop Agent. Session state should be refetched and synchronized on the UI in this callback.
Get server instances#
Get server instances so you can select the server that is suitable for your session.
Create a session#
Creates a session in a given zone by a given user from your user pool.
async createSession(
    userId: string,
    zoneId?: string | null,
    studioServerId?: string | null,
  ): Promise<[ISessionIdentifier | null, SyncStageSDKErrorCode]>
Parameters:
- zoneId- zone in which your session is hosted
- studioServerId- studio server where you are running your session
- userId- id of your app user to match the data between SyncStage and your backend
Join the session#
Joins a particular session identified by sessionCode.
async join(
    sessionCode: string,
    userId: string,
    displayName?: string | null,
    zoneId?: string | null,
    studioServerId?: string | null,
  ): Promise<[ISession | null, SyncStageSDKErrorCode]>;
Parameters:
- 
sessionCode- the session code
- 
userId- id of your app user to match de data between SyncStage and your backend
- 
zoneId- zone in which your session is hosted
- 
studioServerId- studio server where you are running your session
- 
displayName- your app user display name
Get session state#
Gets state of currently joined session.
Leave the session#
Leaves currently joined session.
Mute / unmute microphone#
Enables or disables microphone stream.
Parameters:
- mute- desired state of the mute option
Is muted#
Returns state of microphone stream.
Get receiver network measurements#
Returns Measurements object with network delay, jitter, and calculated network quality indicators.
async getReceiverMeasurements(identifier: string): Promise<[IMeasurements | null, SyncStageSDKErrorCode]>
Parameters:
- identifier- receiver's identifier
Get transmitter network measurements#
Returns Measurements object with network delay, jitter, and calculated network quality indicators.
Start recording#
Stop recording#
Get Session Settings#
Gets session settings.
Set Input Device#
Sets input device.
- identifier- device identifier
Set Output Device#
Sets output device.
- identifier- device identifier
Set Noise Cancellation#
Sets noise cancellation.
Set Disable Gain#
Sets disable gain.
- disabled- boolean value
Set Direct Monitor#
Sets direct monitor.
- enabled- boolean value
Set Latency Optimization Level#
Sets latency optimization level.
- level- latency optimization level
Register Desktop Agent Reconnected Callback#
In case of reconnection UI application should be aware of this fact, to refetch the session state to keep it synchronized.
Parameters:
- onWebsocketReconnected- callback
Unregister Desktop Agent Reconnected Callback#
Remove the callback in the SyncStage.