A glossy Matrix collaboration client for desktop.
Go to file
J. Ryan Stinnett 933c6ee3e3 Use Xenial as the build image's base distribution
Since Xenial has the oldest glibc (2.23) of all the active distributions, this
attempts to construct a build image based on that. The Dockerfile here was built
by recursively expanding the `FROM` lines until reaching
`buildpack-deps:bionic-curl` and then changing that to `xenial`. Everything else
is the same.

Part of https://github.com/vector-im/riot-web/issues/13553
2020-05-07 14:45:29 +01:00
.buildkite Files I've added 2019-12-06 18:20:31 +00:00
build Port 51f2afb7b7 from riot-web 2020-02-17 09:58:55 +00:00
dockerbuild Use Xenial as the build image's base distribution 2020-05-07 14:45:29 +01:00
hak/matrix-seshat Add cfg to access the hak.json 2020-04-04 00:21:52 +01:00
res/img Initial copy of files from the riot-web repo 2019-12-06 18:17:34 +00:00
riot.im Remove Conflicts from riot-desktop 2020-05-07 11:29:38 +01:00
scripts Get the app ID from the cintext 2020-03-11 19:21:14 +00:00
src widen search paths / fix vector-im/riot-web#13190 2020-04-16 14:08:16 +02:00
.eslintrc.js Lint scripts dir 2020-02-17 14:49:26 +00:00
.gitignore Add a release script 2020-04-15 18:12:02 +01:00
CHANGELOG.md Prepare changelog for v1.6.0 2020-05-05 11:06:57 +01:00
LICENSE Initial commit 2019-12-06 13:07:37 +00:00
package.json v1.6.0 2020-05-05 11:06:57 +01:00
README.md Update readme now it's the real source 2020-04-17 18:06:06 +01:00
release_config.yaml Add a release script 2020-04-15 18:12:02 +01:00
release.sh Add a release script 2020-04-15 18:12:02 +01:00
yarn.lock Upgrade matrix-js-sdk to 6.0.0 2020-05-05 11:05:35 +01:00

Riot Desktop

This is Riot desktop app as of release 1.6.

Fetching Riot

Since this package is just the Electron wrapper for Riot, it doesn't contain any of the Riot code, so the first step is to get a working copy of Riot. There are a few ways of doing this:

# Fetch the prebuilt release Riot package from the riot.im GitHub releases page. The version
# fetched will be the same as the local riot-desktop package.
# We're explicitly asking for no config, so the package Riot will have no config.json.
yarn run fetch --noverify --cfgdir ''

...or if you'd like to use GPG to verify the downloaded package:

# Fetch the Riot public key from the riot.im web server over a secure connection and import
# it into your local GPG keychain (you'll need GPG installed). You only need to to do this
# once.
yarn run fetch --importkey
# Fetch the package and verify the signature
yarn run fetch --cfgdir ''

...or either of the above, but fetching a specific version of Riot:

# Fetch the prebuilt release Riot package from the riot.im GitHub releases page. The version
# fetched will be the same as the local riot-desktop package.
yarn run fetch --noverify --cfgdir '' v1.5.6

If you only want to run the app locally and don't need to build packages, you can provide the webapp directory directly:

# Assuming you've checked out and built a copy of riot-web in ../riot-web
ln -s ../riot-web/webapp ./

[TODO: add support for fetching develop builds, arbitrary URLs and arbitrary paths]

Building

Now you have a copy of Riot, you're ready to build packages. If you'd just like to run Riot locally, skip to the next section.

yarn run build

This will do a couple of things:

  • Run the setversion script to set the local package version to match whatever version of Riot you installed above.
  • Run electron-builder to build a package. The package built will match the operating system you're running the build process on.

If you're on Windows, you can choose to build specifically for 32 or 64 bit:

yarn run build32

or

yarn run build64

This build step will not build any native modules.

If you'd like to build the native modules (for searching in encrypted rooms): This will take 10 minutes or so, and will require a number of native tools to be installed, depending on your OS (eg. rust, tcl, make/nmake).

yarn run build:native

On Windows, this will automatically determine the architecture to build for based on the environment (ie. set up by vcvarsall.bat).

You can also build using docker, which will always produce the linux package:

# Run this once to make the docker image
yarn run docker:setup

yarn run docker:install
# if you want to build the native modules (this will take a while)
yarn run docker:buildnative
yarn run docker:build

After running, the packages should be in dist/.

Starting

If you'd just like to run the electron app locally for development:

# Install electron - we don't normally need electron itself as it's provided
# by electron-builder when building packages
yarn add electron
yarn start

Config

If you'd like the packaged Riot to have a configuration file, you can create a config directory and place config.json in there, then specify this directory with the --cfgdir option to yarn run fetch, eg:

mkdir myconfig
cp /path/to/my/config.json myconfig/
yarn run fetch --cfgdir myconfig

The config dir for the official Riot.im app is in riot.im. If you use this, your app will auto-update itself using builds from Riot.im.