Docs

MCP & API Reference

Query behavioral trend data across search, social, and commerce platforms. Use MCP to query via an AI assistant like Claude or ChatGPT, or the REST API to integrate directly into your code.

Base URL
https://api.trendsmcp.ai/api
Method
POST /
Auth
Authorization: Bearer <key>
Format
application/json

Get your free API key

No credit cardInstant delivery100 free requests/mo
4,109,774API calls served
Loved by developers
Check your inbox Your API key is on its way

Nothing there? Check spam or .

What are you working on?

How will you connect?

Sign in to your account

API key sent to your inbox. Sign in to access your dashboard.

Add to your AI in 30 seconds

How will you connect to TrendsMCP?

Which client are you using?

Or configure manually

Cursor SettingsTools & MCPAdd a Custom MCP Server

"trends-mcp": {
  "url": "https://api.trendsmcp.ai/mcp",
  "transport": "http",
  "headers": { "Authorization": "Bearer YOUR_API_KEY" }
}

Mac / Linux — ~/.cursor/mcp.json
Windows — %USERPROFILE%\.cursor\mcp.json

↑ Sign up above first to get your API key — the config won't work without it.

Three steps: open Claude, review the pre-filled form, click Add.

NameTrends MCP
Server URLhttps://www.trendsmcp.ai/mcp

In Claude: SettingsCustomizeConnectorsAdd custom connector. The link above does this for you. Use https://www.trendsmcp.ai/mcp for Claude Connectors (OAuth) or https://api.trendsmcp.ai/mcp for direct MCP config; both reach the same service.

Or configure manually

UserSettingsDeveloperEdit Config — add inside mcpServers

"trends-mcp": {
  "command": "npx",
  "args": [
    "-y",
    "mcp-remote",
    "https://api.trendsmcp.ai/mcp",
    "--header",
    "Authorization:${AUTH_HEADER}"
  ],
  "env": {
    "AUTH_HEADER": "Bearer YOUR_API_KEY"
  }
}

Mac — ~/Library/Application Support/Claude/claude_desktop_config.json
Windows — %APPDATA%\Claude\claude_desktop_config.json

Fully quit and restart Claude Desktop after saving.

Claude Code (CLI)

claude mcp add --transport http trends-mcp https://api.trendsmcp.ai/mcp \
  --header "Authorization: Bearer YOUR_API_KEY"

Windsurf

SettingsAdvanced SettingsCascadeAdd custom server +

"trends-mcp": {
  "url": "https://api.trendsmcp.ai/mcp",
  "transport": "http",
  "headers": { "Authorization": "Bearer YOUR_API_KEY" }
}

Mac / Linux — ~/.codeium/windsurf/mcp_config.json
Windows — %USERPROFILE%\.codeium\windsurf\mcp_config.json
Or: Command Palette → Windsurf: Configure MCP Servers

VS Code

Extensions sidebar → search @mcp trends-mcpInstall — or paste manually into .vscode/mcp.json inside servers

"trends-mcp": {
  "type": "http",
  "url": "https://api.trendsmcp.ai/mcp",
  "headers": { "Authorization": "Bearer YOUR_API_KEY" }
}

Paste into .vscode/mcp.json, or:
Command Palette (⇧⌘P / Ctrl+Shift+P) → MCP: Add Server

Authentication

An account is required to connect — both for MCP and the REST API. Sign up for free with your email and we'll send your API key instantly (100 requests/month, no credit card). Every request must then include that API key as a Bearer token in the Authorization header. How calls are counted is defined below (same rules for REST and MCP).

Never expose your API key in client-side code or public repositories.
curl -X POST https://api.trendsmcp.ai/api \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"source":"google search","keyword":"bitcoin"}'
import requests

res = requests.post(
    "https://api.trendsmcp.ai/api",
    headers={"Authorization": "Bearer YOUR_API_KEY"},
    json={"source": "google search", "keyword": "bitcoin"}
)
res.raise_for_status()
data = res.json()
const res = await fetch("https://api.trendsmcp.ai/api", {
  method: "POST",
  headers: {
    "Authorization": "Bearer YOUR_API_KEY",
    "Content-Type": "application/json"
  },
  body: JSON.stringify({ source: "google search", keyword: "bitcoin" })
});
const data = await res.json();

What counts as a request

Each successful hit against the data API uses one unit of your monthly quota.

Get TrendsHistorical time series for a keyword

One source + keyword per HTTP request or MCP tool call counts as one request.

Get GrowthPoint-to-point growth & momentum

One source + keyword per call counts as one request, including every entry in percent_growth in that same call.

Get Top TrendsLive leaderboards across platforms

Counted per feed (type) and per page. Example with limit 25: offset 0 is one request, offset 25 is another for the same type. Different feeds are separate. If one response includes several feeds, each feed is counted per page on its own.

Data Sources

Two types of sources are available, accessed via different operations. Keyword sources return a historical time series or growth metric for a specific keyword. Live feeds return the top-ranked items on a platform right now. No keyword needed.

Keyword sources (Get Trends & Get Growth)

Pass the source value below in your request body alongside keyword. For Get Growth, pass one source or a comma-separated list (e.g. amazon, tiktok, youtube). For Get Trends, pass one source per request. Scores are normalized to a 0–100 scale where the pipeline supports it.

sourceDescriptionKeyword format
google searchGoogle search volumeAny keyword or phrase
google imagesGoogle image search volumeAny keyword or phrase
google newsGoogle News search volumeAny keyword or phrase
google shoppingGoogle Shopping search volumeAny keyword or phrase
youtubeYouTube search volumeAny keyword or phrase
tiktokTikTok hashtag volumeHashtag or topic
redditSubreddit subscribersSubreddit name only, no r/ prefix
amazonAmazon product search volumeProduct name or category
wikipediaWikipedia page viewsArticle title or topic
news volumeNews article mention volumeAny keyword or phrase
news sentimentNews sentiment score (positive / negative)Any keyword or phrase
app downloadsAndroid app download estimates (AppBrain)Android bundle ID e.g. com.openai.chatgpt
app rankingsAndroid app store ranking charts (AppBrain)Android bundle ID e.g. com.himshers.hims
npmnpm package weekly downloadsExact package name, case-sensitive e.g. react, @babel/core
steamSteam concurrent players (monthly)Game display name e.g. Elden Ring (first Steam search result)

Live feeds (Get Top Trends)

Pass the type value below with mode: "top_trends". No keyword needed. Optional category filter for Amazon Best Sellers by Category and Top Websites. Returns the current ranked leaders on that platform (e.g. the top 25 trending hashtags on TikTok right now).

typePlatform / feed
Google TrendsTop trending search terms on Google right now
Google News Top NewsTop news stories from Google News
TikTok Trending HashtagsTop trending hashtags on TikTok
YouTube TrendingTop trending videos on YouTube
X (Twitter) TrendingTop trending topics on X
Reddit Hot PostsHottest posts on Reddit's front page
Reddit World NewsTop posts in r/worldnews
Wikipedia TrendingMost-viewed Wikipedia articles today
Amazon Best Sellers Top RatedAmazon top-rated best sellers across all categories
Amazon Best Sellers by CategoryAmazon best sellers filtered by product category
App Store Top FreeTop free apps on the iOS App Store
App Store Top PaidTop paid apps on the iOS App Store
Google PlayTop apps on Google Play
Top WebsitesMost-visited websites globally by traffic rank
Spotify Top PodcastsTop podcasts on Spotify
Steam Most PlayedTop games by concurrent live players
GitHub Trending ReposDaily trending repositories across all languages
IMDb MOVIEmeterTop 100 most-popular movies by user activity
Open Library Trending BooksDaily trending books from Open Library

About this data

Trends MCP is an independent analytics service. Output consists of proprietary estimates produced through aggregation, normalization, and modeling of publicly observable signals. Index scores and volume-like figures are not official metrics from any third-party platform. See our Terms of Service for details.

Routing

All requests go to a single POST / endpoint. The operation is selected by the fields you include in the request body.

OperationRequired fields
Get Trendssource + keyword (no percent_growth)
Get Growthsource + keyword (percent_growth optional, defaults to ["12M"])
Get Top Trendsmode: "top_trends"
POST/

Get Growth

Calculates point-to-point percentage growth for a keyword over one or more time windows. Supports preset strings ("12M", "YTD", etc.) or exact custom date pairs. Pass one source or a comma-separated list (e.g. amazon, tiktok, youtube) for multi-source comparison.

Quota: 1 request per source + keyword (all percent_growth periods in that call). Full rules

Request body

FieldTypeRequiredDescription
sourcestringRequiredOne source or comma-separated list. See Data Sources.
keywordstringRequiredKeyword, brand, or topic. Format depends on source — see Data Sources.
percent_growtharrayOptionalPreset strings or custom date objects. Defaults to ["12M"] if omitted.
data_modestringOptionalWeekly only — approximately 5 years. Omit when using MCP.

Growth period presets

7D14D30D1M2M3M6M9M12M1Y18M24M2Y36M3Y48M60M5YMTDQTDYTD

Custom date range object

FieldTypeDescription
namestringOptional label returned in results.
recentstringMore recent date, YYYY-MM-DD.
baselinestringBaseline/comparison date, YYYY-MM-DD.

Response fields

FieldTypeDescription
search_termstringThe keyword queried.
data_sourcestringThe source used.
resultsarrayOne object per period requested.
  periodstringPeriod identifier, e.g. "12M" or custom name.
  growthnumberPercentage change, positive or negative.
  directionstring"increase" or "decrease".
  recent_datestringISO 8601 date of the recent data point.
  baseline_datestringISO 8601 date of the baseline point.
  recent_valuenumberNormalized score at the recent date.
  baseline_valuenumberNormalized score at the baseline date.
  volume_availablebooleanWhether absolute volume exists for this source.
  recent_volumenumber | nullAbsolute volume at the recent date.
  baseline_volumenumber | nullAbsolute volume at the baseline date.
  volume_growthnumber | nullVolume growth %, if available.
metadataobjecttotal_data_points, calculations_completed, all_successful.
{
  "source":         "google search",
  "keyword":        "nike",
  "percent_growth": ["12M", "3M", "YTD"]
}
{
  "source":  "amazon",
  "keyword": "nike",
  "percent_growth": [
    {
      "name":     "Last Year",
      "recent":   "2025-12-31",
      "baseline": "2024-12-31"
    }
  ]
}
{
  "search_term": "nike",
  "data_source": "google search",
  "results": [
    {
      "period":           "12M",
      "growth":           -12.31,
      "direction":        "decrease",
      "recent_date":      "2026-03-21",
      "baseline_date":    "2025-03-22",
      "recent_value":     57,
      "baseline_value":   65,
      "volume_available": true,
      "recent_volume":    24158298,
      "baseline_volume":  27548936,
      "volume_growth":    -12.31
    }
  ],
  "metadata": {
    "total_data_points":      261,
    "calculations_completed": 1,
    "all_successful":         true
  }
}
POST/

Get Top Trends

Returns ranked items from live platform feeds stored for Trends MCP. On the REST API, omit type to aggregate every feed in one response (same semantics the handler uses internally). On MCP, the get_top_trends tool requires an explicit type per call. There is no single MCP invocation that returns all feeds at once.

Quota: per feed (type) and per page (limit / offset). Full rules

Feed labels must match the strings below exactly (including spacing and capitalization).

Request body

FieldTypeDefaultDescription
modestringSet to "top_trends".
typestringall (REST)REST: optional; omit for all feeds. MCP: required (one feed per tool call).
categorystringOptional filter for Amazon Best Sellers by Category and Top Websites only.
limitinteger25Max items per feed (up to 200).
offsetinteger0REST: skip this many rows per feed for pagination (when the backend supports it for that feed).

Available feeds

Amazon Best Sellers by CategoryAmazon Best Sellers Top RatedApp Store Top FreeApp Store Top PaidGitHub Trending ReposGoogle News Top NewsGoogle PlayGoogle TrendsIMDb MOVIEmeterOpen Library Trending BooksReddit Hot PostsReddit World NewsSteam Most PlayedTop WebsitesSpotify Top PodcastsTikTok Trending HashtagsWikipedia TrendingX (Twitter) TrendingYouTube Trending
{
  "mode":  "top_trends",
  "type":  "Google Trends",
  "limit": 10
}
{
  "as_of_ts": "2026-03-26T22:22:25Z",
  "type":     "Google Trends",
  "limit":    10,
  "count":    10,
  "data": [
    [1, "chuck norris"],
    [2, "project hail mary"],
    [3, "bachelorette cancelled"]
    // ... [rank, name] pairs
  ]
}

MCP / AI

AI Prompts

When using Trends MCP through an AI assistant (Claude, ChatGPT, Cursor, etc.), include "using TrendsMCP" or "via TrendsMCP" in your prompt so the AI routes to the MCP instead of a web search.

Get GrowthPoint-to-point growth & momentum
Year-over-year momentum"Using TrendsMCP, how has Google Search interest in GLP-1 grown over the past 12 months?"
Multi-period snapshot"Via TrendsMCP, show me 3M, 6M, and 1Y growth for Anthropic on Google Search."
YTD brand tracking"Using TrendsMCP, what's the YTD Google Search growth for Duolingo?"
Cross-source momentum"Via TrendsMCP, compare 6-month growth for weight loss drugs across Google, TikTok, and Amazon."
News sentiment shift"Using TrendsMCP, how has news sentiment for Meta changed over the past 6 months?"
Custom date range"Via TrendsMCP, show Google Search growth for AI agents from Jan 2025 to Jan 2026."
Subreddit subscriber growth"Using TrendsMCP, what's the subscriber growth for subreddit wallstreetbets on Reddit over the last 30 days?"
Shopping demand signal"Via TrendsMCP, show me 12M Google Shopping growth for running shoes."
Get Top TrendsLive leaderboards across platforms
Google trending now"Using TrendsMCP, what's trending on Google right now?"
TikTok hashtags"Via TrendsMCP, show me the top TikTok trending hashtags today."
Reddit front page"Using TrendsMCP, what are the hottest Reddit posts right now?"
Wikipedia trending"Via TrendsMCP, what are the top trending Wikipedia articles today?"
X / Twitter topics"Using TrendsMCP, show me what's trending on X right now."
App Store charts"Via TrendsMCP, what apps are topping the App Store Free charts today?"
Amazon best sellers (top rated)"Using TrendsMCP, what are the top-rated Amazon best sellers right now?"
Amazon by category"Via TrendsMCP, show Amazon best sellers for category Electronics."
YouTube trending"Via TrendsMCP, what's trending on YouTube right now?"

Live leaderboards: MCP tools require one feed (type) per call. The REST Get Top Trends request can omit type to return every feed in one response.

Errors

Errors return JSON with an error string and message. HTTP status may be 4xx/5xx depending on the failure; some upstream gaps are reported as data_unavailable (or similar) with a generic message rather than not_found.

StatusError codeMeaning
400missing_parameterRequired field missing from request body
400invalid_sourceUnrecognized source value (message may list allowed values)
401Missing or invalid API key
404not_foundNo series or entity matched this keyword/source (when the pipeline classifies it that way)
variesdata_unavailablePipeline could not return data (temporary gap, unsupported query, or empty upstream). HTTP status is not always 404; read message.
429rate_limitedMonthly request limit reached. Upgrade for more.
500internal_errorUnexpected server error

Additional codes can appear as the data layer evolves; treat message as the operator-facing detail.

400 Response
{
  "error":   "missing_parameter",
  "message": "The 'keyword' parameter is required."
}