loading…
Search for a command to run...
loading…
Track how your brand appears in AI-generated answers across ChatGPT, Perplexity, and other AI models. Analyze visibility, sentiment, citations, and domain ranki
Track how your brand appears in AI-generated answers across ChatGPT, Perplexity, and other AI models. Analyze visibility, sentiment, citations, and domain rankings with 31 tools — including analytics reports, chat inspection, query analysis, and full CRUD for brands, prompts, tags, and topics.
Community-built MCP server for the Peec AI API — AI Search Analytics for brand visibility, sentiment, and citations across ChatGPT, Perplexity, and other AI models.
Note: This is an unofficial community project, not affiliated with or endorsed by Peec AI. It requires a Peec AI account and API key.
API Beta: The Peec AI API is currently in beta — endpoints, payloads, and responses may change. Access is limited to Enterprise customers.
Peec AI tracks how brands appear in AI-generated answers. This MCP server gives any MCP-compatible client direct access to that data — 33 tools covering projects, brands, prompts, chats, query analysis, analytics reports, source content, and full CRUD operations.
Key capabilities:
Sign up at app.peec.ai and create an API key under Settings > API Keys.
claude mcp add --transport stdio peecai -- npx -y mcp-server-peecai
Set environment variables:
export PEECAI_API_KEY="your-api-key"
export PEECAI_PROJECT_ID="your-project-id" # optional default
Add to your claude_desktop_config.json:
{
"mcpServers": {
"peecai": {
"command": "npx",
"args": ["-y", "mcp-server-peecai"],
"env": {
"PEECAI_API_KEY": "your-api-key",
"PEECAI_PROJECT_ID": "your-project-id"
}
}
}
}
Add to .vscode/mcp.json in your workspace:
{
"servers": {
"peecai": {
"command": "npx",
"args": ["-y", "mcp-server-peecai"],
"env": {
"PEECAI_API_KEY": "your-api-key",
"PEECAI_PROJECT_ID": "your-project-id"
}
}
}
}
Confirm the peecai server is connected — in Claude Code run /mcp, in VS Code/Cursor check the MCP server status in the output panel.
list_projects — List all projects for the company.
CUSTOMER = active, PITCH = demo)limit, offsetlist_brands — List tracked brands with their associated domains.
project_id, limit, offsetlist_prompts — List monitored search prompts.
project_id, topic_id, tag_id, limit, offsetlist_tags — List category tags for a project.
project_id, limit, offsetlist_topics — List topic groupings for a project.
project_id, limit, offsetlist_models — List tracked AI models (ChatGPT, Perplexity, etc.).
project_id, limit, offsetlist_model_channels — List model channels (stable IDs grouping one or more models, e.g. openai-0, perplexity-0).
project_id, limit, offsetlist_chats — List AI chat interactions with optional date and dimension filtering.
project_id, start_date, end_date, brand_id, prompt_id, model_id, model_channel_id, limit, offsetget_chat_content — Get full content of a specific chat.
chat_id, project_idlist_prompt_suggestions — List AI-generated prompt suggestions.
project_id, topic_id, limit, offsetlist_topic_suggestions — List AI-generated topic suggestions.
project_id, limit, offsetAll report tools support dimensions for multi-level breakdowns: prompt_id, model_id, model_channel_id, tag_id, topic_id, date, country_code, chat_id. Date filtering via start_date / end_date (YYYY-MM-DD). Server-side filtering via filters parameter (field, operator: "in" | "not_in", values).
get_brands_report — Brand analytics per brand.
| Metric | Description |
|---|---|
visibility |
Ratio 0–1 (visibility_count / visibility_total) |
sentiment |
Score 0–100, 50 = neutral |
position |
Average rank when mentioned, lower = better |
share_of_voice |
Share of voice 0–1 (proportion of total mentions) |
mention_count |
Number of times the brand was mentioned |
get_domains_report — Domain-level analytics.
| Metric | Description |
|---|---|
retrieval_rate |
Share of chats retrieving this domain (0–1) |
citation_rate |
Average citations per retrieval |
classification |
OWN, CORPORATE, COMPETITOR, EDITORIAL, REFERENCE, INSTITUTIONAL, UGC, OTHER |
get_urls_report — URL-level analytics.
| Metric | Description |
|---|---|
retrievals |
Number of chats retrieving this URL |
citation_count |
Total citations across all chats |
citation_rate |
Average citations per retrieval |
classification |
HOMEPAGE, PRODUCT_PAGE, CATEGORY_PAGE, LISTICLE, COMPARISON, ARTICLE, HOW_TO_GUIDE, PROFILE, ALTERNATIVE, DISCUSSION, OTHER |
get_url_content — Get the scraped markdown content of a source URL discovered via get_urls_report.
content (markdown, null while scraping pending), title, domain, channel_title, classification, url_classification, content_length, truncated, content_updated_aturl, project_id, max_length (1–20,000,000, default 100,000)max_length, truncated=true — re-request with a larger max_length to get more.search_queries — Get search queries AI models generated when answering prompts.
project_id, start_date, end_date, filters, limit, offsetshopping_queries — Get shopping/product queries AI models generated.
project_id, start_date, end_date, filters, limit, offsetWrite tools are disabled by default for safety. Enable them by setting PEECAI_ALLOW_WRITES=true.
When disabled, these tools are completely invisible — they don't appear in tools/list and cannot be called by any client.
| Entity | Create | Update | Delete |
|---|---|---|---|
| Brands | create_brand |
update_brand |
delete_brand |
| Prompts | create_prompt |
update_prompt |
delete_prompt |
| Tags | create_tag |
update_tag |
delete_tag |
| Topics | create_topic |
update_topic |
delete_topic |
| Suggestions | Accept | Reject |
|---|---|---|
| Prompt suggestions | accept_prompt_suggestion |
reject_prompt_suggestion |
| Topic suggestions | accept_topic_suggestion |
reject_topic_suggestion |
Delete operations are soft-deletes and irreversible through the API. Delete tools carry destructiveHint: true in their MCP annotations, causing clients like Claude Code to require explicit user approval before execution.
| Tool type | Read-only | Idempotent | Destructive |
|---|---|---|---|
| All read tools (17) | Yes | Yes | No |
| Create (4) | No | No | No |
| Update (4) | No | Yes | No |
| Delete (4) | No | Yes | Yes |
| Accept suggestion (2) | No | No | No |
| Reject suggestion (2) | No | Yes | No |
MCP resources provide reference data that clients can fetch without a tool call.
| Resource | Type | Description |
|---|---|---|
peecai://projects |
Static | List all projects |
peecai://projects/{project_id}/brands |
Template | Brands for a project |
peecai://projects/{project_id}/tags |
Template | Tags for a project |
peecai://projects/{project_id}/topics |
Template | Topics for a project |
peecai://projects/{project_id}/models |
Template | AI models for a project |
peecai://projects/{project_id}/prompts |
Template | Prompts for a project |
Resource templates support listing — clients can enumerate available resources across all projects.
Guided analytical workflows available as MCP prompts. All prompts support project_id autocompletion.
| Prompt | Description |
|---|---|
brand-visibility-analysis |
Analyze brand visibility, sentiment, and position across AI models |
competitive-gap-analysis |
Compare own brand vs competitors across prompts and models |
ai-search-citation-report |
Analyze domain and URL citations in AI responses |
"List my Peec AI projects"
"Show brand visibility for the last 30 days"
"Which domains get cited most in AI search results?"
"Compare brand sentiment across ChatGPT and Perplexity"
"Show me the full chat content for chat ID abc-123"
"Get URL report broken down by AI model and country"
"What search queries do AI models use when answering my prompts?"
"Create a brand 'My Brand' with domain mybrand.com"
"Add a new prompt: 'best CRM software 2025' for country DE"
| Variable | Required | Description |
|---|---|---|
PEECAI_API_KEY |
Yes | API key from app.peec.ai |
PEECAI_PROJECT_ID |
No | Default project ID — saves repeating it in every tool call |
PEECAI_ALLOW_WRITES |
No | Set to true to enable write operations (create/update/delete). Disabled by default for safety. |
This server implements the MCP 2025-11-25 specification:
structuredContent alongside text for type-safe client parsingreadOnlyHint, destructiveHint, idempotentHint on every toolprogressTokenproject_id argument supports autocompletion via completable()list callbacks for enumerating resources across projectsAbortSignal to API callsThe Peec AI API is in beta and may change. A drift detection script compares the live OpenAPI spec against a committed snapshot:
npm run check:api-drift
No API key is required — the OpenAPI spec is publicly accessible.
npm install # Install dependencies
npm run build # Compile TypeScript to dist/
npm run dev # Watch mode — recompile on changes
npm test # Run unit tests (372 tests)
npm run test:watch # Run tests in watch mode
npm run test:integration # Run integration tests (requires PEECAI_API_KEY)
npm run check:api-drift # Check for API spec changes
Integration tests hit the live Peec AI API and are skipped by default in npm test.
# Read-only smoke test (all 17 read tools + prompts + resources)
PEECAI_API_KEY=xxx npm run test:integration
# Full CRUD round-trip (requires a test project + write access)
PEECAI_ALLOW_WRITES=true PEECAI_TEST_PROJECT_ID=or_xxx npm run test:integration
src/
├── index.ts # Server entry point, tool/resource/prompt registration
├── api-client.ts # HTTP client for Peec AI Customer API
├── types.ts # TypeScript interfaces for API responses
├── schemas.ts # Zod output schemas for structured content
├── util.ts # Validation, date handling, MCP response helpers
├── prompts.ts # MCP prompt templates (guided workflows)
└── tools/ # One file per MCP tool (or tool group)
├── projects.ts # list_projects
├── brands.ts # list_brands
├── prompts.ts # list_prompts
├── tags.ts # list_tags
├── topics.ts # list_topics
├── models.ts # list_models
├── model-channels.ts # list_model_channels
├── chats.ts # list_chats
├── chat-content.ts # get_chat_content
├── prompt-suggestions.ts # list_prompt_suggestions
├── topic-suggestions.ts # list_topic_suggestions
├── report-brands.ts # get_brands_report
├── report-domains.ts # get_domains_report
├── report-urls.ts # get_urls_report
├── url-content.ts # get_url_content
├── queries-search.ts # search_queries
├── queries-shopping.ts # shopping_queries
├── write-brands.ts # create/update/delete brand
├── write-prompts.ts # create/update/delete prompt
├── write-tags.ts # create/update/delete tag
├── write-topics.ts # create/update/delete topic
└── suggestion-actions.ts # accept/reject suggestions
Built by Tobias Hein at artaxo — a digital marketing agency specializing in AI Search Optimization.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"mcp-server-peecai": {
"command": "npx",
"args": []
}
}
}