JSPM

fastify-hyperdrive

3.0.1
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 5
  • Score
    100M100P100Q38280F
  • License AGPL-3.0

Serve files from Hyperdrive as a fastify route

Package Exports

  • fastify-hyperdrive

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (fastify-hyperdrive) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

fastify-hyperdrive

Serve files from Hyperdrive as a fastify route

Usage

npm i --save fastify-hyperdrive

# or

yarn add fastify-hyperdrive
const fastifyHyperdrive = require('fastify-hyperdrive')

// Make a function that maps keys to hyperdrive instances
// Make sure you have networking set up for them
// Either use `drive.promises` from the stock Hyperdrive repo
// Or use the Hyperdrive constructor from dat-sdk
// Check out `test.js` for more info
async function getHyperdrive(key) {
  // If you use the stock version of hyperdrive
  return hyperdrive(key).promises
  // Or if you use dat-sdk or hyperdrive-promise
  return hyperdrive(key)
}

fastify.get('/:key/*`, fastifyHyperdrive(getHyperdrive))
// This might be needed for Range requests?
fastify.head('/:key/*', fastifyHyperdrive(getHyperdrive))

API

fastifyHyperdrive(async getHyperdrive(key)) => (request, reply) => Promise

Create a route handler for fastify which will resolve paths within hyperdrives. The return value is the callback expected in fastify.get()