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

opencode-brain

v1.1.0

Published

Persistent memory using Memvid, compatible with Claude Code (claude-brain)

Readme

OpenCode Brain Banner

Give OpenCode photographic memory in ONE portable file.

npm version License: MIT Build Status

Share memories between OpenCode and Claude Code.
Using claude-brain and Memvid.

Install in 30 seconds · How it Works · Commands · FAQ

The Problem

You: "Remember that auth bug we fixed?"
OpenCode: "I don't have memory of previous conversations."
You: "We spent 3 hours on it yesterday"
OpenCode: "I'd be happy to help debug from scratch!"

Large context window. Zero memory between sessions.

The Fix

You: "What did we decide about auth?"
OpenCode: "We chose JWT over sessions for your microservices.
          The refresh token issue - here's exactly what we fixed..."

One file. OpenCode remembers everything.

Installation

Prerequisites

  • Node.js 18.0.0 or higher
  • OpenCode 0.1.0 or higher

Install

npm install opencode-brain

Add to your opencode.json:

{
  "plugin": ["opencode-brain"]
}

Restart OpenCode. Done.

How it Works

After install, OpenCode's memory lives in one file:

your-project/
└── .claude/
    └── mind.mv2   # OpenCode's brain. That's it.

No database. No cloud. No API keys.

What gets captured:

  • Tool outputs (files read, commands run, searches)
  • Session context, decisions, bugs, solutions
  • Auto-injected at session start
  • Searchable anytime

Why one file?

  • git commit → version control OpenCode's brain
  • scp → transfer anywhere
  • Send to teammate → instant onboarding
  • Compatible with claude-brain → Use both tools on the same project

Commands

In OpenCode:

/mind:stats                         # memory statistics
/mind:search "authentication"       # find past context
/mind:ask "why did we choose X?"    # ask your memory
/mind:recent                        # what happened lately

Or just ask naturally: "mind stats", "search my memory for auth bugs", etc.

Tools

| Tool | Description | |------|-------------| | mind_search | Search memories by query with relevance scoring | | mind_ask | Ask questions about past work using context | | mind_stats | View memory statistics and health | | mind_timeline | View recent observations chronologically |

Examples

Search for Past Errors

/mind:search "database connection error"

Output:

1. [problem] Database connection timeout
   Score: 0.85 | 2h ago | via opencode
   Failed to connect to PostgreSQL: connection timeout after 30s
   File: src/db/connection.ts
   
2. [solution] Fixed connection pool configuration
   Score: 0.72 | 2h ago | via opencode
   Increased pool size to 20, added retry logic with exponential backoff
   File: src/db/connection.ts

Ask About Decisions

/mind:ask "Why did we switch from REST to GraphQL?"

Output:

Based on recent observations:

We switched to GraphQL to solve the over-fetching problem in the mobile app. 
The REST endpoints were returning entire user objects when the app only needed 
names and avatars, causing slow load times. GraphQL allows the mobile team to 
request exactly what they need.

Decision made 3 days ago during API redesign discussion.

View Recent Activity

/mind:recent 5

Output:

📅 Recent Observations (last 5):

1. 5 minutes ago | [feature] Added user authentication endpoints
   Implemented JWT-based auth with refresh tokens
   
2. 15 minutes ago | [discovery] Found existing auth middleware
   Located reusable auth middleware in src/middleware/
   
3. 1 hour ago | [problem] TypeScript errors in auth service
   Missing types for User interface
   
4. 1 hour ago | [solution] Fixed TypeScript errors
   Added proper type definitions
   
5. 2 hours ago | [decision] Chose PostgreSQL for user data
   Better suited for relational user data than MongoDB

Cross-Tool Compatibility

opencode-brain and claude-brain share the same .claude/mind.mv2 file.

How it Works

  • Both plugins read/write the same memory file
  • Source attribution shows which tool created each memory
  • File locking prevents corruption from concurrent access
  • Completely transparent - just works

Use Cases

Scenario 1: Research + Implementation

  1. Use Claude Code to research an architecture decision → Stored in .claude/mind.mv2
  2. Use OpenCode to implement it → Reads the same file, sees the decision
  3. Both tools maintain a shared memory

Scenario 2: Team Collaboration

  1. Developer A uses Claude Code to debug an issue
  2. Developer A commits .claude/mind.mv2 to git
  3. Developer B pulls the repo and uses OpenCode
  4. Developer B sees all of Developer A's debugging context

Scenario 3: Multi-Tool Workflow

  1. Use Claude Code for complex reasoning tasks
  2. Use OpenCode for rapid coding
  3. Both see the same project context
  4. No context loss when switching tools

Memory Types

Observations are automatically classified as:

  • discovery - New information found (files, patterns, APIs)
  • decision - Choices made (architecture, libraries, approaches)
  • problem - Errors encountered (bugs, failures, issues)
  • solution - Fixes implemented (bug fixes, workarounds)
  • pattern - Patterns recognized (code smells, best practices)
  • warning - Concerns noted (tech debt, security issues)
  • success - Successful outcomes (passing tests, deployments)
  • refactor - Code refactoring (improvements, cleanups)
  • bugfix - Bugs fixed (specific issues resolved)
  • feature - Features added (new functionality)

FAQ

Empty: ~70KB. Grows ~1KB per memory. A year of use stays under 5MB.

Large outputs are automatically compressed to ~500 tokens using ENDLESS MODE compression.

100% local. Nothing leaves your machine. Ever.

The .mv2 file is stored in your project directory with full control.

Sub-millisecond. Native Rust core via memvid. Searches 10K+ memories in <1ms.

Yes! 100% compatible. Both use .claude/mind.mv2 and can be used interchangeably on the same project.

File locking ensures safe concurrent access.

Tool outputs over 3000 characters are automatically compressed using tool-specific strategies:

  • File reads: Extract structure, imports, exports, functions, classes
  • Bash commands: Focus on errors, success indicators, key output
  • Grep results: Summarize matches and files
  • Glob results: Group by directory, show samples
  • Edits/Writes: Capture summary and confirmation

Compression reduces to ~500 tokens while preserving key information.

Compression is automatic for large outputs. The autoCompress config option exists but compression is recommended to avoid context limits.

rm .claude/mind.mv2

The file will be recreated automatically on next use.

Yes! It's designed for version control. Your team can share the same project context.

Just add it to git:

git add .claude/mind.mv2
git commit -m "Share project context"

opencode-brain automatically detects corruption and creates a backup before starting fresh.

Backups are stored as .claude/mind.mv2.backup-{timestamp} (keeps 3 most recent).

Troubleshooting

Memory file is corrupted

If you see deserialization errors, opencode-brain automatically:

  1. Creates a backup: .claude/mind.mv2.backup-{timestamp}
  2. Starts a fresh memory file
  3. Keeps the 3 most recent backups

Check backup files if you need to recover data.

Memory file too large

Files over 100MB are automatically detected and archived. Consider:

  • Deleting old .mv2 files periodically
  • Starting fresh for new projects
  • Checking for runaway observation creation

Enable debug logging

export OPENCODE_BRAIN_DEBUG=1

This shows detailed logging of:

  • Observations being captured
  • Compression operations
  • File locking activity
  • SDK operations

Plugin not loading

  1. Check opencode.json has correct plugin name: "opencode-brain"
  2. Verify Node.js version: node --version (needs 18+)
  3. Rebuild: npm run build in plugin directory
  4. Check OpenCode logs for errors

Observations not being captured

  1. Enable debug logging (see above)
  2. Check if tools are being used (Read, Bash, Grep, etc.)
  3. Verify .claude/ directory is writable
  4. Check for file locking issues (shouldn't happen with proper-lockfile)

API Reference

Tools

mind_search

Search memories by query using fast lexical search.

Parameters:

  • query (string, required) - Search terms or question
  • limit (number, optional) - Max results, default 10

Returns: Array of search results with observation, score, and snippet

mind_ask

Ask questions about past work using memory context.

Parameters:

  • question (string, required) - Natural language question

Returns: String answer based on relevant memories

mind_stats

View memory statistics.

Parameters: None

Returns: Statistics object with:

  • totalObservations - Total memory count
  • totalSessions - Session count
  • oldestMemory - Timestamp of oldest memory
  • newestMemory - Timestamp of newest memory
  • fileSize - Size in bytes
  • topTypes - Observation type counts

mind_timeline

View recent observations chronologically.

Parameters:

  • limit (number, optional) - Max results, default 20

Returns: Array of observations in chronological order

Contributing

Contributions welcome! See CONTRIBUTING.md for guidelines.

Quick Start

git clone https://github.com/deiviuds/opencode-brain.git
cd opencode-brain
npm install
npm run build
npm test

License

MIT - see LICENSE


If this saved you time, ⭐ star the repo

Built with ❤️ for the OpenCode community

Related: claude-brain - The original for Claude Code