Bumps [svelte-check](https://github.com/sveltejs/language-tools) from 3.8.6 to 4.0.2. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/sveltejs/language-tools/releases">svelte-check's releases</a>.</em></p> <blockquote> <h2>svelte-check-4.0.2</h2> <ul> <li>fix: ensure components typed through Svelte 5's <code>Component</code> interface get proper intellisense</li> </ul> <h2>svelte-check-4.0.1</h2> <ul> <li>fix: remove ancient <code>process</code> augmentation from internal <code>d.ts</code> file</li> </ul> <h2>svelte-check-4.0.0</h2> <ul> <li>chore: bump magic-string (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2476">#2476</a>)</li> <li>chore: switch from fast-glob to fdir (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2433">#2433</a>)</li> <li>fix: detect <!-- raw HTML omitted --> tag (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2482">#2482</a>)</li> <li>feat: better type checking for bindings in Svelte 5 (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2477">#2477</a>)</li> <li>feat: replace svelte-preprocess with barebones TS preprocessor (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2452">#2452</a>)</li> <li>feat: project reference support (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2463">#2463</a>)</li> </ul> <h3>Breaking changes</h3> <ul> <li>require Svelte 4 or later (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2453">#2453</a>)</li> <li>make TypeScript a peer dependency, require TS 5 or later (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2453">#2453</a>)</li> <li>require node 18 or later (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2453">#2453</a>)</li> <li><code>process</code> augmentation (declaring a <code>process.browser</code> field) was removed</li> <li>slight changes to how files are assigned to which tsconfig.json (<a href="https://redirect.github.com/sveltejs/language-tools/issues/1234">#1234</a>, <a href="https://redirect.github.com/sveltejs/language-tools/issues/2463">#2463</a>)</li> <li>slight changes to how Svelte module resolution works; <code>.svelte</code> files now take precedence over <code>.svelte.js/ts</code> files (if both exist) (<a href="https://redirect.github.com/sveltejs/language-tools/issues/2481">#2481</a>)</li> <li>language-server now forces fewer TypeScript options. Most notably <code>skipLibCheck</code> is no longer forced to <code>true</code>, which may result in <code>d.ts</code> files now being checked in your project, which they were not before, revealing type errors. Either fix those or add <code>"skipLibCheck": true</code> to your <code>tsconfig.json</code> (<a href="https://redirect.github.com/sveltejs/language-tools/issues/1976">#1976</a>, <a href="https://redirect.github.com/sveltejs/language-tools/issues/2463">#2463</a>)</li> </ul> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href=" |
||
---|---|---|
.cargo | ||
.github | ||
docker | ||
docs | ||
oidc-test | ||
tests | ||
warpgate | ||
warpgate-admin | ||
warpgate-common | ||
warpgate-core | ||
warpgate-database-protocols | ||
warpgate-db-entities | ||
warpgate-db-migrations | ||
warpgate-protocol-http | ||
warpgate-protocol-mysql | ||
warpgate-protocol-ssh | ||
warpgate-sso | ||
warpgate-web | ||
.all-contributorsrc | ||
.bumpversion.cfg | ||
.dockerignore | ||
.env | ||
.flake8 | ||
.gitignore | ||
Cargo.lock | ||
Cargo.toml | ||
clippy.toml | ||
Cranky.toml | ||
Cross.toml | ||
deny.toml | ||
justfile | ||
LICENSE | ||
README.md | ||
rust-toolchain | ||
rustfmt.toml | ||
sonar-project.properties |
Warpgate is a smart SSH, HTTPS and MySQL bastion host for Linux that doesn't need special client apps.
- Set it up in your DMZ, add user accounts and easily assign them to specific hosts and URLs within the network.
- Warpgate will record every session for you to view (live) and replay later through a built-in admin web UI.
- Not a jump host - forwards your connections straight to the target instead.
- Native 2FA and SSO support (TOTP & OpenID Connect)
- Single binary with no dependencies.
- Written in 100% safe Rust.
Getting started & downloads
- See the Getting started wiki page (or Getting started on Docker).
- Release / beta binaries
- Nightly builds

![]() |
![]() |
Project Status
The project is currently in alpha stage and is gathering community feedback. See the official roadmap for the upcoming features.
In particular, we're working on:
- Requesting admin approvals for sessions
- Support for tunneling PostgreSQL connections,
- and much more.
How it works
Warpgate is a service that you deploy on the bastion/DMZ host, which will accept SSH, HTTPS and MySQL connections and provide an (optional) web admin UI.
Run warpgate setup
to interactively generate a config file, including port bindings. See Getting started for details.
It receives connections with specifically formatted credentials, authenticates the user locally, connects to the target itself, and then connects both parties together while (optionally) recording the session.
When connecting through HTTPS, Warpgate presents a selection of available targets, and will then proxy all traffic in a session to the selected target. You can switch between targets at any time.
You manage the target and user lists and assign them to each other through the admin UI, and the session history is stored in an SQLite database (default: in /var/lib/warpgate
).
You can also use the admin web interface to view the live session list, review session recordings, logs and more.
Contributing / building from source
- You'll need Rust, NodeJS and Yarn
- Clone the repo
- Just is used to run tasks - install it:
cargo install just
- Install the admin UI deps:
just yarn
- Build the frontend:
just yarn build
- Build Warpgate:
cargo build
(optionally--release
)
The binary is in target/{debug|release}
.
Tech stack
- Rust 🦀
- HTTP:
poem-web
- Database: SQLite via
sea-orm
+sqlx
- SSH:
russh
- HTTP:
- Typescript
- Svelte
- Bootstrap
Backend API
- Warpgate admin and user facing APIs use autogenerated OpenAPI schemas and SDKs. To update the SDKs after changing the query/response structures, run
just openapi-all
.
Contributors ✨
Thanks goes to these wonderful people (emoji key):
Eugeny 💻 |
Spencer Heywood 💻 |
Andreas Piening 💻 |
Niklas 💻 |
Nooblord 💻 |
Shea Smith 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!