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

@xpert-ai/plugin-context-editing

v0.0.1

Published

`@xpert-ai/plugin-context-editing` adds automatic context pruning to [Xpert AI](https://github.com/xpert-ai/xpert) agents. The middleware wraps LangChain chat requests and mirrors Anthropic-style context editing: once the dialog grows past a threshold, ol

Readme

Xpert Plugin: Context Editing Middleware

@xpert-ai/plugin-context-editing adds automatic context pruning to Xpert AI agents. The middleware wraps LangChain chat requests and mirrors Anthropic-style context editing: once the dialog grows past a threshold, older tool outputs are cleared or collapsed so the model stays within its input window.

Key Features

  • Clears older ToolMessage results once token/message/fraction triggers are met (default: 100,000 tokens).
  • Keeps the most recent tool outputs by count, token budget, or fraction of model context (default: last 3 results).
  • Optional input scrubbing for tool calls plus exclusion lists per tool name; inserts a placeholder for cleared results.
  • Removes orphaned tool messages automatically and annotates cleared entries with response_metadata.context_editing.
  • Supports fast approximate token counting or exact model-based counting when available (e.g., OpenAI getNumTokensFromMessages).
  • Ships as a global NestJS module that plugs directly into the Xpert agent middleware pipeline.

Installation

pnpm add @xpert-ai/plugin-context-editing
# or
npm install @xpert-ai/plugin-context-editing

Note: Ensure the host service already provides @xpert-ai/plugin-sdk, @nestjs/common@^11, @langchain/core@^0.3, zod, and chalk. These are treated as peer/runtime dependencies.

Quick Start

  1. Register the Plugin
    Start Xpert with the package in your plugin list:
    PLUGINS=@xpert-ai/plugin-context-editing
    The plugin registers the global ContextEditingPlugin module.
  2. Enable the Middleware on an Agent
    In the Xpert console (or agent definition), add a middleware entry with strategy ContextEditingMiddleware and provide options as needed.
  3. Configure Triggers and Retention
    Example middleware block:
    {
      "type": "ContextEditingMiddleware",
      "options": {
        "trigger": { "tokens": 100000 },
        "keep": { "messages": 3 },
        "excludeTools": ["healthcheck"],
        "placeholder": "[cleared]",
        "clearToolInputs": false,
        "tokenCountMethod": "approx"
      }
    }
    Swap trigger or keep to use fraction (of model context) or tokens depending on your needs.

Configuration

| Field | Type | Description | Default | | ----- | ---- | ----------- | ------- | | trigger | object | When to start clearing. Provide exactly one of:- tokens: number of tokens in the conversation.- messages: total message count.- fraction: fraction of the model max input tokens. | { "tokens": 100000 } | | keep | object | How much to preserve once triggered. Provide exactly one of:- messages: keep the most recent N tool results.- tokens: keep tool results until this token budget is reached (counting from the newest).- fraction: keep tool results up to this fraction of model context. | { "messages": 3 } | | excludeTools | string[] | Tool names that should never be cleared. | [] | | placeholder | string | Text inserted into cleared ToolMessage content. | "[cleared]" | | clearToolInputs | boolean | Also clears the originating tool call parameters on the AI message. | false | | tokenCountMethod | "approx" | "model" | Token counting mode: approx is fast character-based; model calls the model's getNumTokensFromMessages when available. | "approx" |

Tips

  • Use trigger.fraction with models that expose profile.maxInputTokens to keep pruning aligned with model limits.
  • Combine excludeTools with keep.tokens to protect critical tool outputs (e.g., auth checks) while trimming large artifacts.

Editing Behavior

  • Before evaluating thresholds, orphaned tool messages (no matching AI tool call) are removed.
  • When triggered, earlier tool results are replaced by the placeholder and tagged with context_editing.strategy = "clear_tool_uses".
  • If clearToolInputs is true, tool call args on the corresponding AI message are cleared and noted in context_editing.cleared_tool_inputs.
  • System messages are included in token counting; approximate mode assumes ~4 characters per token.

Development & Testing

npm install
npx nx build @xpert-ai/plugin-context-editing
npx nx test @xpert-ai/plugin-context-editing

TypeScript artifacts emit to packages/context-editing/dist. Validate middleware behavior against a staging agent run before publishing.

License

This project follows the AGPL-3.0 License located at the repository root.