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

@autosk/pi-agent

v0.1.3

Published

autosk extension that drives `pi --mode rpc` as an agent (model/thinking/first_message, kickback loop, autosk_transit pi-tool bridge).

Readme

@autosk/pi-agent

Drive pi (pi --mode rpc) as an autoskd v2 agent. piAgent({...}) returns an AgentDefinition the engine can run for a workflow step; it ports v1's "standard branch" (spawn pi, seed the first message, drive turns, kickback loop) onto the v2 ctx.spawn + ctx.transit API (design docs/plans/20260612-Bun-Daemon-Extensions.md §3.4).

Usage

import { piAgent } from "@autosk/pi-agent";
import { worktreeIsolation } from "@autosk/worktree";

export default function (autosk) {
  autosk.registerWorkflow({
    name: "my-flow",
    firstStep: "dev",
    steps: {
      // The step key IS the agent name; registering the workflow registers
      // its inline agents.
      dev: piAgent({
        model: "sonnet:high",
        firstMessageFile: new URL("./prompts/dev.md", import.meta.url).pathname,
      }),
      review: piAgent({ thinking: "xhigh", firstMessageFile: ".../review.md" }),
    },
    isolation: worktreeIsolation(),
  });
}

A piAgent({...}) is an inline step value: the step key is the agent name (there is no name option — the driver takes its display name from ctx.workflows.current.step), so registering the workflow registers its agents.

How it works

On each onRun the agent:

  1. spawns pi --mode rpc (with the role's model / thinking / extra args) and injects a pi extension that registers an autosk_transit tool. The spawn env also carries AUTOSK_CWD (the canonical project root, from ctx.projectRoot) and AUTOSK_AGENT (the step name), so any autosk CLI the agent runs — directly, or via the @autosk/pi-tools autosk_task / autosk_comment tools — targets the task's own project and attributes comments to the step, even when the run is in a throwaway worktree;
  2. seeds pi with the rendered step prompt (role first-message + task context + the available transitions + "call autosk_transit");
  3. mirrors pi's session entries (messages / custom) into the autosk transcript 1:1, so existing pi renderers stay reusable; while a turn streams it also forwards pi's message_update events as ephemeral partial snapshots via ctx.partial(m) (coalesced ~40 ms), so a client renders the in-progress assistant message live before the durable line commits (see docs/daemon.md → Streaming partial messages);
  4. observes the autosk_transit tool call on pi's RPC event stream and translates it into ctx.transit(...) (the transit channel — core stays closed, no session-scoped daemon RPC);
  5. runs a kickback/corrections loop (private to this extension): if a turn ends without a transit — or a chosen transition is rejected by the workflow's onTransit — it feeds a corrective message back to the model and retries, up to maxCorrections times. After the budget is spent it returns without a transit and the engine parks the task (agent_did_not_transit).

onSteer / onFollowup forward a session.input message into the live pi; onAbort asks pi to wind down gracefully (the engine's abort signal already terminates the child).

Interactive (chat) mode

Besides backing a workflow step, this package's default export registers a named agent, "pi", via autosk.registerAgent(...), so the daemon can open an interactive (taskless) chat session against it (see docs/daemon.md → Interactive sessions). onRun branches on ctx.mode:

  • "task" — the workflow transit loop above (unchanged).
  • "interactive" — a chat loop: spawn pi --mode rpc without the autosk_transit extension (transit is unavailable in a chat, so the tool is not offered), send no initial prompt (the session is empty until the user types), then await ctx.signal. Each composer message arrives via onFollowup and is forwarded to the live pi (idle → a fresh turn, streaming → a follow-up). The agent returns when the signal fires; the engine seals the session done (graceful end), aborted (abort), or failed (crash) — no transit, no park.

Configuration — PiAgentOptions

The agent name is not an option — it is the workflow step key the piAgent is assigned to (taken from ctx.workflows.current.step at run time).

| Option | Default | Description | | ------------------ | ----------------------------- | ------------------------------------------------------------------------ | | model | pi default | pi model spec, e.g. "sonnet:high" (--model). | | thinking | pi default | Thinking level offxhigh (--thinking). | | firstMessage | "" | Inline first-message seed (wins over firstMessageFile). | | firstMessageFile | — | Path to a file whose contents seed the first message. | | extraArgs | [] | Extra args forwarded verbatim to pi. | | piExtensions | [] | pi extensions to load (-e <path> each). | | piSkills | [] | pi skills to enable (--skill <name> each). | | maxCorrections | 3 | Corrective turns before giving up (then the engine parks the task). | | piBin | $AUTOSK_PI_BIN or "pi" | pi binary to spawn (the e2e tests point this at a stub). |

The injected autosk_transit tool

src/pi-transit-extension.ts is the pi extension this package injects via pi -e. It registers the autosk_transit tool (one to string: a sibling step name, or done | cancel | human). The tool returns an immediate ack; the real transition (and any rejection fed back as a correction) is driven by the autosk daemon, which observes the call on pi's RPC event stream. That file is loaded by pi's toolchain, not the daemon, so it is excluded from this package's tsc typecheck.

Project resolution under isolation

Under worktree isolation the agent runs in ~/.autosk/worktrees/<slug>/<task>, which contains no .autosk/. The daemon sets AUTOSK_CWD (= ctx.projectRoot) in the spawned pi's environment; the autosk CLI honors it as the project selector, so task/comment calls resolve the original project instead of walking up from the worktree. The structured task/comment tools live in the separate, pi-installed @autosk/pi-tools extension (not injected here) — workflow transitions stay on the in-process autosk_transit channel.

Exports

  • piAgent(options)AgentDefinition
  • buildPiCommand(options, { interactive? }) (the interactive flag skips the injected autosk_transit extension), PiDriver, parseTarget, the prompt renderers (renderInitialPrompt, kickbackMessage, rejectionMessage, targetLabels) — exported for tooling / tests.
  • default export — an extension factory that registers the named "pi" agent for interactive chat sessions. (Workflow roles are still registered separately, by the consuming extension, e.g. @autosk/feature-dev, as inline piAgent({...}) step values.)