Altaviz
Monitors and manages Google Ads campaigns, detecting anomalies such as creative fatigue, CPA drift, spend spikes, conversion tracking outages, and underfunded winners.
Monitors and manages Meta ad campaigns, detecting anomalies such as creative fatigue, CPA drift, spend spikes, conversion tracking outages, and underfunded winners.
Monitors and manages TikTok ad campaigns, detecting anomalies such as creative fatigue, CPA drift, spend spikes, conversion tracking outages, and underfunded winners.
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., "@Altavizfind anomalies and tell me what they cost per day"
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.
Altaviz — AI Media Buying Copilot
Live: altaviz.vercel.app · MCP: https://altaviz.vercel.app/api/mcp
Built by David Fernandez for the It's Today Media Build Challenge.
60-second tour: open the demo → expand the Google tracking-outage finding → ask the copilot "What should I kill today?" → approve its actions in the queue.
What it does
Watches a multi-platform ad account (Meta, Google, Taboola, TikTok) and closes the gap between when something breaks and when a human notices.
Detect — a statistical engine (plain TypeScript, no LLM in the loop) finds the five failure modes that cost affiliate teams money: creative fatigue, CPA drift, spend spikes, conversion-tracking outages, underfunded winners. Every finding ships with evidence and a $/day impact.
Decide — a Claude copilot (streaming tool-use agent,
claude-sonnet-5) grounded in the same tools. "What should I kill today?" gets dollars, evidence, and reasoning — it knows a tracking outage means "fix the pixel", not "cut spend".Act, approved — the agent proposes typed actions with exact platform-API params. They queue for human approval. Nothing executes without a click.
MCP — the identical tool registry is a Model Context Protocol server, so the team can drive the account from Claude Desktop, Claude Code, or Cursor.
claude mcp add --transport http altaviz https://altaviz.vercel.app/api/mcp{
"mcpServers": {
"altaviz": {
"command": "npx",
"args": ["-y", "mcp-remote", "https://altaviz.vercel.app/api/mcp"]
}
}
}Demo data: a deterministic seeded account — 6 campaigns, 90 days, realistic affiliate economics (CPA at 60–85% of payout), five injected anomalies. No database; every visitor sees the same story. Real platform adapters swap in behind the same Account → Campaign → AdSet → Ad → DailyMetric interface.
Related MCP server: Meta Ads MCP
Why this tool
Your business buys media to build email/SMS lists; ROI is the metric. The expensive failures at that scale aren't strategy — they're detection lag. Dashboards show numbers, not what changed, what it costs per day, and what to do. I chose this over a creative generator or LP builder deliberately: those make more assets; this protects margin on every dollar already being spent — and it's the class of system I've built for five years (anomaly detection on streaming data, agentic tool-use).
Design decisions:
Statistics, not prompts. z-scores, trend slopes, significance gates in
lib/detect. LLMs narrate and decide; they never invent numbers. Findings are reproducible and auditable.List economics built in. Pause/scale calls are priced on payout plus a configurable backend $/lead — list-building campaigns often run at front-end breakeven on purpose, and the detectors know that.
One tool registry, two consumers.
lib/toolsdefines each tool once (zod schema + executor); the chat agent and MCP server both consume it.Hard approval boundary. The agent can propose
raise_budget; it cannot call it. Product decision, not a gap.Public-demo hardening: per-IP rate limiting, capped agent turns/tokens/history.
What I'd build next
Weeks 1–2: read-only Meta/Google Ads API adapters behind the existing interface; validate detector thresholds against incidents your buyers remember.
Weeks 3–4: scheduled morning briefing to Slack with approve buttons; wire approved actions to platform APIs behind the same HITL boundary, with an audit log.
Month 2: close the creative loop — fatigue finding → refresh brief → your video-gen pipeline → upload as paused drafts via your ads MCP server.
Ongoing: eval suites — detector precision/recall on known incidents; copilot recommendations scored against what senior buyers actually did.
Architecture
Next.js 16 · TypeScript · Tailwind · @anthropic-ai/sdk · mcp-handler · zod · React Three Fiber (hero) · Vercel.
lib/data/ seeded account generator + types
lib/detect/ statistical anomaly engine (pure functions)
lib/tools/ ONE zod tool registry → consumed by both ↓
app/api/chat/ streaming Claude agent loop (NDJSON)
app/api/[transport]/ MCP server (Streamable HTTP)
app/app/ dashboard · app/ landingnpm install
ANTHROPIC_API_KEY=sk-ant-... npm run dev # everything but chat works without a key
npx tsx scripts/sanity.ts # prints KPIs + anomaly findings, no serverKnown limits (deliberate for a demo): in-memory rate limiting (per serverless instance); chat history replays as text only; MCP is unauthenticated read-only demo data.
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/davidfertube/altaviz'
If you have feedback or need assistance with the MCP directory API, please join our Discord server