@marko/run-adapter-node
TypeScript icon, indicating that this package has built-in type declarations

0.1.13 • Public • Published

Marko Run Logo
@marko/run-adapter-node

Preview and deploy @marko/run apps on Connect-style servers

Intallation

npm install @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";

export default defineConfig({
  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.

// my-app-server.ts
import express from 'express'
import { routerMiddleware } from "@marko/run-adapter-node/middleware";

express()
  .use("/assets", express.static("assets"))
  .use(routerMiddleware()) // register the router middleware
  .listen(8080);

Match Middleware

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.ts
import 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 route
    if (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.

Readme

Keywords

Package Sidebar

Install

npm i @marko/run-adapter-node

Weekly Downloads

46

Version

0.1.13

License

MIT

Unpacked Size

63.1 kB

Total Files

10

Last publish

Collaborators

  • tigt
  • ryanturnquist
  • dylanpiercey
  • ryansolid
  • mlrawlings
  • agliga