Run Discord through a sandboxed Electron client. Forked from https://github.com/khlam/discord-sandboxed
Go to file
2021-03-25 17:10:07 -07:00
.github/workflows 1.0.0; Fix config.json and directory not getting created. Now using github actions to build and publish releases. 2020-12-20 16:46:21 -08:00
docs/img README. [skip build] 2020-12-22 09:16:46 -08:00
src 1.0.0; Fix config.json and directory not getting created. Now using github actions to build and publish releases. 2020-12-20 16:42:10 -08:00
views Fix some change in client HTML that broke load detection. Fix user connected to voice channels addressing #14 2021-03-25 17:08:21 -07:00
.gitignore 0.4.2; Trying to fix voice 2020-12-17 18:31:43 -08:00
LICENSE.md init 2019-10-06 22:06:55 -07:00
main.js 1.0.0; Fix config.json and directory not getting created. Now using github actions to build and publish releases. 2020-12-20 16:42:10 -08:00
package-lock.json ver 2021-03-25 17:10:07 -07:00
package.json ver 2021-03-25 17:10:07 -07:00
README.md README. [skip build] 2020-12-22 09:16:46 -08:00

Discord-Sandbox

Open-source Sandbox Discord client for the privacy-minded. Say NO to intrusive data collection.

Are you worried Discord is watching what programs you have open or listening to your mic even while you're not pressing your push-to-talk key? Discord-Sandbox isolates the Discord client from reading background processes by running the Discord web client inside of a <webview>, which is finally contained inside the Electron process. While I cannot guarantee this client protects you from anything, I have tried my best to remove Discord's data collection.

Note that since this client is running the Discord web client, the following features will NOT be available.

- Viewing Streams or Streaming your desktop
- Discord's "High Quality Audio" or whatever

Push to Talk

  1. To enable push-to-talk, open Discord-Sandbox, set your push-to-talk key to Backspace, and lower the Push to Talk Release Delay slider all the way to 0 as shown.

  1. Click on the gear icon in the top left corner. Check the box to enable system-wide push to talk. Set your push to talk key by clicking in the black box and pressing the desired key (Default PTT key is mouse button 4). Configuration settings are stored in /Documents/DiscordSandbox/config.json.

Telemetry Mitigations

As detailed from Luna Mendes' discord-unofficial-docs, Discord sends telemetry data over the /api/science endpoint. This project does its best to disable this telemetry communication by running javascript code into the webview that adds a blacklist/whitelist to the default XMLHttpRequest behavior. In this way, we explicitly block all communication with the science address, while simultaneously whitelisting addresses needed for minimum Discord functionality. See the full code in mainRender.js.

Discord likely does other sneaky things to spy on us. If you have any ideas on improving this project's security/privacy please let me know by opening an issue!

Clicking on the Logs icon to the right of the settings button in the client will open the Log window, which will detail when a communication by the client is blocked.

What this Client Tries to Do

Discord-Sandbox tries to isolate the Discord client within the Electron process, preventing it from watching keystrokes or processes it has no business in.

What this Client Cannot Do

Discord's desktop application has the capabilities to collect a lot of user-behavior information. This project seeks to isolate your keystrokes and background processes from Discord. Discord can still collect the following information. Since these are inherent to the service, we can't do much about it.

  • Messages, client data, emails, and voice data
  • Links you have clicked/opened from within the client (Passing links to a browser has been disabled to somewhat mitigate this)

How does Push-to-Talk Work?

The Discord web client lacks push-to-talk detection while the browser session does not have window focus. This project works enables system-wide push-to-talk while respecting your privacyby using a separate key-press detection library, iohook, and mediating its interaction with Discord. This separates your activity from Discord without compromising usability.

When your push-to-talk key is held down, the renderer process will send a backspace key-down keycode to the <webview>. This opens your microphone without giving the client window focus, so you can use Discord without worrying about the client listening in on whatever else you're running.

Building From Source

  1. If you're using Windows 10, make sure you have the latest C++ Redistributable for Visual Studio 2015, 2017, and 2019
  2. Install Node (https://nodejs.org/en/download/)
  3. Clone Repo git clone https://github.com/khlam/discord-sandboxed.git
  4. Install dependencies npm i && npm i -d
  5. Run npm start
  6. (Optional) Create Windows installer npm run package-win

This Discord-Sandbox open source project is not affiliated with Discord or Discord Inc. I do not claim to have created Discord. Discord-Sandbox is not the official Discord client. Discord is a freeware VoIP application made by Discord Inc. You can download the official Discord client Here.