Preview and deploy @marko/run apps on Connect-style servers
Package Exports
@marko/run-adapter-node
@marko/run-adapter-node/middleware
Readme
@marko/run-adapter-node
Preview and deploy @marko/run apps on Connect-style servers
Intallation
npminstall @marko/run-adapter-node
Usage
In your application's Vite config file (eg. vite.config.js), import and register this adapter with the @marko/run Vite plugin:
import{ defineConfig }from"vite";import marko from"@marko/run/vite";import nodeAdapter from"@marko/run-adapter-node";exportdefaultdefineConfig({
plugins:[marko({
adapter:nodeAdapter(),}),],});
Middleware
This package provides two different middlwares. Both middleware handle converting Connect-style requests to WHATWG requests and similarly writing WHATWG responses back to the Connect response.
Router Middleware
This middleware fully handles requests that match a route.
This middleware attaches the matched route onto the request object where it can be invoked later. Along with an invoke function, the object will contain the route's meta data. This is useful if you have other middleware that need to run between finding a match and invoking the route.
// my-app-server.tsimport express from"express";import{ matchMiddleware }from"@marko/run-adapter-node/middleware";express().use("/assets", express.static("assets")).use(matchMiddleware())// register the match middlware// ...other middleware here.use((req, res, next)=>{// `req.route` will be populated if the match middlware found a routeif(req.route){// do something with `req.route.config` which will contain the route's meta data}next();}).use((req, res, next)=>{if(req.route){// finally invoke the route handler
req.route.invoke(req, res, next);}else{next();}}).listen(8080);
Build and Dev
For now, check out the examples directory for more info.