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

@pingfyr/mcp

v0.3.0

Published

MCP server for Pingfyr — schedule reminders via email, webhook, Slack, Discord, Telegram, OpenClaw, or Google Calendar.

Readme

@pingfyr/mcp — MCP Server for Pingfyr Reminder API

Schedule reminders via API. Wake your agents via webhook. Deliver notifications via email, Slack, Discord, Telegram, OpenClaw, or Google Calendar.

What is Pingfyr?

Pingfyr is a reminder service built for AI agents. It lets your agent schedule reminders that get delivered at the right time — via email to humans, via webhook to wake up other agents, or via Slack, Discord, Telegram, OpenClaw, and Google Calendar for team notifications.

No cron jobs. No infrastructure. Just tell your agent when to remind, and Pingfyr handles the rest.

Installation

npm install -g @pingfyr/mcp

Or run directly with npx:

npx @pingfyr/mcp

Configuration

Claude Code (~/.claude/mcp.json)

{
  "mcpServers": {
    "pingfyr": {
      "command": "pingfyr-mcp",
      "env": {
        "PINGFYR_API_KEY": "rm_your_api_key",
        "PINGFYR_API_URL": "https://pingfyr.com"
      }
    }
  }
}

Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json on macOS)

{
  "mcpServers": {
    "pingfyr": {
      "command": "npx",
      "args": ["-y", "@pingfyr/mcp"],
      "env": {
        "PINGFYR_API_KEY": "rm_your_api_key",
        "PINGFYR_API_URL": "https://pingfyr.com"
      }
    }
  }
}

Other MCP Clients

Any MCP-compatible client (Cursor, Windsurf, etc.) can use the same configuration pattern above.

Sign up at pingfyr.com to get your API key.

Available Tools

| Tool | Description | | ----------------- | -------------------------------------------------------------------------------------------------- | | create_reminder | Schedule a new reminder via email, webhook, Slack, Discord, Telegram, OpenClaw, or Google Calendar | | list_reminders | List all reminders with optional filtering by status, limit, and offset | | update_reminder | Update a pending reminder (title, body, fire_at, channel, recipients, repeat, timezone) | | cancel_reminder | Cancel a pending reminder |

create_reminder Parameters

| Parameter | Required | Type | Description | | ----------------- | -------- | -------- | --------------------------------------------------------------------------------- | | title | Yes | string | Title of the reminder (max 200 chars) | | fire_at | Yes | string | When to fire (ISO 8601 datetime, must be in the future) | | channel | Yes | enum | email, webhook, slack, discord, telegram, openclaw, google_calendar | | recipients | Yes | string[] | Delivery addresses (see Channels table for format per channel) | | body | No | string | Body/description of the reminder (max 2000 chars) | | repeat | No | enum | daily, weekly, monthly, custom | | cron_expression | No | string | Cron expression (required when repeat is custom) | | timezone | No | string | IANA timezone for recurring reminders (default: UTC) | | metadata | No | object | Arbitrary key-value metadata to attach to the reminder |

list_reminders Parameters

| Parameter | Required | Type | Description | | --------- | -------- | ------ | ----------------------------------------------------------- | | status | No | enum | pending, processing, delivered, failed, cancelled | | limit | No | number | Max results (default: 50, max: 100) | | offset | No | number | Pagination offset (default: 0) |

update_reminder Parameters

| Parameter | Required | Type | Description | | ------------ | -------- | -------- | ------------------------------------ | | id | Yes | string | UUID of the reminder to update | | title | No | string | New title | | body | No | string | New body | | fire_at | No | string | New fire time (ISO 8601) | | channel | No | enum | New channel | | recipients | No | string[] | Updated delivery addresses | | repeat | No | enum | New repeat schedule (null to remove) | | timezone | No | string | New timezone |

Examples

Email reminder (multi-recipient)

{
  "title": "Project deadline reminder",
  "fire_at": "2026-12-15T08:00:00Z",
  "channel": "email",
  "recipients": ["[email protected]", "[email protected]"]
}

Slack reminder

{
  "title": "Weekly team sync reminder",
  "fire_at": "2026-12-01T09:00:00Z",
  "channel": "slack",
  "recipients": ["https://hooks.slack.com/services/T.../B.../xxx"],
  "repeat": "weekly",
  "timezone": "America/New_York"
}

Discord notification

{
  "title": "Deploy notification",
  "fire_at": "2026-12-01T17:00:00Z",
  "channel": "discord",
  "recipients": ["https://discord.com/api/webhooks/xxx/yyy"]
}

Telegram reminder

{
  "title": "Daily standup",
  "fire_at": "2026-12-01T09:00:00Z",
  "channel": "telegram",
  "recipients": ["bot:123456:789012"],
  "repeat": "daily",
  "timezone": "Europe/Berlin"
}

Find your bot_id in Settings → Telegram Bots on the Pingfyr dashboard.

OpenClaw notification

{
  "title": "Agent task complete",
  "fire_at": "2026-12-01T10:00:00Z",
  "channel": "openclaw",
  "recipients": ["https://openclaw.example.com/webhook"]
}

Google Calendar event (Starter+ plan required)

Creates a Google Calendar event on the user's connected Google account. Connect your account at Settings → Google Calendar in the Pingfyr dashboard.

{
  "title": "Team sync",
  "fire_at": "2026-12-01T09:00:00Z",
  "channel": "google_calendar",
  "recipients": ["google"]
}

Webhook (agent wake-up)

{
  "title": "Check for new orders",
  "fire_at": "2026-12-01T10:00:00Z",
  "channel": "webhook",
  "recipients": ["https://your-agent.example.com/webhook"],
  "repeat": "daily"
}

Custom cron schedule

{
  "title": "Weekday morning check",
  "fire_at": "2026-12-01T09:00:00Z",
  "channel": "webhook",
  "recipients": ["https://your-agent.example.com/webhook"],
  "repeat": "custom",
  "cron_expression": "0 9 * * MON-FRI",
  "timezone": "America/New_York"
}

Channels

| Channel | recipients format | Description | | ----------------- | -------------------------- | --------------------------------------------------------------------------------- | | email | Email addresses | Deliver to one or more email inboxes (Starter+ plan required) | | webhook | HTTP/HTTPS URL | POST request to wake up agents | | slack | Slack Incoming Webhook URL | Post message to a Slack channel | | discord | Discord Webhook URL | Post message to a Discord channel | | telegram | bot:<bot_id>:<chat_id> | Send message via Telegram bot (register bot in Settings → Telegram Bots) | | openclaw | OpenClaw URL | POST request to an OpenClaw endpoint | | google_calendar | google (literal) | Create a Google Calendar event on your connected account (Starter+ plan required) |

Plans

| Plan | Price | Reminders/month | Recipients/month | | ---------- | ------- | --------------- | ---------------- | | Free | $0 | 50 | 100 | | Starter | $59/mo | 10,000 | 20,000 | | Pro | $269/mo | 50,000 | 100,000 | | Enterprise | Contact | Unlimited | Unlimited |

Free plan includes Webhook, Slack, Discord, Telegram, and OpenClaw channels. Email and Google Calendar require a paid plan (Starter+).

Environment Variables

| Variable | Required | Description | | ----------------- | -------- | --------------------------------------------- | | PINGFYR_API_KEY | Yes | Your Pingfyr API key | | PINGFYR_API_URL | No | API base URL (default: https://pingfyr.com) |

License

MIT