2019-07-24 03:38:00 +07:00
|
|
|
# code-server [!["Latest Release"](https://img.shields.io/github/release/cdr/code-server.svg)](https://github.com/cdr/code-server/releases/latest) [![MIT license](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/cdr/code-server/blob/master/LICENSE) [![Discord](https://img.shields.io/discord/463752820026376202.svg?label=&logo=discord&logoColor=ffffff&color=7389D8&labelColor=6A7EC2)](https://discord.gg/zxSwN8Z)
|
2019-01-08 07:46:19 +07:00
|
|
|
|
2019-07-13 06:41:56 +07:00
|
|
|
`code-server` is [VS Code](https://github.com/Microsoft/vscode) running on a
|
|
|
|
remote server, accessible through the browser.
|
2019-03-06 08:45:21 +07:00
|
|
|
|
2019-03-07 09:59:43 +07:00
|
|
|
Try it out:
|
|
|
|
```bash
|
2019-07-24 07:06:40 +07:00
|
|
|
docker run -it -p 127.0.0.1:8443:8443 -v "$PWD:/home/coder/project" codercom/code-server
|
2019-03-07 09:59:43 +07:00
|
|
|
```
|
|
|
|
|
2019-03-06 08:45:21 +07:00
|
|
|
- Code on your Chromebook, tablet, and laptop with a consistent dev environment.
|
2019-07-13 06:41:56 +07:00
|
|
|
- If you have a Windows or Mac workstation, more easily develop for Linux.
|
2019-03-06 08:45:21 +07:00
|
|
|
- Take advantage of large cloud servers to speed up tests, compilations, downloads, and more.
|
|
|
|
- Preserve battery life when you're on the go.
|
2019-07-13 06:41:56 +07:00
|
|
|
- All intensive computation runs on your server.
|
|
|
|
- You're no longer running excess instances of Chrome.
|
2019-03-05 01:31:27 +07:00
|
|
|
|
2019-07-22 22:21:15 +07:00
|
|
|
![Screenshot](/doc/assets/ide.gif)
|
2019-03-05 01:31:27 +07:00
|
|
|
|
|
|
|
## Getting Started
|
2019-04-20 08:20:31 +07:00
|
|
|
### Run over SSH
|
2019-04-20 08:22:00 +07:00
|
|
|
Use [sshcode](https://github.com/codercom/sshcode) for a simple setup.
|
2019-04-20 08:20:31 +07:00
|
|
|
|
2019-03-07 09:59:43 +07:00
|
|
|
### Docker
|
2019-07-13 06:41:56 +07:00
|
|
|
See docker oneliner mentioned above. Dockerfile is at
|
|
|
|
[/Dockerfile](/Dockerfile).
|
2019-03-07 09:59:43 +07:00
|
|
|
|
2019-07-24 03:38:00 +07: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-05 01:31:27 +07:00
|
|
|
|
2019-07-24 03:38:00 +07:00
|
|
|
### Binaries
|
|
|
|
1. [Download a binary](https://github.com/cdr/code-server/releases) (Linux and
|
|
|
|
OS X supported. Windows coming soon).
|
|
|
|
2. Unpack the downloaded file then run the binary.
|
|
|
|
3. In your browser navigate to `localhost:8443`.
|
2019-01-08 07:46:19 +07:00
|
|
|
|
2019-07-24 03:38:00 +07: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-05 01:31:27 +07:00
|
|
|
|
2019-07-13 06:41:56 +07:00
|
|
|
### Build
|
2019-07-16 01:23:29 +07:00
|
|
|
- If you also plan on developing, set the `OUT` environment variable:
|
|
|
|
`export OUT=/path/to/some/directory`. Otherwise it will build in this
|
|
|
|
directory which will cause issues because `yarn watch` will try to
|
2019-07-03 07:10:17 +07:00
|
|
|
compile the build directory as well.
|
2019-07-08 22:33:58 +07:00
|
|
|
- For now `@coder/nbin` is a global dependency.
|
2019-07-11 06:10:39 +07:00
|
|
|
- Run `yarn build ${codeServerVersion} ${vscodeVersion} ${target} ${arch}` in
|
2019-07-17 02:57:02 +07:00
|
|
|
this directory (for example: `yarn build development 1.36.0 linux x64`).
|
|
|
|
- If you target the same VS Code version our Travis builds do everything will
|
|
|
|
work but if you target some other version it might not (we have to do some
|
|
|
|
patching to VS Code so different versions aren't always compatible).
|
2019-07-11 06:10:39 +07:00
|
|
|
- You can run the built code with `node path/to/build/out/vs/server/main.js` or run
|
|
|
|
`yarn binary` with the same arguments in the previous step to package the
|
|
|
|
code into a single binary.
|
2019-07-02 23:33:27 +07:00
|
|
|
|
2019-07-13 06:41:56 +07:00
|
|
|
## Known Issues
|
2019-07-24 03:38:00 +07:00
|
|
|
- Uploading .vsix files doesn't work.
|
2019-03-08 04:23:16 +07:00
|
|
|
- Creating custom VS Code extensions and debugging them doesn't work.
|
2019-07-24 03:38:00 +07:00
|
|
|
- Extension profiling and tips are currently disabled.
|
2019-03-05 01:31:27 +07:00
|
|
|
|
2019-07-13 06:41:56 +07:00
|
|
|
## Future
|
2019-03-28 05:05:44 +07:00
|
|
|
- **Stay up to date!** Get notified about new releases of code-server.
|
|
|
|
![Screenshot](/doc/assets/release.gif)
|
2019-03-05 01:31:27 +07:00
|
|
|
- Windows support.
|
2019-03-15 05:32:18 +07:00
|
|
|
- Electron and Chrome OS applications to bridge the gap between local<->remote.
|
2019-03-05 01:31:27 +07:00
|
|
|
- Run VS Code unit tests against our builds to ensure features work as expected.
|
|
|
|
|
2019-07-13 06:41:56 +07:00
|
|
|
## Extensions
|
|
|
|
At the moment we can't use the official VSCode Marketplace. We've created a
|
|
|
|
custom extension marketplace focused around open-sourced extensions. However,
|
2019-07-24 03:38:00 +07:00
|
|
|
you can manually download the extension to your extensions directory. It's also
|
|
|
|
possible to host your own marketplace by setting the `SERVICE_URL` and
|
|
|
|
`ITEM_URL` environment variables.
|
2019-03-23 02:58:13 +07:00
|
|
|
|
2019-04-18 05:18:35 +07:00
|
|
|
## Telemetry
|
2019-07-24 03:38:00 +07:00
|
|
|
Use the `--disable-telemetry` flag to completely disable telemetry. We use the
|
|
|
|
data collected to improve code-server.
|
2019-04-18 05:18:35 +07:00
|
|
|
|
2019-03-05 01:31:27 +07:00
|
|
|
## Contributing
|
2019-07-17 02:57:02 +07:00
|
|
|
### Development
|
2019-07-24 03:38:00 +07:00
|
|
|
```shell
|
2019-07-17 02:57:02 +07:00
|
|
|
git clone https://github.com/microsoft/vscode
|
|
|
|
cd vscode
|
2019-07-23 04:01:32 +07:00
|
|
|
git checkout 1.36.1
|
2019-07-17 02:57:02 +07:00
|
|
|
git clone https://github.com/cdr/code-server src/vs/server
|
|
|
|
cd src/vs/server
|
|
|
|
yarn patch:apply
|
|
|
|
yarn
|
|
|
|
yarn watch
|
|
|
|
# Wait for the initial compilation to complete (it will say "Finished compilation").
|
2019-07-20 06:45:13 +07:00
|
|
|
# Run the next command in another shell.
|
2019-07-24 03:38:00 +07:00
|
|
|
yarn start
|
2019-07-17 02:57:02 +07:00
|
|
|
# Visit http://localhost:8443
|
|
|
|
```
|
|
|
|
|
|
|
|
### Upgrading VS Code
|
|
|
|
We have to 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 07:46:19 +07:00
|
|
|
|
2019-07-17 02:57:02 +07: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 07:46:19 +07:00
|
|
|
|
2019-07-23 04:01:32 +07:00
|
|
|
Our changes include:
|
|
|
|
- Add a `code-server` schema.
|
|
|
|
- Make the extension sidebar work in the browser. Mostly involves removing
|
|
|
|
Node-specific code for the `extensions` channel client and adding a
|
|
|
|
`gallery` channel.
|
|
|
|
- Allow multiple extension directories (both user and built-in).
|
|
|
|
- Rewrite assets used in the CSS (like icons) or as images to use the base URL.
|
|
|
|
- Change the loader to use the base URL.
|
2019-08-01 04:34:44 +07:00
|
|
|
- Change the web socket to use the base URL and TLS if necessary.
|
2019-07-24 03:38:00 +07:00
|
|
|
- Set the favicon using a relative path.
|
2019-07-23 04:01:32 +07:00
|
|
|
- Modify the file service to support writing from an asynchronous stream (for
|
|
|
|
uploading files).
|
|
|
|
- Add a file prefix to ignore for temporary files created during upload.
|
|
|
|
- Insert our upload service for use in editor windows and explorer.
|
|
|
|
- Modify the log level to get its initial setting from the server.
|
|
|
|
- Get telemetry working by adding a channel for it.
|
2019-08-01 04:34:44 +07:00
|
|
|
- Change a regular expression used for mnemonics so it works on Firefox.
|
|
|
|
- Make it possible for us to load code on the client.
|
2019-07-23 04:01:32 +07:00
|
|
|
|
2019-07-17 02:57:02 +07:00
|
|
|
## License
|
2019-03-05 01:31:27 +07:00
|
|
|
[MIT](LICENSE)
|
2019-01-08 07:46:19 +07:00
|
|
|
|
2019-03-05 01:31:27 +07:00
|
|
|
## Enterprise
|
2019-07-13 06:41:56 +07:00
|
|
|
Visit [our enterprise page](https://coder.com/enterprise) for more information
|
|
|
|
about our enterprise offering.
|
2019-03-05 03:27:46 +07:00
|
|
|
|
|
|
|
## Commercialization
|
2019-07-13 06:41:56 +07:00
|
|
|
If you would like to commercialize code-server, please contact
|
|
|
|
contact@coder.com.
|