@vavite/connect
is a Vite plugin for developing and building server-side Node.js applications in the form of a Connect-compatible middleware function (req, res, next)
. For development, the middleware is plugged into Vite's development server. For production, @vavite/connect
can build a middleware, or a standalone server. You can also provide a custom server entry to be processed with Vite so that you can use Vite-specific features such as import.meta.env
.
@vavite/connect
does not support custom servers during development, check out the @vavite/reloader
package if that's your requirement.
Install vite
and @vavite/connect
as development dependencies (npm install --save-dev vite @vavite/connect
) and add @vavite/connect
to your Vite config:
import { defineConfig } from "vite";
import { vaviteConnect } from "@vavite/connect";
export default defineConfig({
plugins: [
vaviteConnect({
// Options, see below
}),
],
});
Then create an handler.ts
(or .js
) file in the root of your project that default exports a function that takes (req, res, next)
and handles the request. For example:
import type { IncomingMessage, ServerResponse } from "node:http";
import type { SirvOptions } from "@vavite/connect";
export default function handler(
req: IncomingMessage,
res: ServerResponse,
next: () => void,
) {
if (req.url === "/") {
res.setHeader("Content-Type", "text/html; charset=utf-8");
// This is plain http.Server, not Express, so res.send() is
// not available, use res.write() and res.end()
res.end("<h1>Hello, world!</h1>");
} else {
next();
}
}
export const sirvOptions: SirvOptions = {
// sirv options, optional, see below.
};
Now you can start the development server with npx vite
and visit http://localhost:3000/
to see the result.
You can build a standalone application with the entry point in dist/server.js
with npx vite build --ssr
. The application will listen to the host and port specified in the HOST
and PORT
environment variables, or 0.0.0.0:3000
by default.
Handler entry module. The default value "/handler"
will resolve to handler.js
, handler.ts
etc. in your project root.
Whether to serve client assets in development mode. Enable when developing full-stack or server-side rendering applications.
TODO: Currently HTML files are not served regardless of this setting. An option to enable it is being considered.
Whether to build a standalone application instead of a Connect-compatible middleware function to be used with a custom server.
Directory that contains client assets to be served using the sirv
package. By default it's set to null
to exclude sirv
from the build.
If you do provide a client assets directory, you can export sirvOptions
from your handler entry to customize the options. The types for the options are exported from @vavite/connect
as SirvOptions
so you don't have to install sirv
yourself.
Whether sirv
should be bundled with the application or simply be imported. You must install sirv
as a production dependency if you set this to false
.
Reminder: This section applies to production build only.
@vavite/connect
does not support custom servers during development, check out the@vavite/reloader
package for that use case.
You can provide a custom server for production with or without processing it with Vite. In this case, you will import the handler in the appropriate way (see below) and add it to your application as a middleware function. For example, in Express it would be something like app.use(handler)
.
For a custom server entry processed with Vite, build your application with npx vite build --ssr server.js
where server.js
is your custom server entry. The standalone
option has no effect when using a custom server entry like this and sirv
middleware will not be injected, you will have to handle serving client assets yourself.
If you don't want to process your custom server with Vite -maybe because you have an existing application with separate tooling- you should set standalone
to false
and import the handler from ./dist/handler.js
(or whatever your build output path is).