Skip to main content
Lets MCP-compatible assistants use Octen directly inside their workflow:
  • search — search live web data with ranked results, highlights, filters, and optional full content
  • news_search — search news results for current events, announcements, and timely reporting
  • extract — fetch known URLs as clean markdown or text

Get API Key

Create a key from the API Platform.

GitHub

View source and contribute.

npm

Install the octen-mcp package.

Why Octen MCP

Fast

Web search averages 62ms. Fast enough for multi-step MCP workflows.

Accurate

Powered by SOTA text and VL embedding models. Better sources, fewer hallucinations.

Fresh

Live web data with minute-level updates. Useful for news, prices, and fast-moving pages.

Efficient

Clean highlights, optional full_content, and page labels keep model context relevant.

Installation

You’ll need an Octen API key first. Create one from the API Platform.
Add to claude_desktop_config.json:
{
  "mcpServers": {
    "octen": {
      "command": "npx",
      "args": ["-y", "octen-mcp"],
      "env": {
        "OCTEN_API_KEY": "your-key-here"
      }
    }
  }
}

Tools

ToolUse forReturns
searchWeb search by queryRanked pages with title, url, highlight, and optional full_content
news_searchNews search by querySame as search, with topic fixed to news
extractReading known URLsOne result per URL with content or highlights, category, and page_structure
Use search for live web retrieval. It supports:
  • topic: general or news
  • count: 1-100 results
  • include_domains / exclude_domains
  • include_text / exclude_text
  • time_range, start_time, and end_time
  • highlight snippets or full_content
  • include_images and include_videos
{
  "query": "latest AI agent benchmark results",
  "count": 5,
  "time_range": "week"
}
Use news_search for current events, headlines, announcements, and time-sensitive reporting. It uses Octen Search with topic set to news. Equivalent Search API request:
{
  "query": "Fed rate decision",
  "topic": "news",
  "count": 10,
  "time_range": "day"
}

extract

Use extract when the input is one or more URLs. It supports:
  • urls: 1-20 URLs
  • query: return ranked highlights from each page instead of the full body
  • max_age_seconds: cache freshness control
  • format: markdown or text
  • include_images, include_videos, include_audio, and include_favicon
{
  "urls": [
    "https://docs.octen.ai/api-reference/search",
    "https://docs.octen.ai/api-reference/extract"
  ],
  "format": "markdown"
}

Response shapes

Search returns a query and ranked result list:
{
  "code": 0,
  "msg": "success",
  "request_id": "req_abc123def456",
  "data": {
    "query": "latest AI agent benchmark results",
    "results": [
      {
        "title": "Example result",
        "url": "https://example.com/article",
        "highlight": "Query-relevant snippet...",
        "time_published": "2026-06-20T00:00:00Z",
        "time_last_crawled": "2026-06-23T08:30:05Z"
      }
    ]
  },
  "meta": {
    "usage": { "num_search_queries": 1, "full_content_tokens": 0 },
    "latency": 237
  }
}
Extract returns one result per URL:
{
  "code": 0,
  "msg": "success",
  "request_id": "req_abc123def456",
  "data": {
    "results": [
      {
        "url": "https://docs.octen.ai/api-reference/search",
        "status": "success",
        "title": "Search - Octen",
        "full_content": "Clean markdown or text content...",
        "time_last_crawled": "2026-04-21T08:30:05Z",
        "page_structure": { "primary": "Content Page", "secondary": "Article" },
        "category": { "primary": "Computers, Electronics & Technology", "secondary": "Artificial Intelligence" }
      }
    ]
  },
  "meta": {
    "usage": { "total_urls": 1, "successful_urls": 1 },
    "latency": 1832
  }
}
With extract.query, each successful URL returns highlights instead of full_content. Failed URLs return status: "failed" and an error_message; failed URLs are not billed.

Handling edge cases

ToolSignalRecommended handling
search / news_searchNo results or weak highlightsRewrite the query, adjust filters, widen the time window, or enable full_content for search results.
extractstatus: failedRead error_message; failed URLs are not billed.
extractpage_structure.primary: "No Main Content"Treat it as a login wall, shell page, paywall, or page without useful main content.

Configuration

VariableRequiredDefault
OCTEN_API_KEYYes-
OCTEN_API_URLNohttps://api.octen.ai