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

@eryv/federation-server

v0.0.3

Published

Federation server — content hosting, peering protocol, community features

Downloads

37

Readme

@eryv/federation-server

Federation server for the eryv agentic AI conversation platform. Handles content hosting, the peering protocol, user accounts, and community features. This is the only component that requires hosting infrastructure — the core product (engine + frontend) works without it.

Status: Early development (0.0.1). The server skeleton is in place but API routes are not yet implemented. See the roadmap for timeline.

Overview

The federation server exposes two API surfaces:

Client-Server (C-S) API

How the frontend talks to a federation instance:

  • Content CRUD (publish, browse, search, install)
  • User authentication and profiles
  • Social features (ratings, comments, collections)
  • Instance info and rules

Server-Server (S-S) API

How federation instances talk to each other:

  • Peering (request, accept, reject)
  • Content synchronization (push, pull, since-timestamp)
  • Identity verification (vouch for users across instances)
  • Moderation signals (reports, blocks)

Design Principles

  • Separate from the core product. The engine and frontend never depend on federation being available.
  • Every instance is equal. No instance has protocol-level privileges. The main site's advantage is network effects, not protocol advantage.
  • Moderation is local. Each instance sets its own policy (NSFW rules, blocked tags, peering approval, rate limits).
  • Content is signed at origin. Published content is cryptographically signed by the origin instance.
  • Identity is per-instance. Users authenticate with their home instance (@[email protected]).

Running

# Development
pnpm dev

# Production
pnpm build && pnpm start

Docker

# Full stack (federation + postgres)
docker compose up federation-server

# Or build directly
docker build -f packages/federation-server/Dockerfile -t eryv-federation .
docker run -p 3000:3000 \
  -e DATABASE_URL=postgres://user:pass@host:5432/eryv \
  -e JWT_SECRET=change-me \
  eryv-federation

Environment Variables

| Variable | Required | Default | Description | |---|---|---|---| | DATABASE_URL | Yes | — | Postgres connection string | | PORT | No | 3000 | Server port | | NODE_ENV | No | — | Set to production for deployed instances | | INSTANCE_DOMAIN | No | — | Public domain for federation identity | | JWT_SECRET | Yes (prod) | — | Secret for auth tokens |

License

AGPL-3.0-only