@squawk/icao-registry
v0.3.3
Published
FAA ICAO hex address to aircraft registration and info lookup
Downloads
1,142
Maintainers
Readme
Resolves a 24-bit ICAO hex address to its aircraft registration and info. Pure logic library - contains no bundled data. Accepts an array of AircraftRegistration records at initialization. For zero-config use, pair with @squawk/icao-registry-data. Includes FAA ReleasableAircraft ZIP parsing utilities for consumers who want to fetch their own fresh data.
Part of the @squawk aviation library suite. See all packages on npm.
Installation
npm install @squawk/icao-registryUsage
With bundled data (zero-config)
npm install @squawk/icao-registry-dataimport { usBundledRegistry } from '@squawk/icao-registry-data';
import { createIcaoRegistry } from '@squawk/icao-registry';
const registry = createIcaoRegistry({ data: usBundledRegistry.records });
const aircraft = registry.lookup('A004B3');With fresh FAA data
import { createIcaoRegistry, parseFaaRegistryZip } from '@squawk/icao-registry';
const zipBuffer = await fetch('https://registry.faa.gov/database/ReleasableAircraft.zip').then(
(r) => r.arrayBuffer(),
);
const data = parseFaaRegistryZip(Buffer.from(zipBuffer));
const registry = createIcaoRegistry({ data });With custom data
import { createIcaoRegistry } from '@squawk/icao-registry';
const registry = createIcaoRegistry({
data: [{ icaoHex: 'A00001', registration: 'N12345', make: 'CESSNA', model: '172S' }],
});Under active development. See the docs for current API status.
