Skip to main content
Glama
Sleywill

SnapAPI MCP Server

snapapi-mcp

MCP (Model Context Protocol) Server für SnapAPI — Erstellen Sie Screenshots, scrapen Sie Webseiten, extrahieren Sie Inhalte, generieren Sie PDFs, nehmen Sie Videos auf und analysieren Sie Seiten direkt aus KI-Tools wie Claude Desktop, Cursor, Windsurf, Cline und Zed.

Was ist das?

Dieses Paket führt einen lokalen MCP-Server aus, der Ihren KI-Assistenten mit der SnapAPI Web-Capture-API verbindet. Sobald die Konfiguration abgeschlossen ist, kann Ihre KI:

  • Screenshots erstellen von jeder URL (ganze Seite, mobil, Dark Mode, Elementauswahl, Geräteemulation)

  • Webseiten scrapen und sauberen Text, HTML oder Linklisten mithilfe eines echten Browsers abrufen

  • Inhalte extrahieren, die für die LLM-Verarbeitung optimiert sind (Markdown, Artikel, Metadaten, strukturierte Daten)

  • PDFs generieren aus URLs oder HTML

  • Videos aufnehmen von Browsersitzungen mit optionalen Interaktionsszenarien

  • Seiten analysieren mit KI (Extrahieren + Analysieren in einem Aufruf)

  • Ihre Nutzung und Kontostatistiken überprüfen

Voraussetzungen

  • Node.js 18 oder neuer

  • Ein SnapAPI-API-Schlüssel — erhältlich unter app.snapapi.pics

Schnellstart

Claude Desktop

Fügen Sie dies zu ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) oder %APPDATA%\Claude\claude_desktop_config.json (Windows) hinzu:

{
  "mcpServers": {
    "snapapi": {
      "command": "npx",
      "args": ["-y", "snapapi-mcp"],
      "env": {
        "SNAPAPI_API_KEY": "sk_live_your_key_here"
      }
    }
  }
}

Starten Sie Claude Desktop nach dem Speichern neu.

Cursor

Fügen Sie dies zu ~/.cursor/mcp.json hinzu:

{
  "mcpServers": {
    "snapapi": {
      "command": "npx",
      "args": ["-y", "snapapi-mcp"],
      "env": {
        "SNAPAPI_API_KEY": "sk_live_your_key_here"
      }
    }
  }
}

Windsurf

Fügen Sie dies zu ~/.codeium/windsurf/mcp_config.json hinzu:

{
  "mcpServers": {
    "snapapi": {
      "command": "npx",
      "args": ["-y", "snapapi-mcp"],
      "env": {
        "SNAPAPI_API_KEY": "sk_live_your_key_here"
      }
    }
  }
}

Cline (VS Code)

Öffnen Sie die Cline-Einstellungen → MCP Servers → Add Server:

  • Command: npx

  • Args: -y snapapi-mcp

  • Environment: SNAPAPI_API_KEY=sk_live_your_key_here

VS Code (native MCP-Unterstützung)

Fügen Sie dies zu .vscode/mcp.json in Ihrem Arbeitsbereich (oder Ihren Benutzereinstellungen) hinzu:

{
  "servers": {
    "snapapi": {
      "command": "npx",
      "args": ["-y", "snapapi-mcp"],
      "env": {
        "SNAPAPI_API_KEY": "sk_live_your_key_here"
      }
    }
  }
}

Zed

Fügen Sie dies zu ~/.config/zed/settings.json hinzu:

{
  "context_servers": {
    "snapapi": {
      "command": {
        "path": "npx",
        "args": ["-y", "snapapi-mcp"],
        "env": {
          "SNAPAPI_API_KEY": "sk_live_your_key_here"
        }
      }
    }
  }
}

Automatisierter Installer

Führen Sie das enthaltene Hilfsskript aus:

# For Claude Desktop
./install-mcp.sh claude

# For Cursor
./install-mcp.sh cursor

# For Windsurf
./install-mcp.sh windsurf

Verfügbare Tools

ping

Überprüfen Sie, ob SnapAPI erreichbar ist und Ihr API-Schlüssel gültig ist. Keine Parameter erforderlich.

Beispiel-Prompt: "Ping SnapAPI, um zu prüfen, ob es funktioniert"


screenshot

Erstellen Sie einen Screenshot einer beliebigen URL mit umfangreichen Anpassungsmöglichkeiten.

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

*

URL für die Aufnahme

html

string

*

Rohes HTML zum Rendern (Alternative zu url)

markdown

string

*

Markdown zum Rendern (Alternative zu url)

format

string

nein

png, jpeg, webp oder avif (Standard: png)

quality

number

nein

1–100 für jpeg/webp (Standard: 80)

width

number

nein

Viewport-Breite (Standard: 1280)

height

number

nein

Viewport-Höhe (Standard: 800)

fullPage

boolean

nein

Ganze scrollbare Seite aufnehmen

selector

string

nein

CSS-Selektor für Elementaufnahme

delay

number

nein

Wartezeit in ms nach dem Laden der Seite vor der Aufnahme

waitUntil

string

nein

load, domcontentloaded oder networkidle

darkMode

boolean

nein

Dunkles Farbschema

blockAds

boolean

nein

Werbenetzwerke blockieren

blockCookieBanners

boolean

nein

Cookie-Popups blockieren

css

string

nein

Benutzerdefiniertes CSS zum Injizieren

javascript

string

nein

Benutzerdefiniertes JS zum Ausführen

device

string

nein

Geräte-Preset (z. B. iphone-15-pro) — verwenden Sie list_devices, um alle zu sehen

hideSelectors

string[]

nein

Elemente, die vor der Aufnahme ausgeblendet werden sollen

*Mindestens einer der Parameter url, html oder markdown muss angegeben werden.

Beispiel-Prompts:


scrape

Scrapen Sie Webseiteninhalte mithilfe eines echten Browsers (JavaScript-gerenderte Seiten funktionieren).

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

ja

URL zum Scrapen

type

string

nein

text (Markdown), html oder links (Standard: text)

pages

number

nein

Zu verfolgende Seiten, 1–10 (Standard: 1)

waitMs

number

nein

Zusätzliche Wartezeit in ms nach dem Laden der Seite

blockResources

boolean

nein

Bilder/Medien/Schriftarten blockieren, um den Vorgang zu beschleunigen

locale

string

nein

Browser-Gebietsschema (z. B. en-US)

premiumProxy

boolean

nein

Residential Proxy verwenden, um Blockaden zu umgehen

Beispiel-Prompts:


extract

Extrahieren Sie saubere, strukturierte Inhalte, die für LLMs optimiert sind.

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

ja

URL zum Extrahieren

type

string

nein

markdown, text, html, article, links, images, metadata oder structured (Standard: markdown)

selector

string

nein

Extraktion auf ein CSS-Element begrenzen

waitFor

string

nein

Auf CSS-Selektor warten vor dem Extrahieren

maxLength

number

nein

Maximale Zeichenlänge

cleanOutput

boolean

nein

Rauschen entfernen (Standard: true)

blockAds

boolean

nein

Werbenetzwerke blockieren

blockCookieBanners

boolean

nein

Cookie-Popups blockieren

fields

object

nein

Benutzerdefinierte Feld-Extraktionszuordnung

Beispiel-Prompts:


pdf

Generieren Sie ein PDF aus einer URL oder HTML.

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

*

URL zur PDF-Konvertierung

html

string

*

HTML zur PDF-Konvertierung (Alternative zu url)

pdfOptions.pageSize

string

nein

a4, a3, a5, letter, legal, tabloid (Standard: a4)

pdfOptions.landscape

boolean

nein

Querformat

pdfOptions.printBackground

boolean

nein

Hintergrundgrafiken einbeziehen

pdfOptions.scale

number

nein

Skalierungsfaktor 0.1–2

pdfOptions.marginTop

string

nein

Oberer Rand, z. B. 1cm

pdfOptions.marginBottom

string

nein

Unterer Rand

pdfOptions.marginLeft

string

nein

Linker Rand

pdfOptions.marginRight

string

nein

Rechter Rand

delay

number

nein

Wartezeit in ms nach dem Laden der Seite

waitUntil

string

nein

load, domcontentloaded oder networkidle

*Mindestens einer der Parameter url oder html muss angegeben werden.

Beispiel-Prompts:


analyze

Extrahieren Sie Inhalte von einer URL und analysieren Sie diese mit einem KI-Modell in einem einzigen Aufruf.

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

ja

URL zur Analyse

prompt

string

ja

Analyseanweisung für die KI

extractType

string

nein

markdown, text, article oder structured (Standard: article)

maxLength

number

nein

Maximale Zeichenanzahl des Inhalts für die KI (Standard: 20000)

Beispiel-Prompts:


video

Nehmen Sie eine Browsersitzung als Video (WebM) auf.

Parameter:

Parameter

Typ

Erforderlich

Beschreibung

url

string

ja

URL zur Aufnahme

duration

number

nein

Aufnahmedauer in Sekunden, 1–60 (Standard: 5)

width

number

nein

Viewport-Breite (Standard: 1280)

height

number

nein

Viewport-Höhe (Standard: 800)

scenario

string

nein

JavaScript, das während der Aufnahme ausgeführt werden soll (scrollen, klicken usw.)

delay

number

nein

Wartezeit in ms vor Beginn der Aufnahme

waitUntil

string

nein

load, domcontentloaded oder networkidle

darkMode

boolean

nein

Dunkles Farbschema

blockAds

boolean

nein

Werbenetzwerke blockieren

blockCookieBanners

boolean

nein

Cookie-Popups blockieren

device

string

nein

Geräte-Preset — verwenden Sie list_devices, um alle zu sehen

Beispiel-Prompts:


get_usage

Überprüfen Sie Ihr SnapAPI-Kontingent und Ihre monatlichen Statistiken. Keine Parameter erforderlich.

Beispiel-Prompts:

  • "Wie viele SnapAPI-Anfragen habe ich diesen Monat noch übrig?"

  • "Zeige mir meine SnapAPI-Nutzung"


list_devices

Listen Sie alle verfügbaren Geräte-Presets für Screenshot- und Videoemulation auf. Keine Parameter erforderlich.

Beispiel-Prompt: "Welche Geräte-Presets sind für Screenshots verfügbar?"


Umgebungsvariablen

Variable

Erforderlich

Beschreibung

SNAPAPI_API_KEY

Ja

Ihr SnapAPI-API-Schlüssel (sk_live_...)

SNAPAPI_BASE_URL

Nein

API-Basis-URL (Standard: https://api.snapapi.pics)


Entwicklung

# Clone the repo
git clone https://github.com/Sleywill/snapapi-mcp.git
cd snapapi-mcp

# Install dependencies
npm install

# Build
npm run build

# Run locally (reads MCP protocol from stdin)
SNAPAPI_API_KEY=sk_live_your_key node dist/index.js

Fehlerbehebung

"SNAPAPI_API_KEY environment variable is required" Stellen Sie sicher, dass der env-Block in Ihrer MCP-Konfiguration Ihren API-Schlüssel enthält. Prüfen Sie, ob er mit sk_live_ beginnt.

Tools erscheinen nicht in Claude Desktop Starten Sie Claude Desktop nach dem Speichern der Konfiguration neu. Überprüfen Sie die MCP-Protokolle unter:

  • macOS: ~/Library/Logs/Claude/mcp*.log

  • Windows: %APPDATA%\Claude\logs\mcp*.log

npx dauert beim ersten Ausführen zu lange Verwenden Sie "args": ["-y", "snapapi-mcp"] — das -y-Flag bestätigt die Installationsaufforderung automatisch ohne Interaktion.

screenshot / scrape gibt einen Fehler zurück

  • Überprüfen Sie, ob Ihr API-Schlüssel unter app.snapapi.pics/dashboard gültig ist

  • Überprüfen Sie Ihr verbleibendes Kontingent mit dem get_usage-Tool

  • Versuchen Sie bei JavaScript-lastigen Seiten, "waitUntil": "networkidle" und einen "delay"-Wert hinzuzufügen

analyze-Tool gibt einen Fehler zurück Der Analyse-Endpunkt erfordert Anthropic-API-Guthaben im SnapAPI-Backend. Verwenden Sie das extract-Tool als Fallback, um den Seiteninhalt abzurufen und ihn selbst zu analysieren.


Lizenz

MIT

Install Server
A
security – no known vulnerabilities
A
license - permissive license
A
quality - A tier

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/Sleywill/snapapi-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server