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

bulletin-deploy

v0.11.0

Published

> [!WARNING] > The following is a prototype, reference implementation, and proof-of-concept. This open source code is provided for research, experimentation, and developer education only. This code has not been audited, is actively experimental, and may c

Readme

bulletin-deploy

[!WARNING] The following is a prototype, reference implementation, and proof-of-concept. This open source code is provided for research, experimentation, and developer education only. This code has not been audited, is actively experimental, and may contain bugs, vulnerabilities, or incomplete features. Use at your own risk.

Deploy a static web app to the Polkadot Bulletin Chain and serve it under a human-readable .dot name — from one command. Names are resolved through DotNS, Polkadot's on-chain naming system.

It targets Polkadot testnets (default: paseo-next-v2). This is reference tooling for putting a static site on-chain, not a managed hosting service — you run the deploys yourself, and there is no server or account to sign up for.

npm License: GPL-3.0-or-later

Features

  • On-chain static hosting — Upload a built site (any framework, or plain HTML) to the Bulletin Chain and address it by a .dot name. No web server to run.
  • Mobile-wallet signinglogin once by scanning a QR with your Polkadot wallet; deploy with no mnemonic stored on disk.
  • Zero-signature testnet deploys — a local worker registers the name and uploads the content, then transfers ownership to your signed-in account — no wallet taps in the default testnet flow.
  • Incremental uploads — re-deploys only push the content chunks that changed, so updates are fast and cheap.
  • No native dependency required--js-merkle does content addressing in pure JavaScript; the IPFS Kubo binary is optional, not required.
  • Built-in environments — target presets (RPC endpoints + contract addresses) selectable with --env, overridable per field.
  • Telemetry off by default — opt-in only, and honors the DO_NOT_TRACK convention.

Install

npm install -g bulletin-deploy

Requires Node.js ≥ 22. Content addressing uses the IPFS Kubo binary if it's on your PATH; otherwise pass --js-merkle to run it in pure JavaScript with no native dependency.

Quick start

# Build your app, then deploy:
bulletin-deploy ./dist my-app.dot

Once it finishes, your site is served at https://my-app.dot.li.

New here? DEPLOYMENT.md walks you from prerequisites to a viewable app, step by step — including how to acquire a .dot name, what authorization a network requires (the raw "not authorized" chain error is a common first-run trap), and where a deployed site is viewable.

Signing with a mobile wallet

Sign in once with your mobile Polkadot wallet — no mnemonic on disk:

bulletin-deploy login    # Scan the QR code with your Polkadot wallet app
bulletin-deploy whoami   # Show the currently signed-in address
bulletin-deploy logout   # Sign out and clear the session

After login, subsequent deploys hand the name to your signed-in account with zero mobile signatures (testnet): a local worker (the default dev account, or your --mnemonic) registers the name and uploads the content, then transfers ownership to your signed-in address as the final step. Pass --no-transfer-to-signedin-user to sign every DotNS transaction with your mobile session instead.

If a deploy's content lands but the final transfer fails, hand the name over separately:

bulletin-deploy transfer my-app.dot              # → the signed-in account
bulletin-deploy transfer my-app.dot --to 0x...   # → an explicit recipient

Options

Run bulletin-deploy --help for the full option reference.

Key options:

| Option | Description | |--------|-------------| | --env <id> | Target environment (default: paseo-next-v2). Run --list-environments to see available IDs. | | --mnemonic "..." | DotNS owner mnemonic (or set MNEMONIC env var). Alternative to session signing. | | --no-transfer-to-signedin-user | When signed in, sign every DotNS tx with your mobile session instead of the default register-as-worker-then-hand-over flow. | | --to <0xH160> | Recipient address for the transfer subcommand. Defaults to the signed-in account. | | --js-merkle | Use pure-JS merkleization (no IPFS Kubo binary required). | | --publish | List the domain in the on-chain Publisher registry after deploy. | | --config <path> | Explicit path to bulletin-deploy.config.ts for product deploys. | | --tag "..." | Label the deploy in telemetry. | | --version | Print the installed version and exit. |

Subcommands: login, logout, whoami (session management, above) and transfer <domain.dot> (hand a name you registered to the signed-in account or --to).

Environments

bulletin-deploy ships with built-in environment presets (RPC endpoints, contract addresses). The default is paseo-next-v2, a Polkadot testnet. Use --list-environments to print the table; override individual fields with --environment-file <path> or --contract KEY=0x.... For what a starting account needs on a given network — funding, a .dot name, authorization — see DEPLOYMENT.md.

Build from source

git clone https://github.com/paritytech/bulletin-deploy
cd bulletin-deploy
npm ci
npm run build
npm test          # offline unit tests

This produces the same bulletin-deploy CLI in bin/. See docs/testing.md for the live-testnet E2E suite.

Releases

Releases use a two-stage flow: a release candidate is validated by the end-to-end test matrix against a live testnet, then the byte-identical source is published to npm under the stable version. Once Trusted Publishing is enabled, npm provenance will let you verify that a published release was built from this repository.

Telemetry

Deploy telemetry (Sentry) is off by default. It activates only if you explicitly opt in with BULLETIN_DEPLOY_TELEMETRY=1, or when the CLI detects it is running in Parity's own CI. Set BULLETIN_DEPLOY_TELEMETRY=0 — or the cross-tool DO_NOT_TRACK=1 — to force it off in any context. The Sentry DSN baked into the package is a public project identifier, not a secret — it grants no access to collected data.

Separately from telemetry, the CLI checks the npm registry for the minimum supported version. Set BULLETIN_DEPLOY_UPDATE_CHECK=0 to disable that check.

Contributing

Issues and pull requests are welcome on the GitHub repository. Releases are cut by the maintainers. (Parity-internal design notes and investigation logs live in docs-internal/, which is not published to npm.)

Security

[!WARNING] The following is a prototype, reference implementation, and proof-of-concept. This open source code is provided for research, experimentation, and developer education only. This code has not been audited, is actively experimental, and may contain bugs, vulnerabilities, or incomplete features. Use at your own risk.

This repository contains reference and proof-of-concept code. Unless a specific release states otherwise, it has not received a full security audit. Use in production or production-like deployments should only follow an independent security review of the relevant code, configuration, generated output, and deployment environment.

Before deploying this for real use cases, you are responsible for:

  • Reviewing the code yourself — we publish a reference, not a hardened production build.
  • Checking that the dependencies are up to date and free of known vulnerabilities.
  • Securing your own fork or deployment environment (keys, secrets, network configuration).
  • Tracking the latest tagged release for security fixes; older releases are not backported (exceptions might apply).

Do not open a public issue for a suspected vulnerability. Follow Parity's responsible-disclosure process (SECURITY.md, inherited org-wide from paritytech/.github) and email [email protected]. For Parity's Bug Bounty programme, see https://parity.io/bug-bounty.

License

GPL-3.0-or-later. Versions up to and including 0.8.3 were published under Apache-2.0; the license changed to GPL-3.0-or-later ahead of the project being open-sourced.