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

seojeom-mcp

v0.3.20

Published

Local-first MCP server for Claude/Codex project wiki and graph workflows

Readme

Seojeom MCP Server

Canonical repo location: packages/seojeom-mcp

During the Godot-only decommission transition, apps/desktop/mcp-server may already be absent. New work should treat this package path as the source of truth. If a deprecated local lane still needs the old path to exist, recreate the minimal metadata-wrapper with pnpm apply:legacy-compat-wrapper.

Local-first MCP server for Claude and Codex.

seojeom-mcp binds to the project currently opened by the Seojeom desktop app or Godot launcher through a shared registry directory, then serves that project's local wiki and graph data over stdio.

Quickstart

Claude Code

claude mcp add -s local \
  -e SEOJEOM_SHARED_REGISTRY_DIR=/mnt/c/Users/<you>/.seojeom/registry \
  seojeom -- npm exec --yes --package=seojeom-mcp seojeom-mcp -- \
  --router \
  --host-kind auto \
  --approval-mode prompt

Claude Desktop

Add this to claude_desktop_config.json and restart Claude Desktop:

{
  "mcpServers": {
    "seojeom": {
      "command": "npm",
      "env": {
        "SEOJEOM_SHARED_REGISTRY_DIR": "<shared-registry-dir>"
      },
      "args": [
        "exec",
        "--yes",
        "--package=seojeom-mcp",
        "seojeom-mcp",
        "--",
        "--router",
        "--host-kind", "auto",
        "--approval-mode", "prompt"
      ]
    }
  }
}

Print the exact onboarding command first

npm exec --yes --package=seojeom-mcp seojeom-mcp -- --print-claude-onboarding

What it provides

  • project binding to the currently active desktop/Godot project
  • local wiki read/search/write tools
  • local graph read/search/query tools
  • core graph mutation/proposal tools for local authoring tasks
  • approval-gated mutating operations

The exact tool surface is discovered at runtime through MCP tools/list.

Runtime contract

  • primary transport: stdio
  • primary install path: npm exec --yes --package=seojeom-mcp seojeom-mcp --
  • recommended mode: shared-registry router mode
  • expected runtime: Node >=20.20.0
  • public npm package shape: standalone stdio entrypoint only

Source build contract

Running pnpm build in this package is a dual-output build:

  • dist/index.js and the rest of dist/** stay available as the local source/runtime HTTP sidecar surface used by Godot and other repo-local lanes
  • .public-package/dist/standalone.js is the staged npm publish surface

After a successful build, you can verify both lanes with:

pnpm smoke:build-layout

Godot-side source verification can also run the local HTTP sidecar smoke directly from the canonical package root:

pnpm smoke:sidecar-health

Surface tiers

seojeom-mcp is not one uniform surface. Treat these as separate contracts:

1. npm public package

  • audience: external Claude/Codex users installing from npm
  • transport: stdio
  • mode: shared-registry router
  • published shape: LICENSE, README.md, bin/seojeom-mcp, dist/standalone.js, package.json
  • capability promise: public tools only
  • non-goals: internal prompts, internal resources, full authoring harness, desktop UI shell

This is the only contract guaranteed by the published npm package.

2. local full runtime

  • audience: local maintainers running from source
  • transport: stdio plus local sidecar HTTP runtime paths
  • profile: full authoring surface
  • includes: prompts, resources, specialized graph/wiki authoring flows, internal playbooks

This source-tree runtime is intentionally larger than the public package.

3. desktop-coupled runtime

  • audience: local desktop/Godot-integrated operation
  • product default: app-bundled sidecar runtime
  • depends on: shared registry writer, approval queue UI, review shell, sidecar health surface
  • examples: approval review pane, desktop approval alerts, graph IPC bearer-token flows
  • debug override: sidecar entry override is reserved for debug-only startup paths

These desktop-coupled capabilities are not part of the standalone npm guarantee.

Registry

  • MCP Registry identifier target: io.github.seojeom/seojeom-mcp
  • planned publish mode: GitHub Actions Trusted Publishing + npm publish --provenance

Notes

  • This package is still a preview release and the tool surface may evolve between versions.
  • Router mode is the recommended public path. Direct per-project standalone flags remain as a compatibility fallback.
  • The public package defaults to a core authoring tool surface. Prompts, resources, and more specialized orchestration surfaces are reserved for non-public/internal profiles.
  • Public package documentation intentionally stays focused on installation and end-user usage. Internal release automation and repository-specific operator workflows are not part of the package contract.

Links

  • Repository: https://github.com/seojeom/seojeom-mcp
  • Issues: https://github.com/seojeom/seojeom-mcp/issues
  • License: MIT