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

@gotokens/bridge

v1.61.4

Published

Bridge server that connects Claude Agent SDK and Codex CLI sessions to mobile devices via WebSocket

Readme

@gotokens/bridge

Bridge server that connects Claude sessions powered by the Claude Agent SDK and Codex CLI to mobile devices via WebSocket.

This is the server component of ccpocket — a mobile client for Claude and Codex.

Quick Start

npx @gotokens/bridge@latest

A QR code will appear in your terminal. Scan it with the ccpocket mobile app to connect.

Warning Versions older than 1.25.0 are deprecated and should not be used for new installs because current Anthropic Claude Agent SDK docs do not permit third-party products to use Claude subscription login. Upgrade to >=1.25.0 and use ANTHROPIC_API_KEY instead of OAuth.

Installation

# Run directly (no install needed)
npx @gotokens/bridge@latest

# Or install globally
npm install -g @gotokens/bridge
gotokens-bridge

# Show CLI help or version
gotokens-bridge --help
gotokens-bridge --version

Configuration

| Environment Variable | Default | Description | |---------------------|---------|-------------| | BRIDGE_PORT | 8765 | WebSocket port | | BRIDGE_HOST | 0.0.0.0 | Bind address | | BRIDGE_API_KEY | (none) | API key authentication (enabled when set) | | BRIDGE_ALLOWED_DIRS | $HOME | Comma-separated list of project directories the Bridge may access | | BRIDGE_PUBLIC_WS_URL | (none) | Public ws:// / wss:// URL used for startup deep link and QR code | | BRIDGE_RELAY_URL | wss://nqqlcknhdxys.sealoshzh.site | Public ws:// / wss:// base URL of a relay | | BRIDGE_RELAY_TOKEN | (none) | Optional admin token used only when the relay requires trusted self-hosted registration | | BRIDGE_RELAY_ROOM_ID | $HOME/.ccpocket/bridge-identity.json | Optional override for the stable relay room id | | BRIDGE_RELAY_ROOM_SECRET | $HOME/.ccpocket/bridge-identity.json | Optional override for the stable relay room secret used by the app connection | | BRIDGE_CODEX_APP_SERVER_MODE | private | Experimental Codex app-server mode: private, managed, or external | | BRIDGE_CODEX_SHARED_APP_SERVER_URL | ws://127.0.0.1:8767 in managed mode | Experimental shared Codex app-server URL for Codex CLI co-presence | | BRIDGE_DEMO_MODE | (none) | Demo mode: hide Tailscale IPs and API key from QR code / logs | | BRIDGE_RECORDING | (none) | Enable session recording for debugging (enabled when set) | | BRIDGE_DISABLE_MDNS | (none) | Disable mDNS auto-discovery advertisement (enabled when set) | | BRIDGE_PROMPT_HISTORY_FILE | $HOME/.ccpocket/prompt-history-v2.json | Custom prompt history store path | | BRIDGE_RECENT_SESSIONS_PROFILE | (none) | Log recent-session index timing when set to 1 or true | | DIFF_IMAGE_AUTO_DISPLAY_KB | 1024 (1 MB) | Auto-display diff images up to this size, in KB | | DIFF_IMAGE_MAX_SIZE_MB | 5 (5 MB) | Maximum diff image size available for on-demand loading, in MB | | ANTHROPIC_API_KEY | (none) | Claude Agent SDK API key used for Claude sessions | | ANTHROPIC_AUTH_TOKEN | (none) | Advanced Claude SDK auth token; prefer ANTHROPIC_API_KEY | | OPENAI_API_KEY | (none) | Codex API key; Codex can also use ~/.codex/auth.json | | HTTPS_PROXY / HTTP_PROXY / ALL_PROXY | (none) | Proxy for outgoing fetch requests (http://, https://, socks4://, socks5://) |

Lowercase proxy variables (https_proxy, http_proxy, all_proxy) are also supported. When BRIDGE_PROMPT_HISTORY_FILE is not set and BRIDGE_PORT is not 8765, prompt history is stored in $HOME/.ccpocket/prompt-history-v2-<port>.json.

Push relay uses Firebase Anonymous Auth automatically; no FCM environment variables are required.

# Example: custom port with API key
BRIDGE_PORT=9000 BRIDGE_API_KEY=my-secret npx @gotokens/bridge@latest

# Example: expose Bridge through a reverse proxy / ngrok
BRIDGE_PUBLIC_WS_URL=wss://example.ngrok-free.app npx @gotokens/bridge@latest

# Example: same setting via CLI flag
gotokens-bridge --public-ws-url wss://example.ngrok-free.app

# Example: disable mDNS advertisement
BRIDGE_DISABLE_MDNS=1 npx @gotokens/bridge@latest
# or via CLI flag
gotokens-bridge --no-mdns

When BRIDGE_PUBLIC_WS_URL is set, the startup deep link and terminal QR code use that public URL instead of the LAN address. This is useful when the Bridge is reachable through a reverse proxy, tunnel, or public domain.

Without it, the printed QR code is LAN-oriented by default and typically encodes something like ws://192.168.x.x:8765.

Self-Hosted Relay

Relay mode lets the phone connect through a public WebSocket relay while the Bridge still runs on your own computer. This is useful when the phone and computer are not on the same reachable network and you do not want to set up Tailscale.

For an official-style open relay, users only need the relay URL:

BRIDGE_RELAY_URL=wss://relay.example.com \
npx @gotokens/bridge@latest

If BRIDGE_RELAY_URL is not set, Bridge uses the default public relay: wss://nqqlcknhdxys.sealoshzh.site. Set BRIDGE_RELAY_URL only when you want to override it.

Bridge stores a stable relay identity in $HOME/.ccpocket/bridge-identity.json and reuses that room id and room secret across Bridge restarts. This keeps the phone's saved relay connection URL valid as long as the same computer is running Bridge. Delete that file only when you want the computer to appear as a new relay machine.

Or with CLI flags:

gotokens-bridge --relay-url wss://relay.example.com

When registration succeeds, the Bridge prints a relay deep link and QR code. The app connects to a path like wss://relay.example.com/r/<roomId> with the room secret in the existing token query parameter. Users do not need to handle relay admin tokens in this mode.

For a trusted self-hosted relay, run the relay server on a public host with an admin token:

RELAY_ADMIN_TOKEN=change-me \
RELAY_PUBLIC_URL=wss://relay.example.com \
npm run relay

Then run the Bridge on your computer with the matching token:

BRIDGE_RELAY_URL=wss://relay.example.com \
BRIDGE_RELAY_TOKEN=change-me \
npx @gotokens/bridge@latest

Or with CLI flags:

gotokens-bridge \
  --relay-url wss://relay.example.com \
  --relay-token change-me

Existing direct LAN, Tailscale, mDNS, and BRIDGE_PUBLIC_WS_URL flows continue to work unchanged.

Loading a Bridge env file

The Bridge reads normal process environment variables. It does not parse .env files by itself, so load the file with your shell, service manager, or container runtime.

cp packages/bridge/.env.example ~/.ccpocket/bridge.env

Shell:

set -a
. ~/.ccpocket/bridge.env
set +a
npx @gotokens/bridge@latest

Installed package:

set -a
. ~/.ccpocket/bridge.env
set +a
gotokens-bridge

Security model: relay v1 is a trusted relay. It forwards WebSocket frames and can see plaintext ccpocket protocol traffic. Run it only on infrastructure you trust, use wss:// in production, and treat RELAY_ADMIN_TOKEN plus the room secret as credentials when trusted self-hosted registration is enabled. This is not end-to-end encrypted.

Experimental: Join a CC Pocket Codex Session from Codex CLI

By default, each Codex session uses a private app-server. To let Codex CLI join the same live thread that CC Pocket started, run the Bridge with shared app-server mode:

BRIDGE_CODEX_APP_SERVER_MODE=managed \
BRIDGE_CODEX_SHARED_APP_SERVER_URL=ws://127.0.0.1:8767 \
npx @gotokens/bridge@latest

Then start or resume a Codex session from CC Pocket. When the session is ready, the session screen can copy a session-specific command like:

codex resume <thread-id> --remote ws://127.0.0.1:8767

Run that command in a terminal on the same machine as the Bridge. The 127.0.0.1 address is for the Mac/Linux machine running the Bridge and Codex CLI, not for the phone.

Modes:

  • private: default behavior. No Codex CLI co-presence.
  • managed: Bridge starts one local WebSocket Codex app-server and shares it with Codex CLI.
  • external: Bridge connects to an already-running app-server. In this mode, BRIDGE_CODEX_SHARED_APP_SERVER_URL is required.

This is experimental and currently targets Codex CLI co-presence only. Codex App compatibility is not guaranteed and may use a different integration model in the future.

Requirements

Health Check

Run the built-in doctor command to verify your environment:

npx @gotokens/bridge@latest doctor

It checks Node.js, Git, CLI providers, macOS permissions (Screen Recording, Keychain), network connectivity, and more.

Architecture

Mobile App ←WebSocket→ Bridge Server ←stdio→ Claude Code CLI

The bridge server spawns and manages Claude Code CLI processes, translating WebSocket messages to/from the CLI's stdio interface. It supports multiple concurrent sessions.

License

This package is governed by the CC Pocket license.

The repository remains under FSL-1.1-MIT, with a specific Bridge Redistribution Exception that allows unofficial redistribution of the Bridge Server, including environment-specific builds and forks for Windows, WSL, proxy-restricted, or other hard-to-validate environments.

If you redistribute this package or a modified fork:

  • do not imply it is official, endorsed, or supported by the CC Pocket maintainer
  • preserve the license text and clearly state that the software is provided "AS IS"
  • make clear that compliance with Anthropic, OpenAI, network, enterprise, and other third-party terms is the responsibility of the redistributor and end user

In short: unofficial Bridge redistributions are permitted for compatibility and support purposes, but they remain unsupported and at your own risk.