npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

fastify-firebase

v2.0.1

Published

add firebase-admin to fastify with typescript support

Readme

fastify-firebase

Fastify v5+ firebase-admin plugin. Adds a singleton firebase object to your Fastify instance with full TypeScript support.


  • Supports both camelCase and snake_case Firebase cert keys TypeScript types for both cert formats.
  • Prevents multiple Firebase app initializations (singleton)
  • Throws clear errors for missing/invalid certs
  • Works with Fastify v5+ and fastify-plugin v5+
  • Async/Promise plugin signature for modern Fastify
  • Full TypeScript support

Install

npm i fastify-firebase
# or
yarn add fastify-firebase
# or
pnpm add fastify-firebase

Usage

Add the plugin into your project using the register function, provide the cert file from Firebase console and you are done! This plugin will add the firebase namespace to your Fastify instance.

import Fastify from 'fastify';
import fastifyFirebase from 'fastify-firebase';
import firebasePrivateKeyJson from '../firebase.json'; // <-- private key file from Firebase console

const server = Fastify({ logger: true });

server.register(fastifyFirebase, firebasePrivateKeyJson); // just hook the plugin with the cert file

server.get('/getAllUsers', async (request, reply) => {
  // firebase is available on request.server.firebase
  const firebase = request.server.firebase;
  const snapshot = await firebase.firestore().collection('Users').get();
  const arrayOfUsers = snapshot.docs.map((doc) => doc.data());
  reply.send(arrayOfUsers);
});

(async () => {
  try {
    const address = await server.listen({ port: 3000 });
    console.log(`Server listening at ${address}`);
  } catch (err) {
    server.log.error(err);
    process.exit(1);
  }
})();

Migration from v1.x

  • Now requires Fastify v5+
  • Cert keys can be camelCase or snake_case
  • Only one Firebase app instance is created (singleton)
  • Plugin is now async/Promise-based

Useful links

License

Licensed under MIT.