femtech-radar

femtech-radar

An MCP server that fetches, dedupes, and scores women's-health & FemTech research and industry news, designed to feed GitHub Agentic Workflows and an auto-updating Astro + RSS site.

Category
Visit Server

README

<!-- AGENT-FIRST NOTICE -->

[!IMPORTANT]

๐Ÿค– Read this with your AI agent โ€” don't read it by hand.

This repo is written agent-first. Point Claude Code, GitHub Copilot, Cursor, or any agent at it: "Read the README and AGENTS.md, then help me run / extend this." Structure + AGENTS.md are optimized for agent comprehension. <!-- /AGENT-FIRST NOTICE -->

<div align="center"><a name="readme-top"></a>

<!-- Optional hero image / logo: <img src="./.github/brand/your-logo.svg" alt="femtech-radar" width="120" /> -->

๐Ÿš€ femtech-radar

FemTech intelligence as a GitHub-native, agent-driven pipeline

Agent-first FemTech intelligence: an MCP server that fetches, dedupes, and scores women's-health & FemTech research and industry news, designed to feed GitHub Agentic Workflows and an auto-updating Astro + RSS site.

[Live Demo][demo-link] ยท [Documentation][docs-link] ยท Changelog ยท Report Bug ยท Request Feature

<!-- SHIELD GROUP -->

License CI Contributors Forks Stars Issues Sponsor

<!-- Tech stack badges โ€” replace with your real stack: Next.js TypeScript -->

</div>

<details> <summary><kbd>๐Ÿ“‘ Table of Contents</kbd></summary>

</details>

๐ŸŒŸ Introduction

The FemTech and women's-health world produces a scattered firehose of signal โ€” research preprints, funding and product news, community opportunities, technical discussion โ€” across dozens of sources. femtech-radar turns that noise into a curated, deduplicated, ranked digest, using only GitHub-native primitives plus a reusable Model Context Protocol (MCP) server.

It's a complete, live three-unit pipeline โ€” scrape โ†’ curate โ†’ publish:

  1. an MCP server (the deterministic "brain") fetches from multiple sources, normalizes into one shape, dedupes, and scores each item by relevance ร— popularity ร— freshness, exposing the result over MCP;
  2. a weekly GitHub Agentic Workflow (gh aw) drives the MCP, lets Copilot curate the digest, and commits the week's data/*.json via a review-gated PR;
  3. an Astro + RSS site reads that data and auto-deploys to GitHub Pages.

It's built for FemTech / women-in-tech practitioners who want signal without the noise โ€” and as a reference implementation of the gh aw ร— MCP ร— GitHub Pages pattern. The product is live: a subscribable weekly intelligence site at https://chanmeng666.github.io/femtech-radar/ that updates itself for free on a public GitHub repo.

โœจ Key Features

1 One MCP tool, a whole radar โ€” radar_collect returns normalized, deduped, scored items per section. All four sections are live: industry (Google News), research (arXiv), opportunities (LinkedIn, with opt-in SerpAPI Google Jobs), and discussions (Hacker News).

2 Deterministic, testable core โ€” fetch โ†’ normalize โ†’ dedupe โ†’ score. The server makes no editorial judgment; that's left to the agent that drives it. 28 unit tests, and zero real network calls in tests (all I/O is injected).

3 Pluggable source adapters โ€” each source is one file behind a uniform Adapter interface. Add a feed by writing a collect() that returns RadarItem[].

4 Resilient by construction โ€” every source failure degrades to an empty result plus a warning; a malformed URL or date never throws out of a run.

5 GitHub-native, near-zero cost โ€” designed to run inside GitHub Actions on a public repo, where Actions and Pages are free; the only metered resource is a few Copilot credits per week.

6 Reusable anywhere MCP runs โ€” drop it into Claude Desktop or any MCP client; it isn't coupled to this project.

7 Live, self-updating, subscribable โ€” a weekly gh aw workflow curates the digest into a review-gated data/*.json PR, and an Astro + RSS site rebuilds itself on GitHub Pages. Readers subscribe via the full RSS feed or per-section feeds at /rss/<section>.xml โ€” no manual scraping, no server to run.

๐Ÿ› ๏ธ Tech Stack

  • Language / Runtime: TypeScript 5 (strict, ESM) ยท Node.js โ‰ฅ 20
  • MCP: @modelcontextprotocol/sdk (stdio server)
  • Parsing / validation: Zod (schema & runtime validation) ยท fast-xml-parser (Atom/RSS)
  • Tooling: pnpm workspaces (monorepo) ยท Vitest (tests) ยท tsup (build)
  • Orchestration: GitHub Agentic Workflows (gh aw) ยท engine copilot, model gpt-4.1 ยท weekly schedule โ†’ review-gated data PR
  • Site: Astro 5 (femtech-radar-site) ยท @astrojs/rss ยท GitHub Pages deploy via deploy-pages.yml
  • Built on: the opportunities adapter ports LinkedIn guest-endpoint logic from the owner's linkedin-jobs-search project (inspired by linkedin-jobs-api); the opt-in SerpAPI Google Jobs path is ported from server-google-jobs

๐Ÿ—๏ธ Architecture

<details> <summary><kbd>System overview</kbd></summary>

graph TD
    subgraph Sources
      A1[arXiv API]
      A2[Google News RSS]
      A3[LinkedIn Jobs]
      A4[Hacker News Algolia]
    end
    A1 --> AD[Source adapters<br/>normalize โ†’ RadarItem]
    A2 --> AD
    A3 --> AD
    A4 --> AD
    AD --> P["collect()<br/>dedupe โ†’ score โ†’ sort โ†’ since-filter"]
    P --> T[MCP tools<br/>radar_collect ยท radar_sources]
    T --> C[MCP clients]
    C --> W[Weekly gh aw workflow<br/>Copilot curates ยท writes why_it_matters]
    W --> D[(data/YYYY-Www.json<br/>review-gated PR)]
    D --> S[Astro + RSS site<br/>GitHub Pages ยท live]

All three units are built and live; all four source sections are active.

</details>

Separation of determinism vs judgment: the MCP server does only deterministic work (fetch, normalize, dedupe, score). Editorial choices โ€” which items to feature, how to summarize โ€” belong to the agent (gh aw + Copilot) that drives it. This keeps the core unit-testable and reusable.

๐Ÿš€ Getting Started

Prerequisites

  • Node.js โ‰ฅ 20 (the server uses global fetch)
  • pnpm โ‰ฅ 9 (npm i -g pnpm)
  • (optional) an MCP client such as Claude Desktop, or the gh aw CLI

Installation

git clone https://github.com/ChanMeng666/femtech-radar.git
cd femtech-radar
pnpm install

# Build the MCP server
pnpm --filter @chanmeng666/femtech-radar-mcp build

# Run the test suite (28 tests)
pnpm --filter @chanmeng666/femtech-radar-mcp test

The built server is an executable stdio MCP server at packages/mcp-server/dist/index.js. It's also published to npm, so any MCP client can run it with npx -y @chanmeng666/femtech-radar-mcp.

Run the site locally

# Dev server (reads data/*.json)
pnpm --filter femtech-radar-site dev

# Production build + preview
pnpm --filter femtech-radar-site build
pnpm --filter femtech-radar-site preview

The published site is live at https://chanmeng666.github.io/femtech-radar/ (RSS: /rss.xml); it rebuilds automatically whenever a new weekly data/*.json lands on master.

๐Ÿ›ณ Project Status & Roadmap

All three planned layers are built and live in production (see docs/superpowers/specs for the full design and docs/superpowers/plans for the per-unit implementation plans):

  • โœ… v1 โ€” MCP server: industry (Google News) + research (arXiv) adapters, dedupe/score pipeline, radar_collect / radar_sources tools, resilient error handling, 28 tests. Published to npm as @chanmeng666/femtech-radar-mcp.
  • โœ… v2 โ€” orchestration: a weekly gh aw workflow (engine copilot, model gpt-4.1) that drives the MCP, curates a digest, and emits a review-gated data PR plus a summary issue โ€” proven end-to-end in production (first digest: data/2026-W27.json).
  • โœ… v3 โ€” publishing (live): Astro 5 site auto-deployed to GitHub Pages at https://chanmeng666.github.io/femtech-radar/ with a subscribable RSS feed at https://chanmeng666.github.io/femtech-radar/rss.xml; rebuilds automatically on every weekly data update.
  • โœ… vNext โ€” 4-section pipeline: opportunities (LinkedIn, with opt-in SerpAPI Google Jobs) and discussions (Hacker News) adapters now active; per-section RSS feeds at /rss/<section>.xml; site polish (favicon, numeric-entity decode, sources chip); weekly workflow updated to collect all four sections.

Deferred to a future version: ChatOps slash commands (/deep-dive) and full bilingual support (i18n routing is reserved).

๐Ÿ“– Usage Guide

femtech-radar is consumed as an MCP server. It exposes two tools:

Tool Parameters Returns
radar_collect section ("industry" | "research" | "opportunities" | "discussions"), optional since (ISO date, default 7 days ago), optional limit (default 15) { items: RadarItem[], warnings: string[] } โ€” deduped, scored, sorted, date-filtered
radar_sources none the configured source list per section

All four sections are live. industry (Google News) and research (arXiv) require no API key. opportunities uses LinkedIn by default (opt-in SerpAPI Google Jobs when SERP_API_KEY is set). discussions uses Hacker News Algolia (free, no key). LinkedIn is best-effort โ€” graceful degradation to [] applies if rate-limited.

Subscribe via RSS: the weekly digest is published at https://chanmeng666.github.io/femtech-radar/rss.xml and works in any feed reader.

Use with GitHub Agentic Workflows (gh aw)

mcp-servers:
  femtech-radar:
    command: npx
    args: ["-y", "@chanmeng666/femtech-radar-mcp"]

Use with Claude Desktop

{
  "mcpServers": {
    "femtech-radar": {
      "command": "node",
      "args": ["/absolute/path/to/femtech-radar/packages/mcp-server/dist/index.js"]
    }
  }
}

npx @chanmeng666/femtech-radar-mcp works once the package is published to npm (v2). Until then, build locally and point your client at dist/index.js as shown above.

See packages/mcp-server/README.md for the full tool reference.

โŒจ๏ธ Development

pnpm install                                              # install workspace deps
pnpm --filter @chanmeng666/femtech-radar-mcp test         # run tests (Vitest)
pnpm --filter @chanmeng666/femtech-radar-mcp build        # build with tsup

Project layout

packages/mcp-server/src/
โ”œโ”€โ”€ schema.ts          # Zod RadarItem / WeeklyData (the shared data contract)
โ”œโ”€โ”€ dedup.ts           # URL canonicalization + title-similarity dedupe
โ”œโ”€โ”€ score.ts           # relevance ร— popularity ร— freshness scoring
โ”œโ”€โ”€ adapters/          # one file per source (industry = Google News, research = arXiv, opportunities = LinkedIn/SerpAPI, discussions = HN)
โ”œโ”€โ”€ collect.ts         # orchestration: adapter โ†’ dedupe โ†’ score โ†’ sort โ†’ since-filter
โ”œโ”€โ”€ tools.ts           # radar_collect / radar_sources handlers
โ””โ”€โ”€ index.ts           # stdio MCP server entry

Adding a source adapter: implement the Adapter interface in adapters/, return RadarItem[] from collect(opts) using the injected fetcher (never call fetch directly โ€” that keeps it testable), then wire it into ADAPTERS in collect.ts.

See AGENTS.md for AI-agent-oriented project conventions and gotchas.

๐Ÿค Contributing

Contributions make the open-source community an amazing place to learn and create. Please read the Contributing Guide and the Code of Conduct before you start, and use the provided issue / pull-request templates.

โค๏ธ Sponsor

If this project helps you, please consider supporting its development:

Sponsor on GitHub Buy Me a Coffee

For questions and help, see SUPPORT.md. For security issues, see SECURITY.md.

๐Ÿ“„ License

This project is released under the MIT license.

๐Ÿ™‹โ€โ™€๏ธ Author

Chan Meng

Email GitHub

<div align="right">

</div>

<!-- Link definitions --> [demo-link]: https://chanmeng666.github.io/femtech-radar/ [docs-link]: ./packages/mcp-server/README.md


<!-- CHAN MENG PERSONAL BRAND --> <div align="center"> <a href="https://github.com/ChanMeng666" target="_blank"> <img src="./.github/brand/chan-meng-logo.svg" alt="Chan Meng" width="160" /> </a>

<p><strong>Chan Meng</strong><br/>Need a custom app like this one? I build them โ€” let's talk.</p>

<a href="mailto:chanmeng.dev@gmail.com"><img src="https://img.shields.io/badge/Email-chanmeng.dev@gmail.com-EA4335?style=flat-square&logo=gmail&logoColor=white" alt="Email Chan Meng"/></a> <a href="https://github.com/ChanMeng666"><img src="https://img.shields.io/badge/GitHub-ChanMeng666-181717?style=flat-square&logo=github&logoColor=white" alt="Chan Meng on GitHub"/></a> </div> <!-- /CHAN MENG PERSONAL BRAND -->

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured