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

nedagram

v3.1.1

Published

Encode and decode text as audio signals - CLI tool for transmitting data over phone calls and audio channels

Readme

Nedagram

فارسی | English

Transfer text over sound - A Progressive Web App that encodes text into audio signals ("Neda") that can be transmitted between devices over a phone call or through speakers to microphones. Works completely without internet after the first visit.

Why Nedagram?

"Neda" is a Persian feminine given name meaning "voice," "call," or "calling"

Nedagram was built to help share text data when sending files isn't possible. By converting text to audio, you can:

  • Share config files, complex passwords, or long URLs over phone calls when internet is unavailable
  • Transfer data between air-gapped devices (private keys, signatures)
  • Off-grid communication - works anywhere with no network required
  • Fully offline after first load - no server, no tracking, no data leaves your device

How It Works

┌─────────────┐    Audio     ┌─────────────┐
│   SENDER    │    Waves     │  RECEIVER   │
│             │  ~~~~~~~~>   │             │
│  Text Input │  Speaker     │ Microphone  │
│      ↓      │     to       │      ↓      │
│  Encrypt*   │    Mic       │   Decode    │
│      ↓      │   (phone)    │      ↓      │
│  Compress   │              │  FEC Decode │
│      ↓      │              │      ↓      │
│  FEC Encode │              │  Decompress │
│      ↓      │              │      ↓      │
│  MFSK Audio │              │  Decrypt*   │
└─────────────┘              └─────────────┘
                              * if encrypted
  1. Sender enters text (config file, password, URL, etc.)
  2. Optionally encrypts data with a password
  3. App compresses and encodes data with error correction
  4. Data is modulated into audio tones (MFSK)
  5. Receiver captures audio via microphone
  6. App decodes, corrects errors, and decrypts if needed
  7. Both parties verify SHA-256 checksum matches

Features

  • Offline-First PWA - Works without internet after first load
  • End-to-End Encryption - Optional ChaCha20-Poly1305 encryption with password protection
  • Two Audio Modes
    • Phone Mode - Works over standard phone calls (300-3400 Hz)
    • Wideband Mode - Faster transmission for direct device-to-device or HD Voice
  • Error Correction - Concatenated FEC (Reed-Solomon + Convolutional with Viterbi decoding)
  • Auto-Detection - Receiver automatically detects transmission mode
  • Compression - DEFLATE compression reduces transmission time
  • Integrity Verification - SHA-256 checksum for sender/receiver verification
  • QR Code Fallback - For small payloads (< 2KB)
  • Multi-Language - English and Farsi (RTL) support
  • Downloadable Offline Package - Share the app itself without internet

Use Cases

  • Share config files, complex passwords, or long URLs over phone calls when internet is unavailable
  • Transfer data between air-gapped devices (private keys, signatures)
  • Off-grid communication - works anywhere with no network required
  • Fully offline after first load
  • No server, no tracking, no data leaves your device

Quick Start

Sending

  1. Open Nedagram on the sending device
  2. Paste your text or upload a file
  3. Select Phone (for calls) or Wideband (for direct transfer)
  4. Optionally enable Encrypt and enter a password
  5. Click Generate Audio
  6. Play the audio near the receiving device
  7. Share the SHA-256 checksum (and password if encrypted) with the receiver

Receiving

  1. Open Nedagram on the receiving device
  2. Click Start Listening
  3. Allow microphone access
  4. Wait for the transmission to complete
  5. If encrypted, enter the password to decrypt
  6. Verify the checksum matches the sender's
  7. Copy or save the decoded text

Technical Specifications

Phone Mode (Optimized for GSM/Phone Calls)

| Parameter | Value | |-----------|-------| | Modulation | 4-MFSK (2 bits/symbol) | | Tone Frequencies | 800, 1300, 1800, 2300 Hz | | Tone Spacing | 500 Hz (wide for codec tolerance) | | Symbol Duration | 50ms + 12ms guard | | Effective Bitrate | ~20-25 bps | | Synchronization | Chirp matched filter detection | | Burst Protection | Block interleaving enabled |

Wideband Mode (HD Voice / Direct)

| Parameter | Value | |-----------|-------| | Modulation | 16-MFSK (4 bits/symbol) | | Frequency Range | 1800 - 5700 Hz | | Symbol Duration | 40ms + 5ms guard | | Effective Bitrate | ~50-60 bps |

Error Correction (Concatenated FEC)

Same scheme used by NASA's Voyager spacecraft for reliable deep space communication.

| Parameter | Value | |-----------|-------| | Outer Code | Reed-Solomon with 16 parity bytes | | Inner Code | Convolutional (k=7, rate 2/3 punctured) | | Viterbi Decoding | Soft-decision, 35-symbol traceback | | Scrambling | LFSR (x^15 + x^14 + 1) for bit distribution | | Error Correction | ~8 byte errors + additional bit errors per frame |

Synchronization

| Component | Phone Mode | Wideband Mode | |-----------|------------|---------------| | Warmup Tone | 200ms steady tone | 400ms steady tone | | Chirp Sweep | 800ms (600-2600 Hz) | 1200ms (1000-4000 Hz) | | Detection | Matched filter cross-correlation | | Calibration | 4 tones × 2 repeats | 4 tones × 3 repeats | | Sync Pattern | 8-symbol alternating pattern |

Encryption (Optional)

| Parameter | Value | |-----------|-------| | Cipher | ChaCha20-Poly1305 (AEAD) | | Key Derivation | PBKDF2-SHA256 (100,000 iterations) | | Overhead | 44 bytes (16 salt + 12 nonce + 16 auth tag) |

Limits

  • Maximum payload: 100 KB
  • Recommended payload: < 50 KB
  • QR code available for payloads < 2 KB

Transmission Time Estimates

| Payload Size | Phone Mode | Wideband Mode | |--------------|------------|---------------| | 100 bytes | ~45 sec | ~20 sec | | 1 KB | ~6 min | ~2.5 min | | 10 KB | ~55 min | ~25 min |

Times are approximate and include preamble, headers, and FEC overhead. Phone mode is optimized for reliability over speed.

Tips for Best Results

  1. Quiet environment - Background noise reduces accuracy
  2. Volume at 70-80% - Too loud causes distortion, too quiet loses signal
  3. Distance 0.5-1m - Optimal range for speaker-to-microphone
  4. Keep devices steady - Movement during transmission can cause errors
  5. Verify checksum - Always compare SHA-256 to confirm integrity

Offline Distribution

You can download Nedagram for completely offline use - no internet connection needed after the initial download.

From the Website

Visit the Help page at nedagram.com and click "Download Offline Package" to get a ZIP file containing everything you need.

Direct download: nedagram.com/nedagram-offline.zip

Manual Build

# Clone and build
git clone https://github.com/shayanb/nedagram.git
cd nedagram
npm install
npm run build

# The zip file will be at dist/nedagram-offline.zip

Running Offline

  1. Extract the ZIP file to a folder
  2. Start a local web server:
    # Using Python (recommended)
    python3 -m http.server 8000 --bind 127.0.0.1
    
    # Using Node.js
    npx serve .
    
    # Using PHP
    php -S 127.0.0.1:8000
  3. Open http://127.0.0.1:8000 in your browser

Important: Use http://127.0.0.1:8000 (not [::] or localhost) for microphone access to work. For other devices on your network, use your computer's IP address (e.g., http://192.168.1.x:8000).

CLI in Offline Package

The offline package includes the CLI in the cli/ folder. Run it directly with Node.js:

node cli/index.cjs encode "Hello" -o message.wav
node cli/index.cjs decode message.wav

Command Line Interface (CLI)

Nedagram includes a CLI for encoding and decoding WAV files without a browser.

Installation

# Install globally from npm
npm install -g nedagram

# Or run directly with npx
npx nedagram --help

# Or use from the offline package (no install needed)
node cli/index.cjs --help

CLI Usage

# Encode text to WAV file
nedagram encode "Hello World" -o message.wav

# Encode from file
nedagram encode -f config.txt -o config.wav

# Encode with encryption
nedagram encode "Secret data" -o encrypted.wav -e -p "password"

# Encode with phone mode (for phone calls)
nedagram encode "Text" -o phone.wav -m phone

# Decode WAV file
nedagram decode message.wav

# Decode encrypted file
nedagram decode encrypted.wav -p "password"

# Decode to file
nedagram decode message.wav -o output.txt

# Pipe input/output
echo "Hello" | nedagram encode -o hello.wav
nedagram decode message.wav > output.txt

CLI Options

Encode: | Option | Description | |--------|-------------| | -f, --file <path> | Read input from file | | -o, --output <path> | Output WAV file path | | -m, --mode <mode> | Audio mode: phone or wideband (default) | | -e, --encrypt | Encrypt the message | | -p, --password <pwd> | Password for encryption | | -q, --quiet | Suppress progress output | | --json | Output result as JSON (includes metadata, sha256) |

Decode: | Option | Description | |--------|-------------| | -o, --output <path> | Write decoded text to file | | -p, --password <pwd> | Password for decryption | | -q, --quiet | Suppress progress output | | --json | Output result as JSON (includes message, metadata, sha256) |

Development

Prerequisites

  • Node.js 18+
  • npm

Setup

# Clone repository
git clone https://github.com/shayanb/nedagram.git
cd nedagram

# Install dependencies
npm install

# Start development server (with HTTPS for mic access)
npm run dev

# Build for production
npm run build

# Build CLI
npm run build:cli

# Run CLI (use -- to pass arguments through npm)
npm run cli -- encode "Hello" -o test.wav
# Or run directly:
./dist-cli/nedagram-cli/index.cjs encode "Hello" -o test.wav

# Run tests
npm test

# Run CLI tests
npm run test:cli

Tech Stack

  • Framework: Preact + TypeScript
  • Build Tool: Vite
  • State: Preact Signals
  • Compression: pako (DEFLATE)
  • Encryption: @noble/ciphers (ChaCha20-Poly1305)
  • Error Correction: Concatenated FEC (Reed-Solomon + Convolutional/Viterbi)
  • PWA: Service Worker with offline caching

Privacy & Security

  • Encryption - Always protect sensitive data with a password
  • Offline capable - Works without any network after first load, also has a downloadable offline package (& CLI)
  • No telemetry - No data is sent anywhere
  • No backend - Entirely client-side
  • Open source - Audit the code yourself, please do!

Browser Support

| Browser | Support | |---------|---------| | Chrome (Desktop/Android) | Full | | Firefox | Full | | Safari (macOS/iOS) | Full | | Edge | Full |

Requires microphone permission for receiving.

Reporting Bugs

If you encounter issues with decoding or any other problems, please report them on GitHub:

  1. Click the debug log button (bottom-right corner of the app) to enable logging
  2. Reproduce the issue
  3. Click "Copy" in the debug panel to copy the log
  4. If possible, click "Save Audio" to save the recorded audio file
  5. Create a GitHub issue with:
    • The debug log
    • The audio file (if available)
    • Description of what you were trying to do

Contributing

Contributions are welcome! Please feel free to submit issues and pull requests.

License

MIT License - See LICENSE for details.

Disclaimer

This software is provided "as is" for educational and research purposes. See DISCLAIMER.md for full terms.

Note: This code has not been audited. The audio encoding/decoding implementation is based on established research papers and popular codebases in the field, developed with AI assistance and guided by the author(s). Use at your own risk for sensitive applications.

Acknowledgments

Built with the goal of helping people communicate freely when traditional methods fail.


Nedagram - When internet fails, sound finds a way. :telephone_receiver: