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

imprint-mcp-server

v0.1.5

Published

MCP server exposing Imprint's local data (meeting notes, calendar, emails) to Claude.

Readme

imprint-mcp-server

A Model Context Protocol server that exposes Imprint's local data — meeting notes, calendar events, email metadata, daily digests — to Claude Desktop, Claude Code, and any other MCP-compatible client.

Read-only by design. The server never writes to Imprint's database; Imprint remains the source of truth for sync, classification, and writes.

What you can ask Claude

"What did we agree on in the Loyco meeting last week?"

"List my meetings tomorrow with online links."

"How many emails did I get from acme.no in April?"

"Summarize what I worked on this Tuesday."

Claude calls the appropriate tool(s), gets structured JSON back, and answers with full context from your own local Imprint data.

Tools

| Name | Purpose | | --- | --- | | search_meeting_notes | Keyword search over titles, summaries, AI summaries, project context. | | get_meeting_note | Full content of one note + optional full transcript. | | list_calendar_events | All events on a given date, with online-meeting URLs. | | search_emails | Filter email metadata by query / sender domain / direction / date range. (Imprint never stores email bodies.) | | get_daily_digest | Imprint's pre-generated work-hours/focus/apps summary for a date. |

Install

npm install -g imprint-mcp-server

Or use it ad-hoc via npx (recommended — no global install needed):

// ~/Library/Application Support/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "imprint": {
      "command": "npx",
      "args": ["-y", "imprint-mcp-server"]
    }
  }
}

Restart Claude Desktop. You'll see Imprint show up in the tools menu, and Claude will call its tools whenever a question matches.

Custom database location

By default the server looks at the standard Imprint path:

~/Library/Application Support/Imprint/imprint.db

Override via env var if Imprint's DB lives elsewhere:

{
  "mcpServers": {
    "imprint": {
      "command": "npx",
      "args": ["-y", "imprint-mcp-server"],
      "env": { "IMPRINT_DB_PATH": "/path/to/imprint.db" }
    }
  }
}

Privacy

  • The server runs locally on your machine. The MCP transport is stdio — there's no network listener.
  • The SQLite connection is opened read-only.
  • Tool results travel from the MCP server to Claude Desktop via stdio, then Claude Desktop sends them to Anthropic's API for the model to read. So: whatever you tell Claude to look up is sent to the model, just like any other Claude conversation. Use the same judgment you would if you pasted the data into a chat.
  • Imprint stores only email metadata (sender domain, subject, timestamp) — no message bodies. The MCP server can't surface what isn't there.

Development

git clone <repo>
cd imprint-mcp-server
npm install
npm run build
npm start

Smoke-test by piping JSON-RPC at it:

(
  echo '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"smoke","version":"1"}}}'
  echo '{"jsonrpc":"2.0","method":"notifications/initialized"}'
  echo '{"jsonrpc":"2.0","id":2,"method":"tools/list"}'
  sleep 0.3
) | node dist/index.js

Releasing

Releases are published to npm via GitHub Actions using OIDC trusted publishing — no long-lived tokens are stored in the repo or secrets.

To cut a release:

# 1. Bump version in package.json
npm version patch  # or minor / major

# 2. Push the tag
git push --follow-tags

The Release to npm workflow runs on tag push, builds, and publishes with --provenance (a signed SLSA attestation linking the tarball to the exact commit + run — visible on the npm package page).

One-time npm setup (already done for imprint-mcp-server)

On npmjs.com → Packages → imprint-mcp-server → Settings → Trusted Publishers, the following GitHub Actions config is registered:

| Field | Value | | --- | --- | | Organization | PTrobe | | Repository | imprint-mcp-server | | Workflow filename | release.yml | | Environment name | (empty) |

This means npm will accept publishes from .github/workflows/release.yml on the PTrobe/imprint-mcp-server repo without any secret. Tokens with 90-day expirations stop being a maintenance burden.

Roadmap

  • [ ] Tasks tool (requires Imprint to cache tasks in DB; today they're fetched live per provider)
  • [ ] Activity-events search (window/app tracking)
  • [ ] Resources (vs. tools) for browsing notes by folder
  • [ ] Write tools — e.g. create_meeting_note, complete_task