Class: OT

The first step in using the OpenTok API is to call the OT.initSession() method. Other methods of the OT object check for system requirements and set up error logging.

Methods

Name Description
(static) addEventListener(type, listener) This method is deprecated.
(static) checkScreenSharingCapability(callback) Checks for support for publishing screen-sharing streams on the client browser.
(static) checkSystemRequirements() → {Number} Checks if the system supports OpenTok for WebRTC.
(static) getActiveAudioOutputDevice() Returns a Promise that resolves the current audio output device.
(static) getAudioOutputDevices() Enumerates the audio output devices (such as speakers) available to the browser.
(static) getDevices(callback) Enumerates the audio input devices (such as microphones) and video input devices (cameras) available to the browser.
(static) getSupportedCodecs() → {Promise} Gets the list of supported codecs for encoding and decoding video streams.
(static) getUserMedia(options) → {Promise} Gets a MediaStream object that uses a microphone and camera as the audio and video source.
(static) hasEndToEndEncryptionSupport() → {Boolean} Whether the client supports end-to-end encryption.
(static) hasMediaProcessorSupport() → {Boolean} Whether the client supports media processors, like video and audio filters.
(static) initPublisher(targetElement, properties, completionHandler) → {Publisher}

Initializes and returns a Publisher object.

(static) initSession(apiKey, sessionId, options) → {Session}

Initializes and returns the local session object for a specified session ID.

(static) log(message) Sends a string to the debugger console.
(static) off(type, handler, context) Removes an event handler.
(static) on(type, handler, context) Adds an event handler function for one or more events.
(static) once(type, handler, context) Adds an event handler function for an event.
(static) registerScreenSharingExtension(kind, id, version) Register an extension for screen-sharing support in an older version of Chrome or Opera.
(static) removeEventListener(type, listener) This method is deprecated.
(static) reportIssue(completionHandler) Report that your app experienced an issue.
(static) setAudioOutputDevice() → {Promise} Sets the new audio output device.
(static) setLogLevel(logLevel) Sets the API log level.
(static) setProxyUrl() Sets the URL of the IP proxy server.
(static) unblockAudio() Causes subscribers' audio to play back in browsers where audio is blocked.
(static) upgradeSystemRequirements() Displays information about system requirements for OpenTok for WebRTC.

(static) addEventListener(type, listener)

This method is deprecated. Use on() or once() instead.

Registers a method as an event listener for a specific event.

The OT object dispatches one type of event — an exception event. The following code adds an event listener for the exception event:

OT.addEventListener("exception", exceptionHandler);

function exceptionHandler(event) {
   alert("exception event. \n  code == " + event.code + "\n  message == " + event.message);
}

If a handler is not registered for an event, the event is ignored locally. If the event listener function does not exist, the event is ignored locally.

Throws an exception if the listener name is invalid.

Parameters:
Name Type Description
type String The string identifying the type of event.
listener function The function to be invoked when the OT object dispatches the event.
See:

(static) checkScreenSharingCapability(callback)

Checks for support for publishing screen-sharing streams on the client browser. The object passed to the callback function defines whether screen sharing is supported, as well as which screen-sharing sources (application, screen, or window) are supported. It also indicates whether an extension is required, installed, and registered (if needed).

OT.checkScreenSharingCapability(function(response) {
  if (!response.supported || response.extensionRegistered === false) {
    // This browser does not support screen sharing
  } else if (response.extensionInstalled === false) {
    // Prompt to install the extension
  } else {
    // Screen sharing is available.
  }
});

Chrome 72+, Firefox 52+, Safari 13+, Edge 79+, and Opera 59+ have screen-sharing support built-in, with no extension required. (Note that support for the OpenTok plugin for Internet Explorer is removed in OpenTok 2.17.) Screen sharing is not supported in mobile browsers. In Electron, screen sharing is supported if the webPreferences.contextIsolation option of the Electron BrowserWindow is set to false or if the app uses a preload script to access the desktop capturer. (The default value of webPreferences.contextIsolation option is true in Electron 12 and false in previous versions). To publish a screen-sharing video in older versions of Chrome or Opera, the client adds an extension that enables publishing a screen-sharing video stream on your domain. The OpenTok screensharing-extensions sample includes code for creating an extension for screen-sharing support in older versions of Chrome and Opera.

For more information, see the OpenTok Screen Sharing developer guide.

Parameters:
Name Type Description
callback function The callback invoked with the support options object passed as the parameter. This object has the following properties that indicate support for publishing screen-sharing streams in the client:

  • extensionInstalled (Boolean) — In older versions of Chrome and Opera, this is set to true if the extension is installed and registered. In Chrome 72+, Firefox 52+, Safari 13+, Opera 59+, Edge 79+, and Internet Explorer, this property is undefined.
  • supported (Boolean) — Set to true if screen sharing is supported in the browser. Check the extensionRequired property to see if the browser requires an extension for screen sharing.
  • supportedSources (Object) — Deprecated. In older browser versions, you could select a type of screen-sharing source (such as "application", "browser", "screen", or "window" by setting the videoSource property of the options passed into the OT.initPublisher() method. However, in current browsers that support screen sharing, passing in any of these values results in the same behavior — the browser displays a dialog box in which the end user selects the screen-sharing source (which can be the entire screen or a specific window). In Electron, screen sharing captures the entire screen, without prompting the user for permission.

The options parameter also includes the following properties, which apply to screen-sharing support in older versions of Chrome and Opera (in all other browsers these properties are undefined):

  • extensionRequired (String) — Set to "chrome" in older versions of Chrome and Opera, which require a screen-sharing extension to be installed. This property is undefined in other browsers.
  • extensionRegistered (Boolean) — In older versions of Chrome and Opera, this property is set to true if a screen-sharing extension is registered; otherwise it is set to false. In other browsers (which do not require an extension), this property is undefined. Use the OT.registerScreenSharingExtension() method to register a screen-sharing extension in older versions of Chrome or Opera.
See:

(static) checkSystemRequirements() → {Number}

Checks if the system supports OpenTok for WebRTC. Note that this method is called automatically when you call OT.initPublisher() or OT.initSession(), and if the system doesn't support OpenTok, the OpenTok.js library displays a message to the user. Call the OT.checkSystemRequirements() method before calling OT.initPublisher() or OT.initSession() if you do not want the library to display that message.
See:
Returns:
Whether the system supports OpenTok for WebRTC (1) or not (0).

(static) getActiveAudioOutputDevice()

Returns a Promise that resolves the current audio output device.

The method returns a Promise which resolves an object that has two properties: deviceId and label, each of which are strings.

The deviceId property is a unique ID for the device. You can pass the deviceId as the parameter of the OT.setAudioOutputDevice() method. The deviceId property is set to undefined if the user has not previously granted access to a camera and microphone.

The label property identifies the device. The label property is set to an empty string if the user has not previously granted access to a camera and microphone.

Note: Current browser support is for desktop versions of Chrome 49+, Edge 17+, and Opera 36+.

See:

(static) getAudioOutputDevices()

Enumerates the audio output devices (such as speakers) available to the browser.

The method returns a Promise which resolves an array of objects corresponding to available audio output devices. Each object has two properties: deviceId and label, each of which are strings.

The deviceId property is a unique ID for the device. You can pass the deviceId as the parameter of the OT.setAudioOutputDevice() method. The deviceId property is set to undefined if the user has not previously granted access to a camera and microphone. In the case there are no audio output devices available, the property is set to `null`.

The label property identifies the device. The label property is set to an empty string if the user has not previously granted access to a camera and microphone.

Notes::

  • Current browser support is for desktop versions of Chrome 49+, Edge 17+, and Opera 36+.
  • The browser may limit the number of returned audio output devices to one before the user has granted access to a camera or microphone.

See:

(static) getDevices(callback)

Enumerates the audio input devices (such as microphones) and video input devices (cameras) available to the browser.

The array of devices is passed in as the devices parameter of the callback function passed into the method.

Parameters:
Name Type Description
callback function The callback function invoked when the list of devices devices is available. This function takes two parameters:
  • error — This is set to an error object when there is an error in calling this method; it is set to null when the call succeeds.
  • devices — An array of objects corresponding to available microphones and cameras. Each object has three properties: kind, deviceId, and label, each of which are strings.

    The kind property is set to "audioInput" for audio input devices or "videoInput" for video input devices.

    The deviceId property is a unique ID for the device. You can pass the deviceId in as the audioSource or videoSource property of the options parameter of the OT.initPublisher() method.

    The label property identifies the device. The label property is set to an empty string if the user has not previously granted access to a camera and microphone.

Note: The browser may limit the number of returned audio and video input devices to one each before the user has granted access to a camera or microphone.
See:

(static) getSupportedCodecs() → {Promise}

Gets the list of supported codecs for encoding and decoding video streams.

The following example gets the list of supported codecs for encoding and decoding video streams:

(async () => {
  try {
    const supportedCodecs = await OT.getSupportedCodecs();
    if (supportedCodecs.videoEncoders.indexOf('H264') < 0 &&
        supportedCodecs.videoDecoders.indexOf('H264') < 0) {
      // The client does not support encoding or decoding H264.
      // Let's recommend using a different browser.
    }
  } catch(err) {
    console.log(err);
  }
})();

You can use the lists of supported video codecs to determine whether the client supports video, depending on the preferred video codec and the type of session being used. You can set the preferred video codec on the Project page of your Vonage Video API account. In routed sessions (sessions that use the OpenTok Media Router), the preferred video codec is used for all clients in the session. In relayed sessions, clients send streams directly to one another, and each publishing-subscribing pair tries to find a common video codec that they can both use. In this regard, the video codec used by the pair in a relayed session may be different from the preferred video codec setting. For more information see the OpenTok Video codecs developer guide.

Returns:
A promise that is resolved when the list of supported codecs is ready. The promise is resolved (on success) with an object that has two properties: videoDecoders, an array of supported video codecs for decoding, and videoEncoders, an array of supported video codecs for encoding, such as:
{
   videoDecoders: ['H264', 'VP8', 'VP9'],
   videoEncoders: ['H264', 'VP8', 'VP9']
}

The promise is rejected if there is an error in getting the list.

(static) getUserMedia(options) → {Promise}

Gets a MediaStream object that uses a microphone and camera as the audio and video source. This method returns a promise that is resolved when the user has granted permission to use the camera or microphone (or both) and the MediaStream object is available. The promise is rejected if there is an error in getting the media or if the end user denies access to the camera or microphone.

You can use this method to get MediaStreamTrack objects to pass into the audioSource and videoSource options of the OT.initPublisher() method. For example, call this method to get a MediaStream that uses the microphone and camera as the audio and video sources. Then you can call getVideoTracks()[0] on the MediaStream object to get a video MediaStreamTrack object for the camera's video. You can then add the video MediaStreamTrack as a source for an HTML Video element, draw that Video element into an HTML Canvas element, and apply video filters or effects to the Canvas. Then you can call the captureStream() method of the HTMLCanvasElement object to get a MediaStream object and call getVideoTracks()[0] on the MediaStream object to get a video MediaStreamTrack object (with the video filters or effects applied). Finally, you can use the video MediaStreamTrack object as the videoSource property of the options you pass into OT.initPublisher(). The OpenTok Publisher will use the video track (with the filters and effects applied) as the video source.

Parameters:
Name Type Description
options Object

(optional) Defines settings for the MediaStream object. The options are the same as those defined for the OT.initPublisher() method. However, only the following properties apply for OT.getUserMedia():

  • audioSource
  • autoGainControl
  • disableAudioProcessing
  • echoCancellation
  • enableStereo
  • facingMode
  • frameRate
  • maxResolution
  • noiseSuppression
  • resolution
  • videoSource

See:
Returns:
A promise that is resolved when the user has granted permission to use the camera or microphone (or both) and the MediaStream object is available. The promise is rejected if there is an error in getting the media, if the end user denies access to the camera or microphone, or if the method is called on Internet Explorer.

(static) hasEndToEndEncryptionSupport() → {Boolean}

Whether the client supports end-to-end encryption.

The following example enables the end-to-end encryption, if supported by the client:

// Publish in a session with end-to-end encryption, if supported
if (OT.hasEndToEndEncryptionSupport()) {
  session.publish(publisher, error) = {
    ...
  });
}
See:
Returns:
Whether the client supports end-to-end encryption (true), or not (false).

(static) hasMediaProcessorSupport() → {Boolean}

Whether the client supports media processors, like video and audio filters.

The following example enables the background blur filter, if supported by the client:

// Add background blur, if supported
if (OT.hasMediaProcessorSupport()) {
  publisherOptions.videoFilter = {
    type: 'backgroundBlur',
  };
}
// Add advanced noise suppression, if supported
if (OT.hasMediaProcessorSupport()) {
  publisherOptions.audioFilter = {
    type: 'advancedNoiseSuppression',
  };
}

const publisher = OT.initPublisher(publisherOptions);
See:
Returns:
Whether the client supports media processors (true), like video and audio filters, or not (false).

(static) initPublisher(targetElement, properties, completionHandler) → {Publisher}

Initializes and returns a Publisher object. You can then pass this Publisher object to Session.publish() to publish a stream to a session.

Note: If you intend to reuse a Publisher object to publish to different sessions (or the same session) sequentially, add an event listener for the streamDestroyed event dispatched by the Publisher object (when it stops publishing). In the event listener, call the preventDefault() method of the event object to prevent the Publisher's video from being removed from the page.

Parameters:
Name Type Description
targetElement Object (Optional) The DOM element or the id attribute of the existing DOM element used to determine the location of the Publisher video in the HTML DOM. See the insertMode property of the properties parameter. If you do not specify a targetElement, the application appends a new DOM element to the HTML body.

The application throws an error if an element with an ID set to the targetElement value does not exist in the HTML DOM.

properties Object (Optional) This object contains the following properties (each of which are optional):

  • audioBitrate (Number) — The desired bitrate for the published audio, in bits per second. The supported range of values is 6,000 - 510,000. (Invalid values are ignored.) Set this value to enable high-quality audio (or to reduce bandwidth usage with lower-quality audio).

    The following are recommended settings:

    • 8,000 - 12,000 for narrowband (NB) speech
    • 16,000 - 20,000 for wideband (WB) speech
    • 28,000 - 40,000 for full-band (FB) speech
    • 48,000 - 64,000 for full-band (FB) music

    The default value is 40,000.

    Currently, this setting is not supported in streams published in Firefox.

  • audioFallback (Object) — An object containing properties that defines whether the stream will use the audio-fallback feature. The audioFallback object includes the following properties:
    • publisher (Boolean) — Whether the stream will use the publisher audio-fallback feature (true) or not (default false). The publisher audio-fallback feature is available in both routed sessions (sessions that uses the OpenTok Media Router) and relayed sessions. With the publisher audio-fallback feature enabled, when it is determined that a Publisher's quality has degraded significantly, it disables the video in that publisher in order to preserve audio quality. For more information, see the Publisher videoDisabled, videoDisableWarning, videoDisableWarningLifted, and videoEnabled events.

      This is a beta feature.

    • subscriber (Boolean) — Whether the stream will use the subscriber audio-fallback feature (true) or not (false). The audio-fallback feature is available in sessions that use the OpenTok Media Router. With the audio-fallback feature enabled (the default), when the server determines that a stream's quality has degraded significantly for a specific subscriber, it disables the video in that subscriber in order to preserve audio quality. For streams that use a camera as a video source, the default setting is true (the audio-fallback feature is enabled). The default setting is false (the audio-fallback feature is disabled) for screen-sharing streams, which have the videoSource property set to "application", "screen", or "window" in the OT.initPublisher() options. For more information, see the Subscriber videoDisabled event and the OpenTok Media Router and media modes.
  • audioFallbackEnabled (Boolean) — Whether the stream will use the audio-fallback feature (true) or not (false). The audio-fallback feature is available in sessions that use the OpenTok Media Router. With the audio-fallback feature enabled (the default), when the server determines that a stream's quality has degraded significantly for a specific subscriber, it disables the video in that subscriber in order to preserve audio quality. For streams that use a camera as a video source, the default setting is true (the audio-fallback feature is enabled). The default setting is false (the audio-fallback feature is disabled) for screen-sharing streams, which have the videoSource property set to "application", "screen", or "window" in the OT.initPublisher() options. For more information, see the Subscriber videoDisabled event and the OpenTok Media Router and media modes.

    Note that this property will be deprecated in the future. Use the audioFallback parameter instead.

  • audioFilter (Object) — An object containing properties that define the audio filter to be applied to the Publisher's audio stream. The following filters are supported:
    • Advanced noise suppression filter — Set the type property of the object to "advancedNoiseSuppression".

    Note: Audio filters are only supported in recent versions of Chrome, Electron, Opera, and Edge. They are not supported in other (non-Chromium-based) browsers or on iOS. You can check if the client supports this feature by calling the OT.hasMediaProcessorSupport() method.

    You can change the audio filter by calling the Publisher.applyAudioFilter() method. You can remove the audio filter by calling the Publisher.clearAudioFilter() method.

  • audioSource (String, MediaStreamTrack, Boolean, or null) — The ID of the audio input device (such as a microphone) to be used by the publisher. You can obtain a list of available devices, including audio input devices, by calling the OT.getDevices() method. Each device listed by the method has a unique device ID. If you pass in a device ID that does not match an existing audio input device, the call to OT.initPublisher() fails with an error (error code 1500, "Unable to Publish") passed to the completion handler function.

    If you set this property to null or false, the browser does not request access to the microphone, and no audio is published.

    You can also set this property to an audio MediaStreamTrack object. This lets you use the object as the audio source for the published stream. For example, you can get an array of audio MediaStreamTrack objects from the audioTracks property of an HTMLMediaElement object. Or you can call the getLocalStreams() or getRemoteStreams() method of an RTCPeerConnection object to get an array of MediaStream objects, and then call the getAudioTracks() method of one of the MediaStream objects to get an audio MediaStreamTrack object.

  • autoGainControl (Boolean) — Whether to enable automatic gain control for the published audio. You may want to set this to false when publishing high-quality audio (by setting the audioBitrate property of the OT.initPublisher() options). The default value is true. This setting is ignored if you set disableAudioProcessing to true (which disables echo cancellation, automatic gain control, and noise suppression for the published stream).
  • disableAudioInputDeviceManagement (Boolean) — Whether to disable automatic audio input device switching. You may want to set this to true if you want to handle the device management by yourself. Note: This is an advanced feature. Do not use without first implementing device management for your application. If you enable this, the audio input device used by the SDK will not be updated when the end user changes their microphone. The default value is false.
  • disableAudioProcessing (Boolean) — Whether to disable echo cancellation, automatic gain control, and noise suppression for the published audio. You may want to set this to true when publishing high-quality audio (by setting the audioBitrate property of the OT.initPublisher() options). The default value is false.
  • echoCancellation (Boolean) — Whether to enable echo cancellation for the published audio. You may want to set this to false when publishing high-quality audio (by setting the audioBitrate property of the OT.initPublisher() options). The default value is true. This setting is ignored if you set disableAudioProcessing to true (which disables echo cancellation, automatic gain control, and noise suppression for the published stream).
  • enableStereo (Boolean) — Whether to publish stereo audio. The default value is false.

    Note: Some browsers (such as Chome 73+) do not support echo cancellation for stereo audio (see this Chrome issue report).

  • enableDtx (Boolean) — Whether to enable Opus DTX. The default value is false. Setting this to true can reduce bandwidth usage in streams that have long periods of silence.
  • facingMode (String) — The preferred camera position to use for the video source. Generally, this setting only applies to mobile devices. This can be set to one of the following values:

    • "user" — The front-facing camera.
    • "environment" — The back camera.
    • "left" — The camera facing the user but to the left (uncommon).
    • "right" — The camera facing the user but to the right (uncommon).

  • fitMode (String) — Determines how the video is displayed if the its dimensions do not match those of the DOM element. You can set this property to one of the following values:

    • "cover" — The video is cropped if its dimensions do not match those of the DOM element. This is the default setting for videos publishing a camera feed.
    • "contain" — The video is letterboxed if its dimensions do not match those of the DOM element. This is the default setting for screen-sharing videos.
  • frameRate (Number) — The desired frame rate, in frames per second, of the video. Valid values are 30, 15, 7, and 1. The published stream will use the closest value supported on the publishing client. The frame rate can differ slightly from the value you set, depending on the browser of the client. And the video will only use the desired frame rate if the client configuration supports it.

    If the publisher specifies a frame rate, the actual frame rate of the video stream is set as the frameRate property of the Stream object, though the actual frame rate will vary based on changing network and system conditions. If the developer does not specify a frame rate, this property is undefined. Also, if the video source is a video MediaStreamTrack object (see the videoSource), this value is ignored and the frame rate is defined by the MediaStreamTrack object, which you can get by calling the getConstraints() method of the MediaStreamTrack object.

    For sessions that use the OpenTok Media Router (sessions with the media mode set to routed, lowering the frame rate proportionally reduces the maximum bandwidth the stream uses. However, in sessions with the media mode set to relayed, lowering the frame rate does not reduce the stream's bandwidth.

    You can also restrict the frame rate of a Subscriber's video stream. To restrict the frame rate a Subscriber, call the restrictFrameRate() method of the subscriber, passing in true. (See Subscriber.restrictFrameRate().)

  • height (Number or String) — The desired initial height of the displayed Publisher video in the HTML page (default: 198 pixels). You can specify the number of pixels as either a number (such as 300) or a string ending in "px" (such as "300px"). Or you can specify a percentage of the size of the parent element, with a string ending in "%" (such as "100%"). Note: To resize the publisher video, adjust the CSS of the publisher's DOM element (the element property of the Publisher object) or (if the height is specified as a percentage) its parent DOM element (see Resizing or repositioning a video).
  • initials (String) — The initials for this stream. These initials are shown as centered, capitalized text in each Publisher and Subscriber view when the video is disabled and no backgroundImageURI is set. If backgroundImageURI is set, it takes precedence and is displayed instead of the initials.

    The initials are also set as the initials property of the Stream object.

    Any one or two-character string (of any case) will be acceptable. If invalid initials are used, then no error will be thrown and initials won't be set.

  • insertDefaultUI (Boolean) — Whether to use the default OpenTok UI (true, the default) or not (false). The default UI element contains user interface controls, a video loading indicator, and automatic video cropping or letterboxing, in addition to the video. (If you leave insertDefaultUI set to true, you can control individual UI settings using the fitMode, showControls, and style options.)

    If you set this option to false, OpenTok.js does not insert a default UI element in the HTML DOM, and the element property of the Publisher object is undefined. Instead, the Publisher object dispatches a videoElementCreated event when the video element (or in Internet Explorer the object element containing the video) is created. The element property of the event object is a reference to the Publisher's video (or object) element. Add it to the HTML DOM to display the video.

    Set this option to false if you want to move the Publisher's video (or object) element in the HTML DOM.

    If you set this to false, do not set the targetElement parameter. (This results in an error passed into to the OT.initPublisher() callback function.) To add the video to the HTML DOM, add an event listener for the videoElementCreated event, and then add the element property of the event object into the HTML DOM.

  • insertMode (String) — Specifies how the Publisher object will be inserted in the HTML DOM. See the targetElement parameter. This string can have the following values:

    • "replace" — The Publisher object replaces contents of the targetElement. This is the default.
    • "after" — The Publisher object is a new element inserted after the targetElement in the HTML DOM. (Both the Publisher and targetElement have the same parent element.)
    • "before" — The Publisher object is a new element inserted before the targetElement in the HTML DOM. (Both the Publisher and targetElement have the same parent element.)
    • "append" — The Publisher object is a new element added as a child of the targetElement. If there are other child elements, the Publisher is appended as the last child element of the targetElement.

  • maxResolution (Object) — Sets the maximum resolution to stream. This setting only applies to when the videoSource property is set to "application", "screen", or "window" (when the publisher is screen-sharing). The resolution of the stream will match the captured screen region unless the region is greater than the maxResolution setting. Set this to an object that has two properties: width and height (both numbers). The maximum value for each of the width and height properties is 1920, and the minimum value is 10.
  • mirror (Boolean) — Whether the publisher's video image is mirrored in the publisher's page. The default value is true (the video image is mirrored), except for a screen-sharing video (when the videoSource property is set to "application", "screen", or "window" (in which case the default is false). This property does not affect the display on subscribers' views of the video.
  • name (String) — The name for this stream. The name appears at the bottom of Subscriber videos. The default value is "" (an empty string). Setting this to a string longer than 1000 characters results in an runtime exception.
  • noiseSuppression (Boolean) — Whether to enable noise suppression for the published audio. You may want to set this to false when publishing high-quality audio (by setting the audioBitrate property of the OT.initPublisher() options). The default value is true. This setting is ignored if you set disableAudioProcessing to true (which disables echo cancellation, automatic gain control, and noise suppression for the published stream).
  • publishAudio (Boolean) — Whether to initially publish audio for the stream (default: true). This setting applies when you pass the Publisher object in a call to the Session.publish() method.
  • publishVideo (Boolean) — Whether to initially publish video for the stream (default: true). This setting applies when you pass the Publisher object in a call to the Session.publish() method.
  • publishCaptions (Boolean) — Whether to initially publish captions for the stream (default: false). This setting applies when you pass the Publisher object in a call to the Session.publish() method. This property will have no effect if captions have not been enabled at the session level. For more information, see the Live Captions developer guide.
  • resolution (String) — The desired resolution of the video. The format of the string is "widthxheight", where the width and height are represented in pixels. Valid values are "1920x1080", "1280x720", "640x480", and "320x240". The published video will only use the desired resolution if the client configuration supports it. Some browsers and clients do not support each of these resolution settings.

    The requested resolution of a video stream is set as the videoDimensions.width and videoDimensions.height properties of the Stream object.

    If you do not specify a resolution, the browser uses the camera's default resolution. Most physical cameras have a default resolution of 640x480, but other cameras, in particular virtual cameras, have different default resolutions. If the client system cannot support the resolution you request, the stream will use the next largest setting supported.

    The actual resolution used by the Publisher is returned by the videoHeight() and videoWidth() methods of the Publisher object. The actual resolution of a Subscriber video stream is returned by the videoHeight() and videoWidth() properties of the Subscriber object. These may differ from the values of the resolution property passed in as the properties property of the OT.initPublisher() method, if the browser does not support the requested resolution, this value is ignored. Also, if the video source is a video MediaStreamTrack object (see the videoSource), this value is ignored and the resolution is defined by the MediaStreamTrack object, which you can get by calling the getConstraints() method of the MediaStreamTrack object.

  • scalableScreenshare (Boolean) — Whether to allow use of scalable video for a publisher that has the videoSource set to "screen" (true) or not (false, the default).
  • scalableVideo (Boolean) — Whether to allow (true, the default) or disable (false) scalable video for the publisher. This only applies in a routed session (one that uses the OpenTok Media Router). Note: By default, scalable video is disabled in screen-sharing videos. You can set the scalableScreenshare option to true to enable scalable video for screen-sharing streams. However, setting scalableVideo to false disables scalable video for any video source (and the scalableScreenshare setting is ignored for screen-sharing streams).
  • showControls (Boolean) — Whether to display the built-in user interface controls (default: true) for the Publisher. These controls include the name display, the audio level indicator, and the microphone control button. You can turn off all user interface controls by setting this property to false. You can control the display of individual user interface controls by leaving this property set to true (the default) and setting individual properties of the style property.
  • style (Object) — An object containing properties that define the initial appearance of user interface controls of the Publisher. The style object includes the following properties:
    • audioLevelDisplayMode (String) — How to display the audio level indicator. Possible values are: "auto" (the indicator is displayed when the video is disabled), "off" (the indicator is not displayed), and "on" (the indicator is always displayed).
    • archiveStatusDisplayMode (String) — How to display the archive status indicator. Possible values are: "auto" (the indicator is displayed when the session is being recorded), "off" (the indicator is not displayed). If you disable the archive status display indicator, you can display your own user interface notifications based on the archiveStarted and archiveStopped events dispatched by the Session object.
    • backgroundImageURI (String) — A URI for an image to display as the background image when a video is not displayed. (A video may not be displayed if you call publishVideo(false) on the Publisher object). You can pass an http or https URI to a PNG, JPEG, or non-animated GIF file location. You can also use the data URI scheme (instead of http or https) and pass in base-64-encrypted PNG data, such as that obtained from the Publisher.getImgData() method. (For example, you could set the property to a value returned by calling getImgData() on a previous Publisher object.) If the URL or the image data is invalid, the property is ignored (the attempt to set the image fails silently).
    • buttonDisplayMode (String) — How to display the microphone controls Possible values are: "auto" (controls are displayed when the stream is first displayed and when the user mouses over the display), "off" (controls are not displayed), and "on" (controls are always displayed).
    • nameDisplayMode (String) — Whether to display the stream name. Possible values are: "auto" (the name is displayed when the stream is first displayed and when the user mouses over the display), "off" (the name is not displayed), and "on" (the name is always displayed).
    • videoDisabledDisplayMode (String) — Whether to display the video disabled indicator and video disabled warning icons for the Publisher. These icons indicate that the video has been disabled (or is at risk of being disabled for the warning icon) due to poor stream quality. This style only applies to the Publisher object. Possible values are: "auto" (the icons are automatically when the displayed video is disabled or at risk of being disabled due to poor stream quality), "off" (do not display the icons), and "on" (display the icons). The default setting is "auto".

      This is a beta feature.

  • videoContentHint (String) — Sets the content hint of the the video track of the publisher's stream. This allows browsers to use encoding or processing methods more appropriate to the type of content. You can set this to one of the following values:

    • "" — No hint is provided (the default).
    • "motion" — The track should be treated as if it contains video where motion is important. For example, you may use this setting for a screen-sharing stream that contains video.
    • "detail" — The track should be treated as if video details are extra important. For example, you may use this setting for a screen-sharing stream that contains text content, painting, or line art.
    • "text" — The track should be treated as if text details are extra important. For example, you may use this setting for a screen-sharing stream that contains text content.

    With the "text" and "detailed" content hints, the browser attempts to maintain high resolution, even if it must reduce the video frame rate. For the "motion" content hint, the browser reduces resolution to prevent the frame rate from stalling.

    You can read more about these options in the W3C Working Draft. You may want to set the video content hint to optimize performance for screen-sharing videos. For example, you can set it to "text" when sharing a screen that contains a lot of text (such as a slideshow).

    Chrome 60+, Safari 12.1+, Edge 79+, and Opera 47+ support video content hints.

    Also see the Publisher.setVideoContentHint() method and the developer guide topic on this feature.

  • videoFilter (Object) — An object containing properties that define the video filter to be applied to the Publisher's video stream. The following filters are supported:
    • Background blur filter — Set the type property of the object to "backgroundBlur".

      A background blur filter object includes an additional blurStrength property, which defines the blur radius and is optional. Set this to either "low" or "high" (the default).

    • Background replacement filter — Set the type property of the object to "backgroundReplacement".

      A background replacement filter object includes an additional backgroundImgUrl property, which defines the URL of the background image to use. Also accepted are image BLOBs (a Base64-encoded string of image data). The following image formats are supported: BMP, PNG, JPEG, and GIF.

      The background image is resized to match the dimensions of the publisher's video. For best results, use an image that has the same dimensions (or at least the same aspect ratio) as the published video. Set the mirror option to false when calling the OT.initPublisher() method to have the background image appear in the correct orientation (not mirrored) in the publisher's page.

    Note: Video filters are only supported in recent versions of Chrome, Electron, Opera, and Edge. They are not supported in other (non-Chromium-based) browsers or on iOS. You can check if the client supports this feature by calling the OT.hasMediaProcessorSupport() method.

    You can change the video filter by calling the Publisher.applyVideoFilter() method. You can remove the video filter by calling the Publisher.clearVideoFilter() method.

  • videoSource (String, MediaStreamTrack, Boolean, or null) — The ID of the video input device (such as a camera) to be used by the publisher. You can obtain a list of available devices, including video input devices, by calling the OT.getDevices() method. Each device listed by the method has a unique device ID. If you pass in a device ID that does not match an existing video input device, the call to OT.initPublisher() fails with an error (error code 1500, "Unable to Publish") passed to the completion handler function.

    If you set this property to null or false, the browser does not request access to the camera, and no video is published. In a voice-only call, set this property to null or false for each Publisher.

    To publish a screen-sharing stream, set this property to "screen". In older browser versions, you could also pass in "application" or "window" to specify a type of screen-sharing source. However, in current browsers that support screen sharing, passing in any of these values results in the same behavior — the browser displays a dialog box in which the end user selects the screen-sharing source (which can be the entire screen or a specific window). In Electron, screen sharing captures the entire screen, without prompting the user for permission. For screen-sharing streams, the following are default values for other properties: audioFallbackEnabled == false, maxResolution == {width: 1920, height: 1920}, mirror == false, scaleMode == "fit". Also, the default scaleMode setting for subscribers to the stream is "fit". In Safari, initializing a screen-sharing publisher without a user gesture handler may throw an InvalidAccessError error.

    You can also set this property to a video MediaStreamTrack object. This lets you use the MediaStreamTrack object as the video source for the published stream. For example, you can get a CanvasCaptureMediaStream object by calling the captureStream() method of a HTMLCanvasElement, and then you can call the getVideoTracks() method of the CanvasCaptureMediaStream object to get a video MediaStreamTrack object. Or you can get an array of video MediaStreamTrack object from the videoTracks property of an HTMLMediaElement object. Or you can call the getLocalStreams() or getRemoteStreams() method of an RTCPeerConnection object to get an array of MediaStream objects, and then call the getVideoTracks() method of one of the MediaStream objects to get an array of video MediaStreamTrack objects. Note that by default the publisher uses a microphone as the audio source, so be sure to set the audioSource option if you want to use a MediaStreamTrack as the audio source or if you do not want to publish an audio track. The default mirror setting for a Publisher with a MediaStreamTrack video source is false. You can also call OT.getUserMedia() to get a MediaStream object that uses the microphone and camera as the audio and video sources.

  • width (Number or String) — The desired initial width of the displayed Publisher video in the HTML page (default: 264 pixels). You can specify the number of pixels as either a number (such as 400) or a string ending in "px" (such as "400px"). Or you can specify a percentage of the size of the parent element, with a string ending in "%" (such as "100%"). Note: To resize the publisher video, adjust the CSS of the publisher's DOM element (the element property of the Publisher object) or (if the width is specified as a percentage) its parent DOM element (see Resizing or repositioning a video).
completionHandler function (Optional) A function to be called when the method succeeds or fails in initializing a Publisher object. This function takes one parameter — error. On success, the error object is set to null. On failure, the error object has two properties: code (an integer) and message (a string), which identify the cause of the failure. The method succeeds when the user grants access to the camera and microphone. The method fails if the user denies access to the camera and microphone. The completionHandler function is called before the Publisher dispatches an accessAllowed (success) event or an accessDenied (failure) event.

The following code adds a completionHandler when calling the OT.initPublisher() method:

var publisher = OT.initPublisher('publisher', null, function (error) {
  if (error) {
    console.log(error);
  } else {
    console.log("Publisher initialized.");
  }
});
See:
Returns:
The Publisher object.

(static) initSession(apiKey, sessionId, options) → {Session}

Initializes and returns the local session object for a specified session ID.

You connect to an OpenTok session using the connect() method of the Session object returned by the OT.initSession() method. Note that calling OT.initSession() does not initiate communications with the cloud. It simply initializes the Session object that you can use to connect (and to perform other operations once connected).

Note that you can initialize only one Session object per session ID. Calling OT.initSession() a second time with the same session ID returns the previously created Session object. However, you can initialize multiple Session objects for different sessions (with different session IDs) to connect to multiple sessions.

When the client disconnects from the session (and the session dispatches a sessionDisconnected event), you can reuse the Session object to reconnect to the session. However, the Session object will retain any existing event handlers attached to it. You can remove all event handlers by calling the off() method of the Session object (passing in no parameters).

For an example, see Session.connect().

Parameters:
Name Type Description
apiKey String Your Vonage application ID (see your Vonage Video API account page). Important: For Vonage applications, this is Vonage application ID (not an API key).
sessionId String The session ID identifying the OpenTok session. For more information, see Session creation.
options Object An object that includes optional options for initializing the session. This object includes the following properties:
  • connectionEventsSuppressed — (Boolean) Set this property to true to support large interactive video sessions. This prevents the Session object from dispatching connectionCreated and connectionDestroyed events when other clients connect to or disconnect from the session. (Also, the OpenTok server does not send these events to the web client.) For more information, see Suppressing connection events in the OpenTok developer guides.
  • ipWhitelist — (Boolean) This is available as an add-on feature. Set this to true if IP white listing is enabled for your project. The default value is false.
  • iceConfig — (Object) This feature is part of the configurable TURN add-on feature.
  • encryptionSecret — (String) This is the initial encryption secret used by the end-to-end encryption feature. See the developer guide.
Returns:
The session object through which all further interactions with the session will occur.

(static) log(message)

Sends a string to the debugger console. However, the function only logs to the console if you have set the log level to OT.LOG or OT.DEBUG, by calling OT.setLogLevel(OT.LOG) or OT.setLogLevel(OT.DEBUG).
Parameters:
Name Type Description
message String The string to log.
See:

(static) off(type, handler, context)

Removes an event handler.

Pass in an event name and a handler method, the handler is removed for that event:

OT.off("exceptionEvent", exceptionEventHandler);

If you pass in an event name and no handler method, all handlers are removed for that events:

OT.off("exceptionEvent");

The method also supports an alternate syntax, in which the first parameter is an object that is a hash map of event names and handler functions and the second parameter (optional) is the context for matching handlers:

OT.off(
  {
    exceptionEvent: exceptionEventHandler
  },
  this
);
Parameters:
Name Type Description
type String (Optional) The string identifying the type of event. You can use a space to specify multiple events, as in "eventName1 eventName2 eventName3". If you pass in no type value (or other arguments), all event handlers are removed for the object.
handler function (Optional) The event handler function to remove. If you pass in no handler, all event handlers are removed for the specified event type.
context Object (Optional) If you specify a context, the event handler is removed for all specified events and handlers that use the specified context.
See:

(static) on(type, handler, context)

Adds an event handler function for one or more events.

The OT object dispatches one type of event — an exception event. The following code adds an event listener for the exception event:

OT.on("exception", function (event) {
  // This is the event handler.
});

You can also pass in a third context parameter (which is optional) to define the value of this in the handler method:

OT.on("exception",
  function (event) {
    // This is the event handler.
  }),
  session
);

If you do not add a handler for an event, the event is ignored locally.

Parameters:
Name Type Description
type String The string identifying the type of event.
handler function The handler function to process the event. This function takes the event object as a parameter.
context Object (Optional) Defines the value of this in the event handler function.
See:

(static) once(type, handler, context)

Adds an event handler function for an event. Once the handler is called, the specified handler method is removed as a handler for this event. (When you use the OT.on() method to add an event handler, the handler is not removed when it is called.) The OT.once() method is the equivilent of calling the OT.on() method and calling OT.off() the first time the handler is invoked.

The following code adds a one-time event handler for the exception event:

OT.once("exception", function (event) {
  console.log(event);
}

You can also pass in a third context parameter (which is optional) to define the value of this in the handler method:

OT.once("exception",
  function (event) {
    // This is the event handler.
  },
  session
);

The method also supports an alternate syntax, in which the first parameter is an object that is a hash map of event names and handler functions and the second parameter (optional) is the context for this in each handler:

OT.once(
  {exeption: function (event) {
    // This is the event handler.
    }
  },
  session
);
Parameters:
Name Type Description
type String The string identifying the type of event. You can specify multiple event names in this string, separating them with a space. The event handler will process the first occurence of the events. After the first event, the handler is removed (for all specified events).
handler function The handler function to process the event. This function takes the event object as a parameter.
context Object (Optional) Defines the value of this in the event handler function.
See:

(static) registerScreenSharingExtension(kind, id, version)

Register an extension for screen-sharing support in an older version of Chrome or Opera.

Note: A screen-sharing extension is not required in Chrome 72+ or Opera 59+. The end user is prompted to grant access to the screen, just as they would be when granting access to a camera. You only need a screen-sharing extension for older versions of Opera and Chrome.

Use the OT.checkScreenSharingCapability() method to check if an extension is required, registered, and installed.

The OpenTok screensharing-extensions repo includes code for creating an extension for screen-sharing support.

Parameters:
Name Type Description
kind String Set this parameter to "chrome". Currently, you can only register a screen-sharing extension for older versions of Chrome and Opera.
id String The ID for your screen-sharing extension. You can find this ID at chrome://extensions.
version Number The version of the screen-sharing extension from the screensharing-extensions repo. Set this if you are using version 2 or later. For example, if you are using version 2, set this to 2. With version 2, the client can use the extension immediately after installing it, without reloading the page.
See:

(static) removeEventListener(type, listener)

This method is deprecated. Use off() instead.

Removes an event listener for a specific event.

Throws an exception if the listener name is invalid.

Parameters:
Name Type Description
type String The string identifying the type of event.
listener function The event listener function to remove.
See:

(static) reportIssue(completionHandler)

Report that your app experienced an issue. You can use the issue ID with Inspector or when discussing an issue with the Vonage API support team.
Parameters:
Name Type Description
completionHandler function A function that is called when the call to this method succeeds or fails. This function has two parameters. The first parameter is an Error object that is set when the call to the reportIssue() method fails (for example, if the client is not connected to the network) or null when the call to the reportIssue() method succeeds. The second parameter is set to the report ID (a unique string) when the call succeeds.

(static) setAudioOutputDevice() → {Promise}

Sets the new audio output device.

The method returns a Promise which resolves when the operation completes successfully. If there is an error, the promise is rejected.

Note: Current browser support is for desktop versions of Chrome 49+, Edge 17+, and Opera 36+.

See:
Returns:
A promise that resolves when the operation completes successfully. If there is an error, the promise is rejected.

(static) setLogLevel(logLevel)

Sets the API log level.

Calling OT.setLogLevel() sets the log level for runtime log messages that are the OpenTok library generates. The default value for the log level is OT.ERROR.

The OpenTok JavaScript library displays log messages in the debugger console (such as Firebug), if one exists.

The following example logs the session ID to the console, by calling OT.log(). The code also logs an error message when it attempts to publish a stream before you have connected to the session (by calling Session.connect()).

OT.setLogLevel(OT.LOG);
session = OT.initSession(sessionId);
OT.log(sessionId);
publisher = OT.initPublisher("publishContainer");
session.publish(publisher);
Parameters:
Name Type Description
logLevel Number The degree of logging desired by the developer:

  • OT.NONE — API logging is disabled.
  • OT.ERROR — Logging of errors only.
  • OT.WARN — Logging of warnings and errors.
  • OT.INFO — Logging of other useful information, in addition to warnings and errors.
  • OT.LOG — Logging of OT.log() messages, in addition to OpenTok info, warning, and error messages.
  • OT.DEBUG — Fine-grained logging of all API actions, as well as OT.log() messages.

See:

(static) setProxyUrl()

Sets the URL of the IP proxy server. With the IP proxy feature, the client routes all internet traffic (except for media streams) via your proxy server.

You must call this method before calling any other OpenTok methods. This ensures that the proxy server is used for OpenTok traffic. Otherwise, the call fails, and the OT object dispatches an exception event. The OT object also dispatches an exception event if you call this method after having previously called it.

This is available as an add-on feature. For more information, see the IP proxy developer guide.

(static) unblockAudio()

Causes subscribers' audio to play back in browsers where audio is blocked. You must call this method in response to an HTML element dispaching a click event.

You only need to call this method if you disable display of the Subscriber's default audio playback icon (by setting the style.audioBlockedDisplayMode property of the options parameter of the Session.subscribe() method). You may call this method in response to the user clicking an HTML element that you display on the page.

The Subscriber dispatches an audioBlocked event if audio is blocked. In response to that event, you can display a UI element to notify the end user to respond to playback subscriber audio. Call the OT.unblockAudio() method in response to the user clicking a DOM element.

Note: Subscriber audio is also unblocked automatically if the local client gains access to the camera or microphone (for instance, in response to a successful call to OT.initPublisher()).

See:
Returns:
Promise The promise resolves if audio playback succeeds on all blocked subscribers. The promise is rejected if playback fails. See Error for details.

(static) upgradeSystemRequirements()

Displays information about system requirements for OpenTok for WebRTC. This information is displayed in an iframe element that fills the browser window.

Note: this information is displayed automatically when you call the OT.initSession() or the OT.initPublisher() method if the client does not support OpenTok for WebRTC.

See:

Events

exception

Dispatched by the OT class when the app encounters an exception. Note that you set up an event handler for the exception event by calling the OT.on() method.
See: