Go to file
Pratik Shah b7b43e8d9c feat(chat): convert to use React
- Change "features/chat" to support listening for new chat messages
  and storing them, removing that logic from conference.js.
- Combine chat.scss and side_toolbar_container.css, and remove unused
  scss files. Chat is the only side panel so the two concepts have
  been merged.
- Remove direct access to the chat feature from non-react and non-redux
  flows.
- Modify the i18n translate function to take in an options object.
  By default the option "wait" is set to true, but that causes
  components to mount after the parent has been notified of
  an update, which means autoscrolling down to the latest rendered
  messages does not work. With "wait" set to false, the children
  will mount and then the parent will trigger componentDidUpdate.
- Create react components for chat. Chat is the side panel
  plus the entiren chat feature. ChatInput is a child of Chat and
  is used for composing messages. ChatMessage displays one message
  and extends PureComponent to limit re-renders.
- Fix a bug where the toolbar was not showing automatically when
  chat is closed and a new message is received.
- Import react-transition-group to time the animation of the
  side panel showing/hiding and unmounting the Chat component.
  This gets around the issue of having to control autofocus if the
  component were always mounted and visibility toggled, but
  introduces not being able to store previous scroll state
  (without additional work or re-work).
2018-09-26 14:48:10 -05:00
.github/ISSUE_TEMPLATE Creates issue templates 2018-06-15 15:37:01 -05:00
android ref(proguard): Create common proguard config. 2018-09-18 14:37:05 -05:00
connection_optimization Updates config feature and whitelists options that can be overridden. (#2282) 2017-12-12 11:16:55 -08:00
css feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
debian Updates postinst prosody (#2896) 2018-04-30 15:19:30 -07:00
doc doc: add ubuntu universe repo note to quickinstall 2018-09-25 11:12:04 -05:00
flow-typed/npm [RN] Update react-native to 0.55.4 (continued) 2018-06-04 16:05:48 -05:00
fonts [WEB] add UI for transcription (#3213) 2018-07-26 09:33:40 -07:00
images cleanup: remove no longer used code 🔥🔥🔥 2018-09-19 15:12:31 +00:00
ios fix(Travis/iOS): use '-quiet' with 'xcodebuild' commands 2018-09-24 14:34:11 -05:00
lang feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
modules feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
react feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
resources Creating a new async prosody http wrapper. 2018-07-16 21:58:48 +00:00
service feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
sounds feat(recording): add sounds for when recording starts and stops (#3078) 2018-06-05 20:20:43 +02:00
static fix(dropbox): Address code review comments. 2018-08-16 13:53:43 -05: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] Don't request camera permission on first launch 2018-07-19 09:03:22 -05:00
.gitattributes react-native 0.40.0 2017-01-22 12:32:08 -06:00
.gitignore misc: ignore jshint files 2018-06-13 11:09:55 +02:00
.travis.yml fix(Travis/iOS): use '-quiet' with 'xcodebuild' commands 2018-09-24 14:34:11 -05:00
.watchmanconfig Merge jitsi-meet-react's mobile support 2016-10-12 10:31:52 -05:00
CONTRIBUTING.md Update CONTRIBUTING.md (#2601) 2018-03-20 09:49:35 -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 use official repo for libflac.js 2018-08-08 09:19:53 +10:00
README.md doc: Adds a link to the quick install tutorial. 2018-06-22 14:52:17 -05:00
analytics-ga.js fix: Filters out e2e_rtt events for google analytics. (#3476) 2018-09-25 11:00:46 -05:00
app.js Make web use the redux settings/profile 2018-05-09 15:20:22 +02:00
base.html add support for possible ssi of <base> attribute 2016-05-20 16:51:37 -05:00
conference.js feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
config.js [RN] Add Google Sign In to live streaming 2018-09-05 23:09:56 +02:00
connection.js fix(connection): reload immediately on possible split-brain (#3162) 2018-07-02 16:22:51 -05: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 [RN] Drop no longer needed polyfills 2018-08-05 17:04:19 -05:00
index.html Passes the asset that fail to load to postLoadErrorHandler. 2018-05-29 13:41:15 -05: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 [WiP] Calendar integration ui (#3395) 2018-08-27 10:13:59 -05:00
logging_config.js Remove duplication 2018-08-05 17:04:19 -05:00
package-lock.json feat(chat): convert to use React 2018-09-26 14:48:10 -05:00
package.json feat(chat): convert to use React 2018-09-26 14:48:10 -05: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 Implement local recording 2018-08-08 09:18:16 +10: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.

The Jitsi Meet client runs in your browser, without the need for installing anything on your computer. 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

On the client side, no installation is necessary. You just point your browser to the URL of your deployment. This section is about installing the Jitsi Meet suite on your server and hosting your own conferencing service.

Installing Jitsi Meet is quite a simple experience. For Debian-based systems, we recommend following the quick-install document, which uses the package system. You can also see a demonstration of the process in this tutorial video.

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

Download

Latest stable release release

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 >= 8 and npm >= 6 are required.

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

sudo apt-get install npm nodejs
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

Running with webpack-dev-server for development

Use it at the CLI, type

make dev

By default the backend deployment used is beta.meet.jit.si, you can point the Jitsi-Meet app at a different backend by using a proxy server. To do this set the WEBPACK_DEV_SERVER_PROXY_TARGET variable:

export WEBPACK_DEV_SERVER_PROXY_TARGET=https://your-example-server.com
make dev

The app should be running at https://localhost:8080/

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!