femtech-radar
Fetches research preprints from arXiv related to women's health and FemTech, normalizes and scores them for relevance.
Fetches industry news from Google News on FemTech and women's health topics, normalizes and scores items.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@femtech-radarshow top femtech news and research"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
๐ค 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.
๐ 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 ยท Documentation ยท Changelog ยท Report Bug ยท Request Feature
๐ 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:
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;
a weekly GitHub Agentic Workflow (
gh aw) drives the MCP, lets Copilot curate the digest, and commits the week'sdata/*.jsonvia a review-gated PR;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.
Related MCP server: junk-filter-mcp
โจ Key Features
1 One MCP tool, a whole radar โ radar_collect returns normalized, deduped, scored items per section. v1 ships industry (Google News) and research (arXiv); opportunities and discussions are defined and roadmapped.
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 RSS โ 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) ยท enginecopilot, modelgpt-4.1ยท weekly schedule โ review-gated data PRSite: Astro 5 (
femtech-radar-site) ยท@astrojs/rssยท GitHub Pages deploy viadeploy-pages.yml
๐๏ธ Architecture
graph TD
subgraph Sources
A1[arXiv API]
A2[Google News RSS]
end
A1 --> AD[Source adapters<br/>normalize โ RadarItem]
A2 --> 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. The diagram shows the full scrape โ curate โ publish pipeline.
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 awCLI
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 testThe 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 previewThe 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_sourcestools, resilient error handling, 28 tests. Published to npm as@chanmeng666/femtech-radar-mcp.โ v2 โ orchestration: a weekly
gh awworkflow (enginecopilot, modelgpt-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.
Deferred to a future version (not yet built): the opportunities + discussions source adapters, ChatOps slash commands (/deep-dive), per-section RSS feeds, and full bilingual (i18n routing is reserved).
๐ Usage Guide
femtech-radar is consumed as an MCP server. It exposes two tools:
Tool | Parameters | Returns |
|
|
|
| none | the configured source list per section |
In v1 only
industryandresearchhave adapters;opportunitiesanddiscussionsreturn an empty list with a"no adapter for โฆ"warning.
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-mcpworks once the package is published to npm (v2). Until then, build locally and point your client atdist/index.jsas 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 tsupProject 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 (research = arXiv, industry = Google News)
โโโ collect.ts # orchestration: adapter โ dedupe โ score โ sort โ since-filter
โโโ tools.ts # radar_collect / radar_sources handlers
โโโ index.ts # stdio MCP server entryAdding 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:
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
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ChanMeng666/femtech-radar'
If you have feedback or need assistance with the MCP directory API, please join our Discord server