Skip to content
This repository has been archived by the owner on Jul 1, 2024. It is now read-only.

🐻‍❄️⚗️ Experimental Nitro (unjs/nitro) preset to export a Nitro server as middleware for fastify

License

Notifications You must be signed in to change notification settings

AugustArchive/fastify-nitro

Repository files navigation

🐻‍❄️⚗️ @augu/fastify-nitro

Experimental Nitro preset to export a Nitro server as middleware for fastify

@augu/fastify-nitro is my little preset for building Nitro applications that expose a fastify server or middleware export.

Note: Why did you create this?

I made this library to easily integrate fastify with Nitro (or Nuxt 3) so I can have other handlers bound to fastify and I don't really like how server middleware works or is defined, I rather just do it at the application level, not at the meta-framework level.

Usage

$ npm i --save-dev @augu/fastify-nitro
$ yarn add -D @augu/fastify-nitro

nitro.config.ts

import { defineNitroConfig } from 'nitropack';

export default defineNitroConfig({
    preset: '@augu/fastify-nitro'
});

Nuxt Usage

To use this plugin with Nuxt 3, you just need to use NITRO_PRESET=@augu/fastify-nitro or add it in your Nuxt configuration:

export default defineNuxtConfig({
    nitro: {
        preset: '@augu/fastify-nitro'
    }
});

Base URL

This preset respects the baseURL option in the Nitropack configuration. You will need to set the prefix to be usuable so fastify knows how to use it!

nitro.config.ts

import { defineNitroConfig } from 'nitropack';

export default defineNitroConfig({
    preset: '@augu/fastify-nitro',
    baseURL: '/some-url'
});

server.js

const nitroPlugin = await import('./.output/server/index.mjs');

app.register(nitroPlugin, {
    // It has to be the same as `baseURL` in nitro.config.ts or it will
    // error.
    prefix: '/some-url'
});

Contributing

Thanks for considering contributing to @augu/fastify-nitro! Before you boop your heart out on your keyboard ✧ ─=≡Σ((( つ•̀ω•́)つ, we recommend you to do the following:

If you read both if you're a new time contributor, now you can do the following:

  • Fork me! **♡( ⁎ᵕᴗᵕ⁎ )
  • Clone your fork on your machine: git clone https://github.com/your-username/fastify-nitro
  • Create a new branch: git checkout -b some-branch-name
  • Run corepack enable and use yarn for this project
  • BOOP THAT KEYBOARD!!!! ♡┉ˏ͛ (❛ 〰 ❛)ˊˎ┉♡
  • Commit your changes onto your branch: git commit -am "add features (。>‿‿<。 )"
  • Push it to the fork you created: git push -u origin some-branch-name
  • Submit a Pull Request and then cry! 。・゚゚・(థ Д థ。)・゚゚・。

License

@augu/nitro-preset is released under the MIT License with love by Noel! 🐻‍❄️💜