2019-08-01 00:08:37 +02:00
|
|
|
|
# code-server · [![MIT license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/cdr/code-server/blob/master/LICENSE) [!["Latest Release"](https://img.shields.io/github/release/cdr/code-server.svg)](https://github.com/cdr/code-server/releases/latest) [![Build Status](https://img.shields.io/travis/com/cdr/code-server/master)](https://github.com/cdr/code-server)
|
2019-01-08 01:46:19 +01:00
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
`code-server` is [VS Code](https://github.com/Microsoft/vscode) running on a
|
|
|
|
|
remote server, accessible through the browser.
|
2019-03-06 02:45:21 +01:00
|
|
|
|
|
2019-03-07 03:59:43 +01:00
|
|
|
|
Try it out:
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-03-07 03:59:43 +01:00
|
|
|
|
```bash
|
2019-09-17 19:27:32 +02:00
|
|
|
|
docker run -it -p 127.0.0.1:8080:8080 -v "${HOME}/.local/share/code-server:/home/coder/.local/share/code-server" -v "$PWD:/home/coder/project" codercom/code-server:v2
|
2019-03-07 03:59:43 +01:00
|
|
|
|
```
|
|
|
|
|
|
2019-08-01 00:08:37 +02:00
|
|
|
|
- **Consistent environment:** Code on your Chromebook, tablet, and laptop with a
|
|
|
|
|
consistent dev environment. develop more easily for Linux if you have a
|
|
|
|
|
Windows or Mac, and pick up where you left off when switching workstations.
|
|
|
|
|
- **Server-powered:** Take advantage of large cloud servers to speed up tests,
|
|
|
|
|
compilations, downloads, and more. Preserve battery life when you're on the go
|
|
|
|
|
since all intensive computation runs on your server.
|
2019-03-04 19:31:27 +01:00
|
|
|
|
|
2019-07-22 17:21:15 +02:00
|
|
|
|
![Screenshot](/doc/assets/ide.gif)
|
2019-03-04 19:31:27 +01:00
|
|
|
|
|
|
|
|
|
## Getting Started
|
2019-09-18 20:21:38 +02:00
|
|
|
|
|
|
|
|
|
### Requirements
|
|
|
|
|
|
|
|
|
|
- Minimum GLIBC version of 2.17 and a minimum version of GLIBCXX of 3.4.15.
|
|
|
|
|
- This is the main requirement for building Visual Studio Code. We cannot go lower than this.
|
|
|
|
|
- A 64-bit host with at least 1GB RAM and 2 cores.
|
2019-09-27 16:39:29 +02:00
|
|
|
|
- 1 core hosts would work but not optimally.
|
2019-09-18 20:21:38 +02:00
|
|
|
|
- Docker (for Docker versions of `code-server`).
|
|
|
|
|
|
2019-04-20 03:20:31 +02:00
|
|
|
|
### Run over SSH
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-04-20 03:22:00 +02:00
|
|
|
|
Use [sshcode](https://github.com/codercom/sshcode) for a simple setup.
|
2019-04-20 03:20:31 +02:00
|
|
|
|
|
2019-03-07 03:59:43 +01:00
|
|
|
|
### Docker
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-08-01 00:08:37 +02:00
|
|
|
|
See the Docker one-liner mentioned above. Dockerfile is at [/Dockerfile](/Dockerfile).
|
2019-03-07 03:59:43 +01:00
|
|
|
|
|
2019-07-23 22:38:00 +02:00
|
|
|
|
To debug Golang using the
|
|
|
|
|
[ms-vscode-go extension](https://marketplace.visualstudio.com/items?itemName=ms-vscode.Go),
|
|
|
|
|
you need to add `--security-opt seccomp=unconfined` to your `docker run`
|
|
|
|
|
arguments when launching code-server with Docker. See
|
|
|
|
|
[#725](https://github.com/cdr/code-server/issues/725) for details.
|
2019-03-04 19:31:27 +01:00
|
|
|
|
|
2019-09-13 17:17:27 +02:00
|
|
|
|
### Digital Ocean
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-09-13 17:17:27 +02:00
|
|
|
|
[![Create a Droplet](./doc/assets/droplet.svg)](https://marketplace.digitalocean.com/apps/code-server?action=deploy)
|
|
|
|
|
|
2019-10-24 23:08:44 +02:00
|
|
|
|
### Google Cloud
|
|
|
|
|
|
|
|
|
|
[![Run on Google Cloud](https://storage.googleapis.com/cloudrun/button.svg)](https://deploy.cloud.run?dir=gcloud/)
|
|
|
|
|
|
2019-07-23 22:38:00 +02:00
|
|
|
|
### Binaries
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-08-01 00:08:37 +02:00
|
|
|
|
1. [Download a binary](https://github.com/cdr/code-server/releases). (Linux and
|
2019-09-27 16:39:29 +02:00
|
|
|
|
OS X supported. Windows coming soon)
|
2019-07-23 22:38:00 +02:00
|
|
|
|
2. Unpack the downloaded file then run the binary.
|
2019-08-08 18:21:45 +02:00
|
|
|
|
3. In your browser navigate to `localhost:8080`.
|
2019-01-08 01:46:19 +01:00
|
|
|
|
|
2019-07-23 22:38:00 +02:00
|
|
|
|
- For self-hosting and other information see [doc/quickstart.md](doc/quickstart.md).
|
|
|
|
|
- For hosting on cloud platforms see [doc/deploy.md](doc/deploy.md).
|
2019-03-04 19:31:27 +01:00
|
|
|
|
|
2019-10-23 18:54:47 +02:00
|
|
|
|
### Build
|
|
|
|
|
|
|
|
|
|
See
|
|
|
|
|
[VS Code prerequisites](https://github.com/Microsoft/vscode/wiki/How-to-Contribute#prerequisites)
|
|
|
|
|
before building.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
export OUT=/path/to/output/build # Optional if only building. Required if also developing.
|
|
|
|
|
yarn build ${vscodeVersion} ${codeServerVersion} # See travis.yml for the VS Code version to use.
|
|
|
|
|
# The code-server version can be anything you want.
|
|
|
|
|
node ~/path/to/output/build/out/vs/server/main.js # You can run the built JavaScript with Node.
|
|
|
|
|
yarn binary ${vscodeVersion} ${codeServerVersion} # Or you can package it into a binary.
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-23 18:49:05 +02:00
|
|
|
|
## Security
|
|
|
|
|
|
|
|
|
|
### Authentication
|
2019-10-24 19:35:26 +02:00
|
|
|
|
By default `code-server` enables password authentication using a randomly
|
|
|
|
|
generated password. You can set the `PASSWORD` environment variable to use your
|
|
|
|
|
own instead or use `--auth none` to disable password authentication.
|
2019-10-23 18:49:05 +02:00
|
|
|
|
|
|
|
|
|
Do not expose `code-server` to the open internet without some form of
|
|
|
|
|
authentication.
|
|
|
|
|
|
|
|
|
|
### Encrypting traffic with HTTPS
|
|
|
|
|
If you aren't doing SSL termination elsewhere you can directly give
|
|
|
|
|
`code-server` a certificate with `code-server --cert` followed by the path to
|
|
|
|
|
your certificate. Additionally, you can use certificate keys with `--cert-key`
|
|
|
|
|
followed by the path to your key. If you pass `--cert` without any path
|
|
|
|
|
`code-server` will generate a self-signed certificate.
|
|
|
|
|
|
|
|
|
|
If `code-server` has been passed a certificate it will also respond to HTTPS
|
|
|
|
|
requests and will redirect all HTTP requests to HTTPS. Otherwise it will respond
|
|
|
|
|
only to HTTP requests.
|
|
|
|
|
|
|
|
|
|
You can use [Let's Encrypt](https://letsencrypt.org/) to get an SSL certificate
|
|
|
|
|
for free.
|
|
|
|
|
|
|
|
|
|
Do not expose `code-server` to the open internet without SSL, whether built-in
|
|
|
|
|
or through a proxy.
|
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
## Known Issues
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-03-07 22:23:16 +01:00
|
|
|
|
- Creating custom VS Code extensions and debugging them doesn't work.
|
2019-07-23 22:38:00 +02:00
|
|
|
|
- Extension profiling and tips are currently disabled.
|
2019-03-04 19:31:27 +01:00
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
## Future
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-03-27 23:05:44 +01:00
|
|
|
|
- **Stay up to date!** Get notified about new releases of code-server.
|
|
|
|
|
![Screenshot](/doc/assets/release.gif)
|
2019-03-04 19:31:27 +01:00
|
|
|
|
- Windows support.
|
2019-03-14 23:32:18 +01:00
|
|
|
|
- Electron and Chrome OS applications to bridge the gap between local<->remote.
|
2019-03-04 19:31:27 +01:00
|
|
|
|
- Run VS Code unit tests against our builds to ensure features work as expected.
|
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
## Extensions
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
|
|
|
|
code-server does not provide access to the official
|
|
|
|
|
[Visual Studio Marketplace](https://marketplace.visualstudio.com/vscode). Instead,
|
|
|
|
|
Coder has created a custom extension marketplace that we manage for open-source
|
|
|
|
|
extensions. If you want to use an extension with code-server that we do not have
|
|
|
|
|
in our marketplace please look for a release in the extension’s repository,
|
|
|
|
|
contact us to see if we have one in the works or, if you build an extension
|
|
|
|
|
locally from open source, you can copy it to the `extensions` folder. If you
|
|
|
|
|
build one locally from open-source please contribute it to the project and let
|
|
|
|
|
us know so we can give you props! If you have your own custom marketplace, it is
|
|
|
|
|
possible to point code-server to it by setting the `SERVICE_URL` and `ITEM_URL`
|
|
|
|
|
environment variables.
|
2019-03-22 20:58:13 +01:00
|
|
|
|
|
2019-04-18 00:18:35 +02:00
|
|
|
|
## Telemetry
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-07-23 22:38:00 +02:00
|
|
|
|
Use the `--disable-telemetry` flag to completely disable telemetry. We use the
|
|
|
|
|
data collected to improve code-server.
|
2019-04-18 00:18:35 +02:00
|
|
|
|
|
2019-03-04 19:31:27 +01:00
|
|
|
|
## Contributing
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-07-16 21:57:02 +02:00
|
|
|
|
### Development
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-10-23 00:49:38 +02:00
|
|
|
|
See
|
|
|
|
|
[VS Code prerequisites](https://github.com/Microsoft/vscode/wiki/How-to-Contribute#prerequisites)
|
|
|
|
|
before developing.
|
|
|
|
|
|
2019-07-23 22:38:00 +02:00
|
|
|
|
```shell
|
2019-07-16 21:57:02 +02:00
|
|
|
|
git clone https://github.com/microsoft/vscode
|
|
|
|
|
cd vscode
|
2019-10-19 02:10:55 +02:00
|
|
|
|
git checkout ${vscodeVersion} # See travis.yml for the version to use.
|
|
|
|
|
yarn
|
2019-07-16 21:57:02 +02:00
|
|
|
|
git clone https://github.com/cdr/code-server src/vs/server
|
|
|
|
|
cd src/vs/server
|
|
|
|
|
yarn
|
2019-10-19 02:10:55 +02:00
|
|
|
|
yarn patch:apply
|
2019-07-16 21:57:02 +02:00
|
|
|
|
yarn watch
|
|
|
|
|
# Wait for the initial compilation to complete (it will say "Finished compilation").
|
2019-07-20 01:45:13 +02:00
|
|
|
|
# Run the next command in another shell.
|
2019-07-23 22:38:00 +02:00
|
|
|
|
yarn start
|
2019-08-08 18:21:45 +02:00
|
|
|
|
# Visit http://localhost:8080
|
2019-07-16 21:57:02 +02:00
|
|
|
|
```
|
|
|
|
|
|
2019-08-03 02:26:41 +02:00
|
|
|
|
If you run into issues about a different version of Node being used, try running
|
|
|
|
|
`npm rebuild` in the VS Code directory and ignore the error at the end from
|
|
|
|
|
`vscode-ripgrep`.
|
|
|
|
|
|
2019-07-16 21:57:02 +02:00
|
|
|
|
### Upgrading VS Code
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-08-30 02:05:48 +02:00
|
|
|
|
We patch VS Code to provide and fix some functionality. As the web portion of VS
|
|
|
|
|
Code matures, we'll be able to shrink and maybe even entirely eliminate our
|
|
|
|
|
patch. In the meantime, however, upgrading the VS Code version requires ensuring
|
|
|
|
|
that the patch still applies and has the intended effects.
|
2019-01-08 01:46:19 +01:00
|
|
|
|
|
2019-07-16 21:57:02 +02:00
|
|
|
|
To generate a new patch, **stage all the changes** you want to be included in
|
|
|
|
|
the patch in the VS Code source, then run `yarn patch:generate` in this
|
|
|
|
|
directory.
|
2019-01-08 01:46:19 +01:00
|
|
|
|
|
2019-07-22 23:01:32 +02:00
|
|
|
|
Our changes include:
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-08-30 02:05:48 +02:00
|
|
|
|
- Change the remote schema to `code-server`.
|
2019-08-01 00:08:37 +02:00
|
|
|
|
- Allow multiple extension directories (both user and built-in).
|
2019-08-12 17:30:02 +02:00
|
|
|
|
- Modify the loader, websocket, webview, service worker, and asset requests to
|
|
|
|
|
use the URL of the page as a base (and TLS if necessary for the websocket).
|
2019-10-23 20:12:11 +02:00
|
|
|
|
- Send client-side telemetry through the server.
|
|
|
|
|
- Add an upload service along with a file prefix to ignore for temporary files
|
|
|
|
|
created during upload.
|
2019-08-30 02:05:48 +02:00
|
|
|
|
- Make changing the display language work.
|
2019-08-01 00:08:37 +02:00
|
|
|
|
- Make it possible for us to load code on the client.
|
2019-10-23 20:12:11 +02:00
|
|
|
|
- Make extensions work in the browser.
|
|
|
|
|
- Fix getting permanently disconnected when you sleep or hibernate for a while.
|
|
|
|
|
- Make it possible to automatically update the binary.
|
2019-07-22 23:01:32 +02:00
|
|
|
|
|
2019-07-16 21:57:02 +02:00
|
|
|
|
## License
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-03-04 19:31:27 +01:00
|
|
|
|
[MIT](LICENSE)
|
2019-01-08 01:46:19 +01:00
|
|
|
|
|
2019-03-04 19:31:27 +01:00
|
|
|
|
## Enterprise
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
Visit [our enterprise page](https://coder.com/enterprise) for more information
|
|
|
|
|
about our enterprise offering.
|
2019-03-04 21:27:46 +01:00
|
|
|
|
|
|
|
|
|
## Commercialization
|
2019-09-27 16:39:29 +02:00
|
|
|
|
|
2019-07-13 01:41:56 +02:00
|
|
|
|
If you would like to commercialize code-server, please contact
|
|
|
|
|
contact@coder.com.
|