Go to file
David Négrier 05646718a9 Fix disconnects after 5 minutes in Chrome
This commit increases idle timeout for websocket connection

Issue: after 5 minutes of inactive tab (hidden tab) in Chrome, WorkAdventure was disconnected.

I believe Google was going in "intensive throttling" mode (see  https://developer.chrome.com/blog/timer-throttling-in-chrome-88/#intensive-throttling)
This means setTimeouts are run only once per minute.

And I believe the "keep alive" must be implemented with a "setTimeout" (one way or another even if I can't find a trace of this in the code). This would mean that the browser would send keep alive requests only once per minute.
But the pusher is configured to shut the connection after 30 seconds of idle activity.

Therefore, the pusher disconnects inactive Chrome tabs. By raising the Pusher idle timer to 2 minutes, we give a chance to Chrome to send a ping to the server in time (since Chrome won't send more than 1 ping per minute).
2021-09-10 18:30:36 +02:00
.github/workflows added yarn run pretty to the front ci 2021-09-06 14:27:01 +02:00
.husky Setting up lint-staged on front and back 2021-06-23 16:45:38 +02:00
back Fix disconnects after 5 minutes in Chrome 2021-09-10 18:30:36 +02:00
benchmark Bump path-parse from 1.0.6 to 1.0.7 in /benchmark 2021-09-01 15:48:20 +00:00
contrib/docker [Breaking change] UPLOADER_URL and ADMIN_URL are now true URLs (and not only host name) and API_URL is replaced by PUSHER_URL 2021-03-31 16:00:14 +02:00
docs explain new property jitsiWidth 2021-09-09 22:58:30 +02:00
front FIX: the video element should not have a bigger height than its container 2021-09-10 16:04:15 +02:00
maps Improving design of the test page 2021-09-09 11:35:17 +02:00
messages Merge pull request #1208 from thecodingmachine/dependabot/npm_and_yarn/messages/striptags-3.2.0 2021-09-01 17:41:35 +02:00
pusher Fix disconnects after 5 minutes in Chrome 2021-09-10 18:30:36 +02:00
uploader Bump path-parse from 1.0.6 to 1.0.7 in /uploader 2021-09-01 13:10:13 +00:00
.dockerignore *: Dockerfiles cleanup, docker-compose.prod.yaml 2021-01-12 22:32:37 +01:00
.env.template Revert "Squashed commit of the following:" 2021-08-02 22:13:10 +02:00
.gitignore .gitignore to upstream 2021-09-09 08:52:24 +02:00
CHANGELOG.md documentation and CHANGELOG 2021-08-27 16:28:59 +02:00
CONTRIBUTING.md setProperty function doesn't set an empty array if property doesn't exist 2021-07-02 14:40:18 +02:00
deeployer.libsonnet fix deeployer 2021-08-16 14:45:22 +02:00
docker-compose.single-domain.yaml Revert "Squashed commit of the following:" 2021-08-02 22:13:10 +02:00
docker-compose.yaml Revert "Squashed commit of the following:" 2021-08-02 22:13:10 +02:00
package-lock.json Merge remote-tracking branch 'remotes/upstream/develop' into trigger-message-refv3 2021-07-02 18:49:22 +02:00
package.json Update package.json (#1344) 2021-08-09 14:36:53 +02:00
README-INTRO.jpg Adding demo to README 2020-06-14 12:33:23 +02:00
README.md Add anthoer note for https://github.com/thecodingmachine/workadventure/issues/932#issuecomment-867562208 2021-06-24 14:35:18 +03:00
SECURITY.md Create SECURITY.md 2021-06-23 15:26:17 +02:00
Vagrantfile.template Update vagrant template 2020-12-16 16:39:34 +01:00
yarn.lock Merging master into develop 2021-06-29 18:39:43 +02:00

Discord

WorkAdventure landscape image

Demo here : https://workadventu.re/.

Work Adventure

Work Adventure is a web-based collaborative workspace for small to medium teams (2-100 people) presented in the form of a 16-bit video game.

In Work Adventure, you can move around your office and talk to your colleagues (using a video-chat feature that is triggered when you move next to a colleague).

Setting up a development environment

Install Docker.

Run:

docker-compose up -d

The environment will start.

You should now be able to browse to http://play.workadventure.localhost/ and see the application. You can view the dashboard at http://workadventure.localhost:8080/

Note: on some OSes, you will need to add this line to your /etc/hosts file:

/etc/hosts

127.0.0.1 workadventure.localhost

Note: If on the first run you get a page with "network error". Try to docker-compose stop , then docker-compose start. Note 2: If you are still getting "network error". Make sure you are authorizing the self-signed certificate by entering https://pusher.workadventure.testing and accepting them.

MacOS developers, your environment with Vagrant

If you are using MacOS, you can increase Docker performance using Vagrant. If you want more explanations, you can read this medium article.

Prerequisites

First steps

Create a config file Vagrantfile from Vagrantfile.template

cp Vagrantfile.template Vagrantfile

In Vagrantfile, update VM_HOST_PATH with the local project path of your machine.

#VM_HOST_PATH# => your local machine path to the project

(run pwd and copy the path in this variable)

To start your VM Vagrant, run:

Vagrant up

To connect to your VM, run:

Vagrant ssh

To start project environment, run

docker-compose up

You environment runs in you VM Vagrant. When you want stop your VM, you can run:

Vagrant halt

If you want to destroy, you can run

Vagrant destroy

Available commands

  • Vagrant up: start your VM Vagrant.
  • Vagrant reload: reload your VM Vagrant when you change Vagrantfile.
  • Vagrant ssh: connect on your VM Vagrant.
  • Vagrant halt: stop your VM Vagrant.
  • Vagrant destroy: delete your VM Vagrant.

Setting up a production environment

The way you set up your production environment will highly depend on your servers. We provide a production ready docker-compose file that you can use as a good starting point in the contrib/docker directory.