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

@fables092/opencode-mem0

v1.0.1

Published

OpenCode plugin that gives coding agents persistent memory using mem0 self-hosted Docker backend

Readme

opencode-mem0 — mem0 self-hosted memory plugin for OpenCode

OpenCode plugin for persistent memory using mem0 self-hosted Docker backend.

Your agent remembers what you tell it — across sessions, across projects — without sending data to any third-party cloud service.

Quick Start

1. Start mem0 Docker backend

docker compose up -d

This starts the mem0 REST API at http://localhost:8000.
You need an OPENAI_API_KEY set in your environment (mem0 uses it for embeddings).

2. Set environment variables

# Required: point the plugin to your mem0 instance (default shown)
export MEM0_BASE_URL=http://localhost:8000

# Optional: set an API key if you configured mem0 with authentication
export MEM0_API_KEY=your-key

3. Install the plugin

bunx opencode-mem0@latest install

Or add manually to ~/.config/opencode/opencode.jsonc:

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

Configuration

Create ~/.config/opencode/mem0.jsonc:

{
  // mem0 base URL (can also use MEM0_BASE_URL env var)
  "baseUrl": "http://localhost:8000",

  // API key if mem0 is configured with authentication (can also use MEM0_API_KEY env var)
  "apiKey": "your-key",

  // Min similarity for memory retrieval (0-1)
  "similarityThreshold": 0.6,

  // Max memories injected per request
  "maxMemories": 5,

  // Max project memories listed
  "maxProjectMemories": 10,

  // Max profile facts injected
  "maxProfileItems": 5,

  // Include user profile in context
  "injectProfile": true,

  // Prefix for container tags
  "containerTagPrefix": "opencode",

  // Optional: Set exact user container tag (overrides auto-generated tag)
  "userContainerTag": "my-custom-user-tag",

  // Optional: Set exact project container tag (overrides auto-generated tag)
  "projectContainerTag": "my-project-tag",

  // Extra keyword patterns for memory detection (regex)
  "keywordPatterns": ["log\\s+this", "write\\s+down"],

  // Context usage ratio that triggers compaction (0-1)
  "compactionThreshold": 0.8,
}

All fields are optional. Environment variables take precedence over config file values.

Tool Usage

The mem0 tool is available to the agent:

| Mode | Args | Description | | --------- | ---------------------------- | ----------------- | | add | content, type?, scope? | Store memory | | search | query, scope? | Search memories | | profile | query? | View user profile | | list | scope?, limit? | List memories | | forget | memoryId, scope? | Delete memory |

Scopes: user (cross-project), project (default)

Types: project-config, architecture, error-solution, preference, learned-pattern, conversation

Features

Context Injection

On first message of a session, the agent receives (invisible to user):

  • User profile (recent cross-project memories)
  • Project memories (all project knowledge)
  • Relevant user memories (semantic search)

Keyword Detection

Say "remember", "save this", "don't forget" etc. and the agent auto-saves to memory.

You: "Remember that this project uses bun"
Agent: [saves to project memory]

Add custom triggers via keywordPatterns config.

Preemptive Compaction

When context hits 80% capacity:

  1. Triggers OpenCode's summarization
  2. Injects project memories into summary context
  3. Saves session summary as a memory

This preserves conversation context across compaction events.

Privacy

API key is <private>sk-abc123</private>

Content in <private> tags is never stored.

Memory Scoping

| Scope | user_id | Persists | | ------- | -------------------------------------- | ------------ | | User | opencode_user_{sha256(git email)} | All projects | | Project | opencode_project_{sha256(directory)} | This project |

Development

bun install
bun run build
bun run typecheck

Local install:

{
  "plugin": ["file:///path/to/opencode-mem0"],
}

Logs

tail -f ~/.opencode-supermemory.log

License

MIT