Zum Hauptinhalt springen

MCP-Server

Snoopy bietet einen ersten MCP-Server (Model Context Protocol) für programmgesteuerten Agenten-Zugriff. Der Server stellt Snoopy's vollständige Überwachungsoberfläche als MCP-Tools über stdio-Transport bereit.

Server starten

snoopy mcp

Der Server läuft auf stdio-Transport und ist dafür gedacht, von einem MCP-Client (Agenten-Framework) gestartet zu werden. Er akzeptiert keine interaktive Eingabe.

Transport und Umfang

  • Transport: stdio (JSON-RPC-Nachrichten auf stdout, Protokolle auf stderr)
  • Beabsichtigte Verwendung: lokal prozessgestartete MCP-Clients
  • Protokoll: MCP 1.0 mit initialize, tools/list und tools/call

Verfügbare Tools

Der Server stellt 19 Tools bereit, die nach Kategorie organisiert sind:

Gesundheitstools

ToolBeschreibung
snoopy_doctorVollständige Systemgesundheitsprüfung (Datenbank, API-Schlüssel, Daemon, Jobs, Start, kürzliche Fehler)

Daemon-Tools

ToolBeschreibung
snoopy_daemon_statusZeigt an, ob der Daemon läuft und seine PID
snoopy_daemon_startStartet den Hintergrund-Daemon
snoopy_daemon_stopStoppt den Hintergrund-Daemon
snoopy_daemon_reloadHot-Reload der Job-Zeitpläne ohne Neustart

Job-Tools

ToolBeschreibung
snoopy_job_listListet alle Überwachungsjobs mit Zustand, Subreddits, Zeitplan
snoopy_job_runsListet kürzliche Laufhistorie für einen Job oder alle Jobs
snoopy_job_addErstellt einen neuen Überwachungsjob
snoopy_job_deleteLöscht einen Job und alle seine Daten (Läufe, Scan-Elemente, Protokolle)
snoopy_job_enableAktiviert die Planung für einen Job
snoopy_job_disableDeaktiviert die Planung für einen Job
snoopy_job_runLöst einen sofortigen Job-Lauf aus

Analyse- und Ergebnis-Tools

ToolBeschreibung
snoopy_analyticsZeigt Analysen (Tokens, Kosten, Beiträge, Kommentare) für Jobs
snoopy_exportExportiert qualifizierte Scan-Elemente als JSON oder CSV
snoopy_consumeListet und markiert nicht konsumierte qualifizierte Ergebnisse

Diagnose-Tools

ToolBeschreibung
snoopy_errorsZeigt kürzliche fehlgeschlagene oder fehlerhafte Läufe für einen Job
snoopy_logsZeigt die Protokollausgabe für einen bestimmten Lauf an

Einstellungs-Tools

ToolBeschreibung
snoopy_settings_getLiest aktuelle Einstellungen (Modell, API-Schlüssel-Status, Zeitplan)
snoopy_settings_setAktualisiert eine einzelne Einstellung

MCP-Aufrufbeispiele

Tools auflisten

{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/list"
}

Gesundheitsprüfung ausführen

{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "snoopy_doctor",
"arguments": {}
}
}

Jobs auflisten

{
"jsonrpc": "2.0",
"id": 3,
"method": "tools/call",
"params": {
"name": "snoopy_job_list",
"arguments": {}
}
}

Job erstellen

{
"jsonrpc": "2.0",
"id": 4,
"method": "tools/call",
"params": {
"name": "snoopy_job_add",
"arguments": {
"name": "SaaS Lead Monitor",
"subreddits": ["startups", "SaaS", "entrepreneur"],
"qualificationPrompt": "Qualify only if the user is actively seeking SaaS recommendations or alternatives.",
"scheduleCron": "*/30 * * * *"
}
}
}

Ergebnisse exportieren

{
"jsonrpc": "2.0",
"id": 5,
"method": "tools/call",
"params": {
"name": "snoopy_export",
"arguments": {
"jobRef": "saas-lead-monitor",
"format": "json",
"lastRun": true
}
}
}

Fehlerbehandlung

Alle Tools geben Fehler im MCP-Standardformat zurück:

{
"content": [{ "type": "text", "text": "Fehlermeldung" }],
"isError": true
}

Häufige Fehler:

FehlerBedeutung
Job not found: <ref>Ungültige Job-Referenz; überprüfen Sie snoopy_job_list
Run not found: <id>Ungültige Lauf-ID; überprüfen Sie snoopy_job_runs
Unknown setting: <key>Ungültiger Einstellungsschlüssel für snoopy_settings_set

Fehlerbehebung

SymptomWahrscheinliche UrsacheLösung
Server beendet sofortStdio-TransportfehlerStellen Sie sicher, dass Sie im richtigen MCP-Client-Kontext laufen
Tools erscheinen nicht im AgentenServer nicht registriertFühren Sie snoopy agent install <runtime> aus
Doctor zeigt API-Schlüssel fehltSchlüssel nicht konfiguriertFühren Sie snoopy settings aus oder setzen Sie TELEPAT_OPENROUTER_KEY
Job-Lauf fehlschlägtDaemon läuft nichtFühren Sie snoopy daemon start aus

Verwandte Seiten