MCP Venezuela FakeNews
A Model Context Protocol server for combating disinformation about Venezuela, integrating real fake news patterns with optional web search.
README
MCP Venezuela FakeNews
Servidor MCP (Model Context Protocol) para combatir desinformación sobre Venezuela. Integra patrones reales de fake news identificados en investigación (junio 2026) con búsqueda web actualizada vía Tavily.
Key Features
- 4 herramientas MCP para verificar claims, buscar fuentes oficiales, listar patrones y generar reportes
- Conocimiento base embebido de 6 patrones reales de desinformación venezolana (videos descontextualizados, contenido IA, usurpación de canales, falsos anuncios, operaciones YouTube, desinformación salarial)
- Búsqueda Tavily opcional — sin API key funciona solo con el conocimiento base
- Ligero — sin dependencias pesadas, compila a un solo archivo JS
Tech Stack
- Runtime: Node.js 18+
- Lenguaje: TypeScript 6.0 (compilado a ES2022)
- Framework MCP:
@modelcontextprotocol/sdk^1.29 - Validación: Zod ^4.4
- Búsqueda web: Tavily Search API (opcional)
- Entorno: dotenv para configuración local
Prerequisites
- Node.js 18 o superior (20+ recomendado)
- npm
- (Opcional) Una API key de Tavily — la misma que usas en opencode
Getting Started
1. Clonar e instalar
git clone <repo-url> ~/mcp-venezuela-fakenews
cd ~/mcp-venezuela-fakenews
npm install
2. Configurar variable de entorno (opcional)
Copia .env.example a .env y agrega tu API key de Tavily:
cp .env.example .env
# Edita .env con tu clave real:
# TAVILY_API_KEY=tvly-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Sin API key las herramientas funcionan igual, pero las búsquedas web devuelven un aviso para que la configures.
3. Compilar
npm run build
Esto produce dist/index.js, dist/index.js.map y dist/index.d.ts.
4. Probar con el inspector MCP
npm run inspect
Esto abre una UI web local donde puedes probar cada herramienta interactivamente.
Architecture Overview
Directory Structure
mcp-venezuela-fakenews/
├── src/
│ └── index.ts # Código fuente único (server + tools + lógica)
├── dist/ # Compilado (generado por tsc)
│ ├── index.js
│ ├── index.js.map
│ └── index.d.ts
├── .env # Variables de entorno local (git-ignorado)
├── .env.example # Plantilla para .env
├── package.json
├── tsconfig.json
└── README.md
Request Lifecycle
- El host MCP (opencode, Claude Desktop, etc.) inicia
dist/index.jscomo subproceso via STDIO transport - El servidor se conecta al transporte y registra sus 4 herramientas
- Cada llamada a tool es un mensaje JSON-RPC sobre STDIO
- La herramienta ejecuta su lógica: consulta patrones embebidos y/o llama a Tavily API
- Devuelve un
contentblock con tipotext
Conocimiento embebido (sin base de datos)
El servidor no necesita base de datos externa. Los patrones de desinformación y datos clave están hardcodeados en src/index.ts:
PATTERNS: array de 6 objetos con nombre, descripción, ejemplos y método de detecciónKEY_FACTS: objeto con 5 categorías (política, economía, terremotos, migración, desinformación)
Esto permite que el MCP funcione offline sin dependencias externas.
Tavily Search (opcional)
La función tavilySearch() en src/index.ts:62:
- Lee
TAVILY_API_KEYdel entorno - Hace POST a
https://api.tavily.com/searchcon query mejorada (agrega "Venezuela" y filtros de fuentes confiables) - Retorna resultados estructurados o un error manejable
- Todas las tools manejan graceful degradation si no hay API key
Herramientas expuestas
| Tool | Input | Output |
|---|---|---|
get_fakenews_patterns |
Ninguno | Lista completa de 6 patrones con ejemplos y detección |
verify_claim |
claim (string), context? (string) |
Análisis del claim + patrones coincidentes + búsqueda web |
search_official_sources |
topic (string), max_results? (number, default 6) |
Resultados de fuentes confiables (USGS, IOM, Reuters, etc.) |
generate_factcheck_report |
topic (string) |
Reporte estructurado borrador con datos clave del cuaderno |
Environment Variables
| Variable | Requerida | Default | Descripción |
|---|---|---|---|
TAVILY_API_KEY |
No | — | API key de Tavily para búsquedas web. Sin ella las tools funcionan con conocimiento base solamente. |
Available Scripts
| Comando | Descripción |
|---|---|
npm run build |
Compila TypeScript a JS con tsc |
npm run start |
Ejecuta dist/index.js directamente |
npm run dev |
Watch mode: compila automáticamente en cada cambio (tsc -w) |
npm run inspect |
Abre el inspector MCP para probar herramientas |
Configuración en OpenCode
Agrega esto a tu ~/.config/opencode/opencode.json o al opencode.json del proyecto:
{
"mcpServers": {
"venezuela-fakenews": {
"command": "node",
"args": ["/Users/josecastro/mcp-venezuela-fakenews/dist/index.js"]
}
}
}
Reinicia opencode o recarga la configuración.
Uso
Listar patrones de desinformación
Usa la herramienta get_fakenews_patterns
Verificar un claim
Usa verify_claim con:
claim: "Delcy Rodríguez anunció aumento de salario a $800 mensuales"
context: "salario"
Buscar fuentes oficiales
Usa search_official_sources con:
topic: "terremotos junio 2026 víctimas oficiales"
Generar reporte
Usa generate_factcheck_report con:
topic: "Situación económica de Venezuela post-terremotos"
Testing
El proyecto actualmente no tiene suite de tests. Para verificar manualmente:
# Compila sin errores
npm run build
# Prueba con el inspector
npm run inspect
Deployment
Como servidor MCP local (recomendado)
No necesita deployment — se ejecuta como subproceso del host MCP. Solo compilar y apuntar la configuración MCP al dist/index.js.
Como servicio remoto (experimental)
Si quisieras ejecutarlo como servidor remoto:
- Cambiar
StdioServerTransportporSSEServerTransportdel SDK - Desplegar en cualquier plataforma Node (Railway, Fly.io, Render)
- Configurar el host MCP con la URL del SSE endpoint
Troubleshooting
TAVILY_API_KEY no configurada
Las tools funcionan sin API key, pero las búsquedas web no estarán disponibles. Configúrala en .env o exporta la variable:
export TAVILY_API_KEY="tvly-tu-clave-aqui"
Error de compilación
# Asegúrate de tener TypeScript 6+
npx tsc --version
# Reinstala dependencias
rm -rf node_modules && npm install
El MCP no se conecta
- Verifica que
dist/index.jsexiste (npm run build) - Verifica la ruta absoluta en la configuración MCP
- Ejecuta directamente para ver errores:
node dist/index.js - El servidor escribe logs a STDERR (visible en los logs del host MCP)
Contributing
Este proyecto nace de una investigación sobre desinformación en Venezuela (junio 2026). Las contribuciones son bienvenidas:
- Agregar más patrones a
PATTERNSensrc/index.ts - Mejorar la detección automática de claims en
verify_claim - Conectar con el cuaderno de Obsidian para lectura dinámica
- Agregar tests
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.