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

termbeam

v1.24.5

Published

Beam your terminal to any device — mobile-optimized web terminal with multi-session support

Downloads

4,822

Readme

TermBeam

Beam your terminal to any device.

npm version npm downloads CI Coverage OpenSSF Scorecard Node.js License: MIT

TermBeam lets you access your terminal from a phone, tablet, or any browser — no SSH, no port forwarding, no configuration needed. Run one command and scan the QR code.

Full documentation · Website

https://github.com/user-attachments/assets/9dd4f3d7-f017-4314-9b3a-f6a5688e3671

Mobile UI

Quick Start

npx termbeam

Or install globally:

npm install -g termbeam
termbeam

Scan the QR code printed in your terminal, or open the URL on any device.

termbeam                        # tunnel + auto-password (default)
termbeam --password mysecret    # custom password
termbeam --no-tunnel            # LAN only
termbeam -i                     # interactive setup wizard

Features

Mobile-First

  • No SSH client needed — just open a browser on any device
  • Touch-optimized key bar with arrows, Tab, Ctrl, Esc, copy, paste, and more
  • Swipe scrolling, pinch zoom, and text selection overlay for copy-paste
  • iPhone PWA safe-area support for a native-app feel

Multi-Session

  • Tabbed terminals with drag-to-reorder and live tab previews on hover/long-press
  • Split view — two sessions side-by-side (auto-rotates horizontal/vertical)
  • Session colors and activity indicators for at-a-glance status
  • Folder browser for picking working directory, optional initial command per session

Productivity

  • Terminal search with regex, match count, and prev/next navigation
  • Tools panel (Ctrl+K / Cmd+K) — slide-out sheet for quick access to all actions, organized into Session · Files · View · Share · Agents · Settings · System. Settings (theme, font size, defaults, haptics) are inline panels reachable from the panel; on mobile the panel slides up from the bottom, on desktop it docks to the right.
  • Customizable Touch Bar — 8-column, multi-row (up to 3) key grid with drag-to-reorder, collapsible drawer, and a dedicated key editor (label, send payload, action, modifier).
  • Workspaces — save named bundles of sessions (each with its own name, cwd, shell, color and initial command). Mark one as default and the server auto-spawns it on startup, so connecting any client lands on a ready terminal. Preferences (theme, fonts, defaults, custom keys, workspaces) are persisted server-side in ~/.termbeam/prefs.json and sync across devices.
  • File upload — send files from your phone to the session's working directory
  • File browser & download — browse files in a session's working directory from the side panel and download them to your device
  • Markdown viewer — preview .md files rendered with GitHub Flavored Markdown directly in the browser
  • Git changes view — view git status, diffs, blame, and commit history in the code viewer. Toggle between Files and Changes tabs, view staged/unstaged diffs with syntax highlighting, and see per-line blame annotations
  • Push notifications — get native push notifications on your phone when commands complete, even when the app is in the background. Uses Web Push API with VAPID authentication
  • In-app updates — auto-update from the UI for npm/yarn/pnpm global installs, with copy-command fallback for other methods
  • Completion notifications — browser alerts when background commands finish
  • 30 color themes with adjustable font size
  • Port preview — reverse-proxy a local web server through TermBeam
  • Image paste from clipboard

Secure by Default

  • Auto-generated password with rate limiting and httpOnly cookies
  • QR code auto-login with single-use share tokens (5-min expiry)
  • DevTunnel integration for secure remote access — ephemeral or persisted URLs
  • Security headers (X-Frame-Options, CSP, nosniff) on all responses; only detected shells allowed

How It Works

TermBeam starts a lightweight web server that spawns a PTY (pseudo-terminal) with your shell, serves a mobile-optimized xterm.js UI via Express, and bridges the two over WebSocket. Multiple clients can view the same session simultaneously, and sessions persist when all clients disconnect.

flowchart LR
  A["Phone / Browser"] <-->|WebSocket| B["TermBeam Server"]
  B <-->|PTY| C["Shell (zsh/bash)"]
  B -->|Express| D["Web UI (xterm.js)"]
  B -.->|Optional| E["DevTunnel"]

CLI Highlights

| Flag | Description | Default | | --------------------- | ----------------------------------------------- | -------------- | | --password <pw> | Set access password | Auto-generated | | --no-password | Disable password protection | — | | --tunnel | Create an ephemeral devtunnel URL | On | | --no-tunnel | Disable tunnel (LAN-only) | — | | --persisted-tunnel | Reusable devtunnel URL (stable across restarts) | Off | | --port <port> | Server port | 3456 | | --host <addr> | Bind address | 127.0.0.1 | | --lan | Bind to all interfaces (LAN access) | Off | | --public | Allow public tunnel access (no Microsoft login) | Off | | -i, --interactive | Interactive setup wizard | Off | | --log-level <level> | Log verbosity (error/warn/info/debug) | info |

For all flags, subcommands, and environment variables, see the Configuration docs.

Background Service

Run TermBeam as an always-on background service using the built-in PM2 integration:

termbeam service install     # interactive wizard — configures PM2, password, tunnel, boot auto-start
termbeam service status      # check process info, uptime, memory
termbeam service logs        # tail live logs
termbeam service restart     # restart after config changes
termbeam service uninstall   # stop and remove the service

The installer checks for PM2 (and offers to install it), then walks you through password, port, access mode, and boot auto-start options. Config is saved to ~/.termbeam/ecosystem.config.js.

For systemd, launchd, and Windows Task Scheduler setup, see the Running in Background docs.

💡 Keep the host awake so the service stays reachable while you're away. macOS: pair with Amphetamine (process trigger on node) or wrap with caffeinate -dims. Windows: enable PowerToys Awake and disable network adapter power saving. Linux: use systemd-inhibit in your unit file. See Keeping the Host Awake for the full setup.

Security

TermBeam auto-generates a password and creates a secure tunnel by default, binding to 127.0.0.1 (localhost only). Auth uses httpOnly cookies with 24-hour expiry, login is rate-limited to 5 attempts per minute, QR codes contain single-use share tokens (5-min expiry), and security headers (X-Frame-Options, CSP, nosniff) are set on all responses.

For the full threat model and safety checklist, see SECURITY.md. For detailed security documentation, see the Security Guide.

Contributing

Contributions welcome — see CONTRIBUTING.md.

Changelog

See CHANGELOG.md for version history.

License

MIT

Acknowledgments

Special thanks to @tamirdresher for the blog post that inspired the solution idea for this project, and for his cli-tunnel implementation.