A HarperDB Component for proxying Edgio requests to an origin server.
- Add this extension to your HarperDB project using your package manager:
npm install git+ssh://git@github.com:tristanlee85/harperdb-proxy-transform.git --save
# or
yarn add git+ssh://git@github.com:tristanlee85/harperdb-proxy-transform.git
# or
pnpm add git+ssh://git@github.com:tristanlee85/harperdb-proxy-transform.git
- Add to
config.yaml
:
'harperdb-proxy-transform':
package: 'harperdb-proxy-transform'
files: /*
outputDir: ./handlers
defaultOrigin: origin
handlers:
myComputeHandler:
type: compute
path: 'src/handlers/myComputeHandler.ts'
always: true # optional, defaults to false
myProxyHandler:
type: proxy
path: 'src/handlers/myProxyHandler.ts'
origin: origin
- Bundle the handlers:
npx hdb-proxy bundle
- Run your app with HarperDB:
harperdb run .
edgioConfigPath
: The path to theedgio.config.js
file.outputDir
: The directory to output the generated handlers to.defaultOrigin
: The origin to use if no origin is specified in the request.handlers
: The handlers to be used.handlers[name]
: The handler to be used.handlers[name].type
: The type of handler to be used (compute
orproxy
).handlers[name].path
: The path to the handler file to be bundled.handlers[name].always
: Whether the handler should be applied to all requests.handlers[name].origin
: The origin to use for the handler (only applies toproxy
handlers).
Handlers are the core of this component. They are the functions that will be used to transform the request and response of a proxied request, or to perform a compute operation.
-
compute
: A compute handler is a function that will be invoked for a given request. It can be used to write to the provided response, or to perform a compute operation such as setting request headers, or modifying the request body. This file must export a default function that takes arequest
andresponse
as arguments.export default async function computeHandler(request, response) { // ... }
-
proxy
: A proxy handler allows you to define transformations to the request and response of a proxied request. This handler may export atransformRequest
function that will be used to transform the request before it is sent to the origin server. It may also export atransformResponse
function that will be used to transform the response after it is received from the origin server. If the handler has a default export, it will be used as thetransformResponse
function.// src/handlers/myProxyHandler.ts export default async function proxyHandler(response, request, rawBody) { // This handler will be used to transform the response after it is received from the origin server. // ... } // src/handlers/myOtherProxyHandler.ts export async function transformRequest(request) { // This handler will be used to transform the request before it is sent to the origin server. // ... } export async function transformResponse(response, request, rawBody) { // This handler will be used to transform the response after it is received from the origin server. // ... }
This component uses Bun
to bundle the handlers that will be used for
compute and proxying requests, including any transformations to the request or response.
To bundle the handlers, run the following command:
npx hdb-proxy bundle
This will infer the handlers to be used from the config.yaml
file, and bundle them into the outputDir
directory.
-o, --out
: The directory to output the generated handlers to.-f, --format
: The format of the bundle (esm
orcjs
).
This component is built using Bun
. To get started, install Bun globally:
npm install -g bun
Then, run the following command to build the extension:
bun run build
This will create a dist
directory with the built extension bundled for Node.js.
If you are developing, you can use the watch
script to automatically rebuild the extension when you make changes to the source code.
bun run watch