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

fedsdk

v0.1.1

Published

US ABA routing number validation against FedACH + Fedwire directories

Readme

fedsdk

US ABA routing number validation against live FedACH + Fedwire directories.

npm license

Install

npm install fedsdk
# or
bun add fedsdk

Usage

import { validate, validateABA, lookup } from 'fedsdk'

// Full validate: ABA checksum + directory lookup
validate('021000021')
// { valid: true, result: { routingNumber: '021000021', name: 'JPMORGAN CHASE', ach: true, wire: true, networks: ['ACH', 'Fedwire'] } }

// Checksum only (no directory hit)
validateABA('021000021') // true
validateABA('021000022') // false

// Directory lookup only
lookup('021000021')
// { routingNumber: '021000021', name: 'JPMORGAN CHASE', ach: true, wire: true, networks: ['ACH', 'Fedwire'] }

lookup('000000000') // null — not in directory

Browser / Edge / Lightweight Usage

To use only the checksum validation (e.g., in browsers, Cloudflare Workers, Edge functions) without importing Node.js modules or loading the 750KB database, import from the ./validate subpath:

import { validateABA } from 'fedsdk/validate'

validateABA('021000021') // true

API

validate(rn: string): ValidationResult

Runs ABA checksum and directory lookup. Returns { valid: false, result: null } if checksum fails; result is null if the number is not in the FedACH/Fedwire directories even when the checksum passes.

validateABA(rn: string): boolean

ABA mod-10 checksum only — no network or file I/O. Fast, synchronous.

lookup(rn: string): LookupResult | null

Directory lookup only. Returns null if routing number is not found.

Types

interface LookupResult {
  routingNumber: string
  name: string
  ach: boolean      // present in FedACH directory
  wire: boolean     // present in Fedwire directory
  networks: ('ACH' | 'Fedwire')[]
}

interface ValidationResult {
  valid: boolean
  result: LookupResult | null
}

Data

Routing number data is sourced from the Federal Reserve's FedACH and Fedwire directories, mirrored by moov-io/fed. The dataset (~19,000 routing numbers) ships bundled with the package.

To refresh the data manually:

npm run sync

License

MIT — see LICENSE