Go to file
damencho 990b1eddf2 Adds strophe.js and plugin-disco as a dependency to fix build problem.
Bumps lib-jitsi-meet to latest. There was a problem that jitsi-meet build fail if anybody touches package.json (including PR testing), this happen after start using custom strophe.js from github:jitsi/strophejs.
The error:
    ERROR in ../strophejs-plugin-disco/lib/strophe.disco.js
    Module not found: Error: Can't resolve 'strophe.js' in '/Users/dminkov/dev/jitsi-meet/node_modules/strophejs-plugin-disco/lib'
     @ ../strophejs-plugin-disco/lib/strophe.disco.js 4:126-147 4:196-227
     @ ./modules/xmpp/xmpp.js
     @ ./JitsiConnection.js
     @ ./JitsiMeetJS.js
     @ ./index.js

Without strophejs-plugin-disco jitsi-meet builds but on runtime loading fail with:
Error: Missing strophe-plugins (disco plugin is required)!

FIXME: We should remove this once strophe.js releases new version and we are back to the official one inside lib-jitsi-meet.
2018-02-08 23:50:45 -06:00
android [Android] Enable Java 1.8 compatibility support 2018-01-19 14:05:25 -06:00
connection_optimization Updates config feature and whitelists options that can be overridden. (#2282) 2017-12-12 11:16:55 -08:00
css Fix settings screen layout on iOS and add soft back button 2018-01-18 15:45:25 -06:00
debian Cleanup, removes unused obsolete files. 2017-12-07 11:14:21 -06:00
doc doc: Add -f to update-ca-certificates 2018-01-25 10:42:43 -06:00
flow-typed/npm Upgrade NPM dependencies/packages: react-native 0.50 2017-12-04 00:45:18 -06:00
fonts Fix settings screen layout on iOS and add soft back button 2018-01-18 10:06:26 -06:00
images Remove obsolete file 2017-08-16 17:07:38 -05:00
ios [RN] Fix app startup from a CallKit intent 2018-02-07 10:12:10 -06:00
lang [RN] Validate the URL in app-settings 2018-01-31 16:06:24 +01:00
modules Coding style: consistent naming, one name per abstraction 2018-02-05 15:55:04 -06:00
react [RN] Fix app startup from a CallKit intent 2018-02-07 10:12:10 -06:00
resources On token verification failure return error, reason and stop processing. 2017-10-26 14:01:21 -05:00
service ref(settings): convert panel to react 2017-12-04 16:19:18 -06:00
sounds JWT client support 2016-06-13 16:11:44 -05:00
static fix(close): use string concatenation for ie11 2018-01-08 16:26:54 -06:00
.buckconfig Merge jitsi-meet-react's mobile support 2016-10-12 10:31:52 -05:00
.editorconfig The Makefile file format requires tab characters 2016-11-23 15:54:03 -06:00
.eslintignore flow-typed 2017-02-03 16:36:14 -06:00
.eslintrc.js use central jitsi eslint config (#2108) 2017-10-25 16:02:14 -07:00
.flowconfig [RN] Update React Native to version 0.51.0 2018-01-11 11:04:28 -06:00
.gitattributes react-native 0.40.0 2017-01-22 12:32:08 -06:00
.gitignore Upgrade NPM dependencies/packages: react-native 0.50 2017-12-04 00:45:18 -06:00
.watchmanconfig Merge jitsi-meet-react's mobile support 2016-10-12 10:31:52 -05:00
CONTRIBUTING.md Updates docs report issue part. 2017-05-15 10:57:31 -05:00
ConferenceEvents.js feat(eslint): Enable for non react files 2017-10-16 14:36:29 -05:00
LICENSE Moves original contribution note 2015-09-19 12:23:54 -05:00
Makefile chore(capabilities.json): deploy 2018-02-01 17:21:52 -06:00
README.md doc: Adds a note on security (as suggested in #409). (#2322) 2017-12-26 10:49:46 -08:00
analytics-ga.js Restructures the analytics events (#2333) 2018-01-03 13:24:07 -08:00
app.js ref(css): move aui css to jitsi-meet 2017-12-05 08:50:13 -06:00
base.html add support for possible ssi of <base> attribute 2016-05-20 16:51:37 -05:00
conference.js feat(api): expose a way to submit feedback 2018-01-19 14:27:44 -08:00
config.js fix(lib-jitsi-meet): RTCBrowserType -> browser. 2018-01-22 15:56:06 -06:00
connection.js Handles connection failed event details (passing them to analytics). (#2432) 2018-02-06 14:54:21 -08:00
favicon.ico Added favicon.ico for 1) better jitsi brand recognition and 2) getting rid of warnings in web server log files 2014-06-05 13:22:44 +03:00
index.android.js feat(web/RN): update React to v16 and React Native to 0.49 2017-11-02 14:32:35 +01:00
index.html fix(css): load css before js 2017-12-05 08:50:13 -06:00
index.ios.js feat(web/RN): update React to v16 and React Native to 0.49 2017-11-02 14:32:35 +01:00
interface_config.js Updates the unsupported mobile browser page. 2017-12-05 09:52:44 -06:00
logging_config.js fix(RN logging): sync with logging_config.js (#2382) 2018-01-17 10:59:48 -08:00
package-lock.json Adds strophe.js and plugin-disco as a dependency to fix build problem. 2018-02-08 23:50:45 -06:00
package.json Adds strophe.js and plugin-disco as a dependency to fix build problem. 2018-02-08 23:50:45 -06:00
plugin.head.html Adds empty SSI templates to avoid 404. 2015-03-31 11:17:26 +02:00
title.html Moves favicon into the title html. 2016-08-01 17:11:16 -05:00
webpack.config.js ref(css): move aui css to jitsi-meet 2017-12-05 08:50:13 -06:00

README.md

Jitsi Meet - Secure, Simple and Scalable Video Conferences

Jitsi Meet is an open-source (Apache) WebRTC JavaScript application that uses Jitsi Videobridge to provide high quality, secure and scalable video conferences. You can see Jitsi Meet in action here at the session #482 of the VoIP Users Conference.

You can also try it out yourself at https://meet.jit.si .

Jitsi Meet allows for very efficient collaboration. It allows users to stream their desktop or only some windows. It also supports shared document editing with Etherpad.

Installation

Installing Jitsi Meet is quite a simple experience. For Debian-based systems, we recommend following the quick-install document, which uses the package system.

For other systems, or if you wish to install all components manually, see the detailed manual installation instructions.

Download

You can download Debian/Ubuntu binaries:

You can download source archives (produced by make source-package):

You can get our mobile versions from here:

Building the sources

Node.js >= 6 is required.

On Debian/Ubuntu systems, the required packages can be installed with:

sudo apt-get install npm nodejs-legacy
cd jitsi-meet
npm install

To build the Jitsi Meet application, just type

make

Working with the library sources (lib-jitsi-meet)

By default the library is build from its git repository sources. The default dependency path in package.json is :

"lib-jitsi-meet": "jitsi/lib-jitsi-meet",

To work with local copy you must change the path to:

"lib-jitsi-meet": "file:///Users/name/local-lib-jitsi-meet-copy",

To make the project you must force it to take the sources as 'npm update' will not do it.

npm install lib-jitsi-meet --force && make

Or if you are making only changes to the library:

npm install lib-jitsi-meet --force && make deploy-lib-jitsi-meet

Alternative way is to use npm link. It allows to link lib-jitsi-meet dependency to local source in few steps:

cd lib-jitsi-meet

# create global symlink for lib-jitsi-meet package
npm link

cd ../jitsi-meet

# create symlink from the local node_modules folder to the global lib-jitsi-meet symlink
npm link lib-jitsi-meet

So now after changes in local lib-jitsi-meet repository you can rebuild it with npm run install and your jitsi-meet repository will use that modified library. Note: when using node version 4.x, the make file of jitsi-meet do npm update which will delete the link, no longer the case with version 6.x.

If you do not want to use local repository anymore you should run

cd jitsi-meet
npm unlink lib-jitsi-meet
npm install

Contributing

If you are looking to contribute to Jitsi Meet, first of all, thank you! Please see our guidelines for contributing.

Embedding in external applications

Jitsi Meet provides a very flexible way of embedding it in external applications by using the Jitsi Meet API.

Security

WebRTC today does not provide a way of conducting multiparty conversations with end-to-end encryption. As a matter of fact, unless you consistently vocally compare DTLS fingerprints with your peers, the same goes for one-to-one calls. As a result when using a Jitsi Meet instance, your stream is encrypted on the network but decrypted on the machine that hosts the bridge.

The Jitsi Meet architecture allows you to deploy your own version, including all server components, and in that case your security guarantees will be roughly equivalent to these of a direct one-to-one WebRTC call. This is what's unique to Jitsi Meet in terms of security.

The meet.jit.si service is maintained by the Jitsi team at Atlassian.

Mobile app

Jitsi Meet is also available as a React Native app for Android and iOS. Instructions on how to build it can be found here.

Acknowledgements

Jitsi Meet started out as a sample conferencing application using Jitsi Videobridge. It was originally developed by then ESTOS' developer Philipp Hancke who then contributed it to the community where development continues with joint forces!