Watch and execute TypeScript processes alongside your Astro development server.
Warning: Experimental. It has some rough edges.
Use cases:
- REST API mocking server
- WebSocket server
- Parallel bundlers, like Vite, Webpack, Rollup…
Features:
- Live reload of each separate process on file change
- TypeScript compilation and execution
- Pipe coloured terminal outputs to the main one
It uses tsx
+ concurrently
under the hood, and comes as an AstroJS integration.
Note: Checkout the demo with Fastify + SocketIO servers / client integration in the project repository.
pnpm astro add astro-sidecar
pnpm i -D tsx
Add as many sidecar(s) as needed in your ./astro.config.mjs
, you must setup entry points like this:
import { defineConfig } from 'astro/config';
import sidecar from 'astro-sidecar';
// https://astro.build/config
export default defineConfig({
integrations: [
//
sidecar({
entryPoints: [
//
'./src/server/websocket.ts',
'./src/server/mocking.ts',
'./src/server/exotic-bundler.ts',
// ...
],
}),
],
});
demo-cli-01.mp4
It comes with two pre-configured sidecar, server boilerplates:
- Fastify, for setting up a mocking server, a proxy…
- SocketIO server for WebSocket communication
Everything is wired up client side too, as seen in the Astro index page.
Native fetch
is used for REST API and SocketIO client for the WebSocket connection.
Web container:
— OR — locally:
pnpx degit https://github.com/JulianCataldo/astro-sidecar/demo ./demo
pnpm dev
I found myself to re-use and perfect this tiny piece of code across various Astro integrations (apps. and projects).
Here are some non-exhaustive use cases here. Of course, you can find yourself many others creative uses for this utility.
I did try other solutions, but wasn't satisfied (e.g. Vite plugins have narrower responsibilities compared to Astro hooks, meaning less power).
It's more or less the same as:
pnpm dev & pnpm tsx watch ./src/server/websocket.ts & pnpm tsx watch ./src/server/mocking.ts
One main benefit is to make it easier to follow the sequential course of events.
But there are some behaviors difference, like doing CTRL + C with the Astro
integration is killing the main process with its child processes.
The shell solution is more dependendant on OS also.
Fine with POSIX-compliant environments (macOS, linux, WSL, modern Windows PowerShell? IDK),
but can be troublesome otherwise.
It's also planned to add an option for bundling sidecars with final SSR production build.
Known issues:
tsx watch ./src/server/websocket.ts exited with code 130
- privatenumber/tsx#95 (comment)
Need to find a way to relay process termination.
For now, doing CTRL + C two times is bearable.
I had trouble running a WebSocket server alongside the Vite dev. one. It's seems to be common need for Vite-based frameworks users (see this, that, or this…).
While upgrading the server.httpServer
has worked for me, some HMR issues still arose.
Basically it's very difficult not to have the dreaded "Socket already in use" issue,
as soon as you are importing your server inside your Astro project (server-side).
I'm still investigating a way to use the ws
instance inside the main app. scope (which is the most error-prone), or at least in the astro.config.mjs
scope,
but meanwhile, this project allows to kickstart WebSocket endpoint easily, though with a different port.
Please note your are required to include (or not) the server in your final SSR app. (e.g. using the Astro dist. as a middleware).
There might be a way to streamline this part furthermore (e.g. leveraging build hooks API?, SSR assets manifest?…).
Anyway, there are also many valid reasons not to include it in the final build.
E.g. the mocking server, or the WebSocket which could be externalized in production.
Admittedly, I aim to make it possible to have an all-in-one Astro / Vite + WS solution.
You might want to spin-up a Fastify / Koa / Express / you name it, server framework,
for example you want to use a specific library only made for it.
Or add a bit of realism by using a different server origin during dev.
Or hack a proxy which is altering or caching an external API…
You have to integrate a older micro-frontend using Webpack, with Vite incompatible libraries, or you want to build an intricate module federation-like system, with total isolation for each build / processes…
Other projects:
- remark-lint-frontmatter-schema: Validate your Markdown frontmatter data against a JSON schema.
- retext-case-police: Check popular names casing. Example:
⚠️ github
→ ✅GitHub
. - Flowbite Astro Admin Dashboard: Open-source admin dashboard template built with Astro, Flowbite, and Tailwind CSS