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

pi-web-extension

v0.1.2

Published

A pi extension that adds web search and web fetch tools to the coding agent.

Readme

pi web extension

npm version license

A pi extension that adds web search and web fetch tools to the coding agent.

  • Keyless web search via Brave and DuckDuckGo HTML fallback
  • Webpage fetching with HTML-to-Markdown conversion, saved to a temp file
  • Agent reads fetched content in chunks via the read tool — no context bloat
  • Automatic prompt steering for URL and web-search style prompts
  • Token-aware: keeps search results compact, trims oversized pages

Install

pi install npm:pi-web-extension

From the public git repo:

pi install git:github.com/NicoAvanzDev/pi-web-extension

From a local clone:

pi install .

Load without installing:

pi --no-extensions -e ./index.ts

How it works

websearch

Runs a keyless web search by scraping public search engines. Tries Brave first, falls back to DuckDuckGo HTML. Returns a compact list of results (title, URL, snippet).

webfetch

Fetches a URL, strips non-content elements, converts the HTML to Markdown via Turndown, and saves the result to a temp file in the pi session directory. Returns metadata (file path, title, content length, preview) so the agent can read the file in chunks as needed.

Prompt steering

Before each agent turn, the extension checks the user prompt for URLs and web-search intent patterns. When detected, it activates the web tools and injects steering instructions into the system prompt.

Tools

The extension exposes LLM-callable tools:

  • websearch
  • webfetch

websearch

Parameters:

  • query: string -- the search query

webfetch

Parameters:

  • url: string -- the URL to fetch
  • format?: "markdown" | "text" | "html" -- output format (default: "markdown")