This extension allows you to use the screen-sharing support with the OpenTok.js client library in older versions of Firefox.
Important: As of Firefox 52, an extension (or whitelist listing) is no longer needed for screen sharing. Firefox prompts the end user for access to a screen, window, or application, as it would for access to the camera. For more information, see this Mozilla blog post. The Firefox extension in this repo is only included to support older versions of Firefox.
Note: Instead of using a Firefox extension for screen sharing, you can have Mozilla add your domain to the browser's screen-sharing whitelist. See this Mozilla.org page for details. Note that it can take a number of weeks for Mozilla to approve your domain's inclusion in the screen-sharing whitelist and include it in a shipping version of Firefox.
This is version 2 of the extension. With version 2, the extensionsInstalled
property of the object passed into callback method of the
OT.registerScreenSharingExtension()
method is set to true
when the extension is installed and set to work in your site's domain.
OpenTok 2.8.0 or later is required for this version of the extension.
To build your screen-sharing extension for Firefox, you need to install Node and Node Package Manager (npm). Then use npm to install the jpm package. In a command-line terminal, enter the following:
npm install jpm --global
-
Fork (or simply download) this repo.
-
Edit the
package.json
file in the firefox/ScreenSharing directory.Change the values for following fields:
id
-- The unique ID for the extension. See this documentation.title
-- The name of the extension, to be displayed in the Firefox UI.description
-- The description of the extension, to be displayed in the Firefox UI.version
-- The version.author
-- The name of the creator, to be displayed in the Firefox UI.private-browsing
-- Set this tofalse
if you want to disable the extension in private browsing mode.
See the Mozilla Add-on package.json documentation.
-
Edit the index.js file. Set the
gDomain
property to match the domain(s) your screen-sharing extension supports. Set this to an array of one or more strings.Use an asterisk at the beginning of the string to match multiple subdomains. For example, the following
gDomain
values match pages athttps://example.com/bar
andhttps://foo.example.com/bar
:['*.example.com'] ['*.example.com', '*.another-domain.com']
Omit the asterisk at the beginning of the string to match a specific subdomain. For example, the following
gDomain
values matchhttps://foo.example.com/bar
but nothttps://example.com/bar
:['foo.example.com'] ['foo.example.com', '*.another-domain.com']
Do not include the protocol,
'https://'
, in thegDomain
strings. And do not include an asterisk before a subdomain (as in['*.foo.example.com’]
). -
In the terminal, navigate to the firefox/ScreenSharing directory. Then package the extension by running the following on the command line:
jpm xpi
-
Firefox now requires that extensions be signed. For more information, see this page on extension signing at mozilla.org. However, you can test an unsigned extension in the Developer Edition and Nightly versions of Firefox (see the next section).
Firefox now requires that extensions be signed. However, for testing the Developer Edition and Nightly versions of Firefox include a setting to disable signature enforcement:
- Load the
about:config
page in Firefox. - In the Search box, type
xpinstall.signatures.required
. - Double-click the preference to set the value to
false
.
Install your extension in one of these ways:
-
Drag the file it onto a browser window in Firefox. You can also navigate to
about:addons
, click the settings button, and select "Install add-on from file". -
Add a link to the file in a web page (such as the page that uses OpenTok screen-sharing).
<a href="my-screensharing-extension.xpi">Install extension</a><br>
Clicking the link installs the extension.
-
Publish your extension to the Mozilla add-on site.
-
Locate the screensharing-test.html file in the root of this repo. Copy the file to a web server. (Screen-sharing access requires that the file be installed on a web server. You cannot load the file from a file: URL.)
-
Edit the following values in the file:
apiKey
-- Set this to your OpenTok API key. See https://dashboard.tokbox.comsessionId
-- An OpenTok session IDtoken
-- A valid token for the OpenTok session
Note that the
extensionId
property applies to screen-sharing support for Chrome. -
In Firefox, navigate to the screensharing-test.html URL on your server. Be sure to load the page via HTTPS. (Screen-sharing requires HTTPS.)
Upon connecting to the OpenTok session, the app publishes a stream using the camera as the video source. Click the Share your screen button to publish a screen-sharing stream.
-
Open a new Firefox window or tab and navigate to the HTTPS screensharing-test.html URL.
Upon connecting to the OpenTok session, the app publishes a stream using the camera as the video source. It also subscribes to the two streams published by the other page (the camera stream and the screen-sharing stream).
-
Mozilla Add-on SDK -- Mozilla documentation on developing add-ons for Firefox
-
Developer hub -- The Mozilla developer hub for add-ons.
-
add-on-sdk -- Mozilla add-on SDK documentation.
To publish a screen:
var publisher = OT.initPublisher('target-element-id', {
name: 'Screen',
audioSource: null,
videoSource: 'screen',
maxResolution: { width: 1280, height: 720 }, // max resolution to encode screen in
width: 1280, // width of preview
height: 720, // height of preview
}, function(error) {
if(error) {
// handle the error
}
// resize the publisher preview to match the encoded video
pub.element.style.width = pub.videoWidth() + 'px';
pub.element.style.height = pub.videoHeight() + 'px';
});
See the OpenTok.js screen-sharing documentation.
Released under the MIT license.