Code With Me Help

Code With Me setup overview and terminology

The Code With Me feature enables you to share an open project in your IDE with your distributed team. You can set up on-premises servers to have full control of your infrastructure while working with Code With Me.

On-premises setup can work in two modes depending on your organization's network and security restrictions - full offline or with users access to JetBrains sites to get the appropriate version of Code With Me Guest.

We need the same version of the thin client for each host IDE of a particular version because the set of supported features and tools depends on it. That's why a connected guest needs to download this file either from JetBrains sites or from the local storage configured on the customer's side.

Different types of the on-premises setup will be reviewed in this documentation.

Workflow

Initiate a Code With Me session

  1. The host requests a Code With Me session creation from the lobby server in the host IDE.

  2. If there are available slots in the license, the lobby server creates a Code With Me session, which is persisted and can be joined until the host closes the session.

  3. The lobby server sends a Code With Me "Join" link to the host, it appears in the IDE and can be shared with potential guests.

  4. Occupied slot in the license is going back to the pool when the session is closed by the host user.

Join a Code With Me session

  1. A guest opens a Code With Me join link.

  2. A lobby server provides the guest with the required version of Code With Me Guest.

  3. Code With Me Guest is downloaded, launched and connects to the session (either using P2P or relays, depending on the companies' policies and P2P availability).

Terminology

Host

A host is either the instance of the JetBrains IDEA-based IDEs which shares its coding environment with clients or the person/user doing that.

Guest

A guest is either the instance that is connected to the Code With Me coding session shared by the host or the person joining the session.

Code With Me Guest

A client is a lightweight version of "IntelliJ IDEA", used by a guest for connecting to the host.

Lobby server

Main part of the setup; responsible for the following actions:

  • Generating a link that can be used to join the Code With Me session.

  • Reporting a list of supported features to the host or a guest (for example, whether P2P is allowed or not).

  • Selecting a relay server in cases when P2P does not work or is forbidden.

  • Managing license info and occupied hosts slots.

Relay server

A relay server is responsible for relaying a connection between the host or guests in case the P2P connection doesn't work or is forbidden. It's possible to have several relays in different locations, the closest one will be used based on the proximity to the session participants.

Quick setup

Code With Me on-premises installer intended for quick evaluation purposes. We provide it as an archive containing lobby, relay, and launcher.sh script. This type of setup doesn't include SSL certificates and, by default, tries to connect to JetBrains sites. Not supposed to be used in production.

Doesn't include audio/video functionality.

Full setup

Cluster/environment where the lobby, relay, Redis +/- video/audio components are installed separately, with SSL certificates; using our examples and templates from this documentation or according to deployment practices in your organization.

Full offline (guests local storage) mode

Setup with a configured local storage that distributes previously downloaded thin client files among connected guests. In this mode, you need to download required Code With Me guest files from JetBrains to dedicated local storage in your network and denote to the lobby server to use this storage as a source.

Mirror-guests script

Script that downloads files required for the connection (thin client, JetBrains Runtime) from JetBrains sites. The script accepts filters passed as the command-line parameters.

Enterprise License

Code With Me local setup requires its own commercial license purchased from our site

IDEs licenses don't cover CWM on-premises installation.

The number of hosts in this license determines the N of users who can be inviters/hosts simultaneously. Minimal N of host users in the license is 10; after 10, you may purchase one by one.

Host slots in the Enterprise are floating, not named. If all slots are busy, the following user can occupy it if an existing Code With Me open session is over.

Audio/video/chat

Code With Me feature Audio and Video chat setup for audio and video calls and chat during the session. In local setup, it becomes available if the setup contains configured Jitsi server and "jitsi_telephony" in the list of lobby's "Enabled features" in config.

Last modified: 31 August 2021