Remote development environments on your infrastructure
Go to file
Colin Adler 15157c1c40
chore: add network integration test suite scaffolding (#13072)
* chore: add network integration test suite scaffolding

* dean comments
2024-04-26 17:48:41 +00:00
.devcontainer chore: revert nix dogfood image (#11022) 2023-12-05 09:02:57 +00:00
.github chore(scripts): implement mainline and stable release channels (#13048) 2024-04-24 19:43:11 +00:00
.vscode fix: add tests and improve accessibility for useClickable (#12218) 2024-02-21 10:59:13 -05:00
agent fix(agent): keep track of lastReportIndex between invocations of reportLifecycle() (#13075) 2024-04-25 16:54:51 +01:00
apiversion fix(enterprise/coderd): check provisionerd API version on connection (#12191) 2024-02-16 18:43:07 +00:00
buildinfo fix: consider all 'devel' builds as 'dev' builds (#9794) 2023-09-25 13:59:49 -05:00
cli fix(cli): scaletest: ignore errors syncing output (#13076) 2024-04-26 09:18:33 +01:00
cmd chore: remove middleware to request version and entitlement warnings (#12750) 2024-03-25 15:01:42 -04:00
coderd feat: add switch http(s) button to error page (#12942) 2024-04-26 11:52:53 -04:00
codersdk feat: specify a custom "terms of service" link (#13068) 2024-04-25 16:36:51 -06:00
cryptorand chore: add /v2 to import module path (#9072) 2023-08-18 18:55:43 +00:00
docs chore(docs): add note regarding Apr 26 scaletest (#13085) 2024-04-26 17:06:36 +01:00
dogfood chore: upgrade go to `1.21.9` (#12861) 2024-04-03 13:20:26 -05:00
enterprise feat: specify a custom "terms of service" link (#13068) 2024-04-25 16:36:51 -06:00
examples chore(docs): fix broken links (#13056) 2024-04-24 11:21:22 +03:00
helm chore: helm golden file test log output on failure (#12661) 2024-03-19 16:01:54 +00:00
offlinedocs chore: sort imports in our typescript code (#12417) 2024-03-05 16:31:22 -07:00
provisioner feat: add owner groups to workspace data (#12841) 2024-04-05 15:06:17 -04:00
provisionerd fix: separate signals for passive, active, and forced shutdown (#12358) 2024-03-15 13:16:36 +00:00
provisionersdk chore: add date information to windows startup logs (#12905) 2024-04-10 09:41:05 -05:00
pty fix: make terminal raw in ssh command on windows (#12990) 2024-04-17 18:01:20 +00:00
scaletest chore: apply shellcheck recommendation which was causing "make lint" to fail locally (#12972) 2024-04-16 13:06:08 +02:00
scripts chore(scripts): auto create autoversion PR from release script (#13074) 2024-04-26 12:53:22 +03:00
site feat: add switch http(s) button to error page (#12942) 2024-04-26 11:52:53 -04:00
support fix(support): correctly rename existing agent connection info, add real netcheck (#12946) 2024-04-12 09:40:04 +01:00
tailnet chore: add network integration test suite scaffolding (#13072) 2024-04-26 17:48:41 +00:00
testutil chore: consolidate various randomPort() implementations (#12362) 2024-02-29 12:51:44 +00:00
.dockerignore chore: experiment building dogfood image with nix (#11680) 2024-01-31 14:27:11 +00:00
.editorconfig chore: Improve project-wide prettier formatting and ignored files (#5505) 2023-01-03 15:11:13 +02:00
.git-blame-ignore-revs chore: add #9555 to .git-blame-ignore-revs (#9557) 2023-09-06 13:10:58 -06:00
.gitattributes feat: add support for optional external auth providers (#12021) 2024-02-21 11:18:38 -07:00
.gitignore chore(site): remove xstate (#10659) 2023-11-14 18:34:38 +00:00
.golangci.yaml chore: enable exhaustruct linter for database param structs (#9995) 2023-10-03 09:23:45 +01:00
.prettierignore feat: support v2 Tailnet API in AGPL coordinator (#11010) 2023-12-06 15:04:28 +04:00
.prettierignore.include feat: support v2 Tailnet API in AGPL coordinator (#11010) 2023-12-06 15:04:28 +04:00
.prettierrc.yaml chore: format code with semicolons when using prettier (#9555) 2023-09-06 12:59:26 -06:00
.swaggo chore: add /v2 to import module path (#9072) 2023-08-18 18:55:43 +00:00
LICENSE chore: Add license (#841) 2022-04-04 11:55:06 -05:00
LICENSE.enterprise Add Enterprise License text (#3932) 2022-09-07 16:55:57 +00:00
Makefile feat: add switch http(s) button to error page (#12942) 2024-04-26 11:52:53 -04:00
README.md chore(README): add contributing section to readme (#13059) 2024-04-24 22:15:14 +03:00
SECURITY.md chore(docs): update docs for correct use of shell and console and enforce linewidth (#9245) 2023-08-23 12:27:57 +03:00
coder.env docs: align CODER_HTTP_ADDRESS with document (#10779) 2023-11-19 15:38:39 +00:00
docker-compose.yaml fix: use `CODER_HTTP_ADDRESS` in `docker-compose.yml` (#7185) 2023-04-18 11:44:41 -05:00
flake.lock chore: nix shell to support playwright e2e tests (#12917) 2024-04-10 14:08:25 -05:00
flake.nix chore: nix shell to support playwright e2e tests (#12917) 2024-04-10 14:08:25 -05:00
go.mod chore(scripts): add script to promote mainline to stable (#13054) 2024-04-24 22:59:22 +03:00
go.sum chore(scripts): add script to promote mainline to stable (#13054) 2024-04-24 22:59:22 +03:00
install.sh fix(install.sh): remove extracted files after installation (#12879) 2024-04-05 19:04:12 +03:00
package.json chore: add package manager (#12551) 2024-03-12 10:44:23 -03:00
pnpm-lock.yaml docs: ui option for adding licenses (#9322) 2023-08-24 22:23:59 -05:00
release.key feat: PGP sign the checksum file in releases (#5757) 2023-01-18 04:45:27 +10:00
shell.nix chore: Add nix shell for simple development setup (#3399) 2022-08-08 15:49:12 +00:00

README.md

Self-Hosted Cloud Development Environments



Quickstart | Docs | Why Coder | Enterprise

discord release godoc Go Report Card license

Coder enables organizations to set up development environments in their public or private cloud infrastructure. Cloud development environments are defined with Terraform, connected through a secure high-speed Wireguard® tunnel, and are automatically shut down when not in use to save on costs. Coder gives engineering teams the flexibility to use the cloud for workloads that are most beneficial to them.

  • Define cloud development environments in Terraform
    • EC2 VMs, Kubernetes Pods, Docker Containers, etc.
  • Automatically shutdown idle resources to save on costs
  • Onboard developers in seconds instead of days

Quickstart

The most convenient way to try Coder is to install it on your local machine and experiment with provisioning cloud development environments using Docker (works on Linux, macOS, and Windows).

# First, install Coder
curl -L https://coder.com/install.sh | sh

# Start the Coder server (caches data in ~/.cache/coder)
coder server

# Navigate to http://localhost:3000 to create your initial user,
# create a Docker template, and provision a workspace

Install

The easiest way to install Coder is to use our install script for Linux and macOS. For Windows, use the latest ..._installer.exe file from GitHub Releases.

curl -L https://coder.com/install.sh | sh

You can run the install script with --dry-run to see the commands that will be used to install without executing them. Run the install script with --help for additional flags.

See install for additional methods.

Once installed, you can start a production deployment with a single command:

# Automatically sets up an external access URL on *.try.coder.app
coder server

# Requires a PostgreSQL instance (version 13 or higher) and external access URL
coder server --postgres-url <url> --access-url <url>

Use coder --help to get a list of flags and environment variables. Use our install guides for a full walkthrough.

Documentation

Browse our docs here or visit a specific section below:

  • Templates: Templates are written in Terraform and describe the infrastructure for workspaces
  • Workspaces: Workspaces contain the IDEs, dependencies, and configuration information needed for software development
  • IDEs: Connect your existing editor to a workspace
  • Administration: Learn how to operate Coder
  • Enterprise: Learn about our paid features built for large teams

Support

Feel free to open an issue if you have questions, run into bugs, or have a feature request.

Join our Discord to provide feedback on in-progress features, and chat with the community using Coder!

Integrations

We are always working on new integrations. Feel free to open an issue to request an integration. Contributions are welcome in any official or community repositories.

Official

Community

Contributing

We are always happy to see new contributors to Coder. If you are new to the Coder codebase, we have a guide on how to get started. We'd love to see your contributions!