Skip to content
This repository has been archived by the owner on Dec 30, 2024. It is now read-only.

Watch and execute TypeScript processes alongside your Astro development server. Useful for mocking, WebSocket, bundler…

License

Notifications You must be signed in to change notification settings

JulianCataldo/astro-sidecar

Repository files navigation

🚀  Astro Sidecar

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.

📦  Installation

pnpm astro add astro-sidecar
pnpm i -D tsx

🛠  Usage

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',
				// ...
			],
		}),
	],
});

🎉  Result

demo-cli-01.mp4

🕹  Live Demo

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:

Open in StackBlitz

— OR — locally:

pnpx degit https://github.com/JulianCataldo/astro-sidecar/demo ./demo
pnpm dev

🤷🏼‍♂️  But… why?

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:

Need to find a way to relay process termination.
For now, doing CTRL + C two times is bearable.

WebSocket

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.

Mock server / API endpoint (exotic server framework)

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…

Additional / exotic bundlers

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:


Find this project useful?

GitHub

🔗  JulianCataldo.com

About

Watch and execute TypeScript processes alongside your Astro development server. Useful for mocking, WebSocket, bundler…

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published