Skip to main content
Cloudflare Logpush is currently an Enterprise-only feature. If you don’t see the Logpush option, you’ll need to upgrade to the Enterprise Cloudflare plan.

Step 1: Create an API Key

Create an API key in Promptwatch. Go to Settings → API Keys in your Promptwatch dashboard.

Step 2: Create a Logpush Job

Go to your Cloudflare dashboard, select your domain and navigate to Analytics & Logs > Logpush > Create a Logpush job.

Step 3: Configure HTTP Destination

For destination select HTTP destination. Enter the following HTTP endpoint URL:
https://logs.promptwatch.com/event/cloudflare?header_authorization=Bearer%20YOUR_API_KEY
Replace YOUR_API_KEY with your actual API key.

Step 4: Configure Logpush Job

For dataset select HTTP Requests and configure the logpush job as follows: Name: promptwatch-crawler-logs If logs match:
  • Field: ClientRequestHost
  • Operator: Equals
  • Value: YOUR_DOMAIN (example: app.promptwatch.com)
Send the following fields: Request
  • ClientIP
  • ClientRequestHost
  • ClientRequestMethod
  • ClientRequestReferer
  • ClientRequestURI
  • ClientRequestUserAgent
General
  • WorkerSubrequest (allows us to filter out requests initiated from a Worker, since they will be seen as duplicate)
Performance
  • EdgeStartTimestamp
Response
  • EdgeResponseContentType
  • EdgeResponseStatus
Advanced options: Keep the default settings as is. The timestamp format should be rfc3339, which is the default format.

Optional: Filter on known AI Crawler user agents

Promptwatch identifies AI crawlers automatically and only stores AI crawler visits, all other traffic is discarded. You can safely send all your server logs without worrying about non-crawler data being retained. If you prefer to only forward AI crawler traffic, you can use the user agents listed below to pre-filter on your side. Keep in mind that you’ll need to maintain this list yourself as new crawlers emerge.
NameUser AgentFull User AgentDescription
GPT BotGPTBotMozilla/5.0 (compatible; GPTBot/1.0; +https://openai.com/gptbot)Used to crawl content for training OpenAI’s generative AI foundation models.
SearchBotOAI-SearchBotMozilla/5.0 (compatible; OAI-SearchBot/1.0; +https://openai.com/searchbot)Used by ChatGPT search to surface websites in search results.
ChatGPT CitationsChatGPT-UserMozilla/5.0 (compatible; ChatGPT-User/1.0; +https://openai.com/bot)Used for user actions in ChatGPT when visiting web pages.
NameUser AgentFull User AgentDescription
Claude BotClaudeBotMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko); compatible; ClaudeBot/1.0; +claudebot@anthropic.com)Used to crawl content for training Anthropic’s generative AI models.
Claude CitationsClaude-UserMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko); compatible; Claude-User/1.0; +claudebot@anthropic.com)When individuals ask questions to Claude or use Claude Code, it may access websites using a Claude-User agent.
Claude Search BotClaude-SearchBotMozilla/5.0 (compatible; claude-search-bot/1.0; +http://www.anthropic.com/bot.html)Navigates the web to improve search result quality for users.
Claude Webclaude-webMozilla/5.0 (compatible; claude-web/1.0; +http://www.anthropic.com/bot.html)Targeted crawler for recent web content, feeding the Claude browser agent with updated site data.
Anthropic AIanthropic-aiMozilla/5.0 (compatible; anthropic-ai/1.0; +http://www.anthropic.com/bot.html)Primary Anthropic crawler that collects broad web data for Claude model development.
NameUser AgentFull User AgentDescription
GeminiGoogle-ExtendedMozilla/5.0 (compatible; Google-Extended/1.0; +http://www.google.com/bot.html)Controls whether content can be used for training Gemini AI models.
Google Mobile AgentGoogle-AgentMozilla/5.0 (Linux; Android 6.0.1; Nexus 5X Build/MMB29P) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/W.X.Y.Z Mobile Safari/537.36 (compatible; Google-Agent; +https://developers.google.com/crawling/docs/crawlers-fetchers/google-agent)Used by Google AI agents to autonomously browse the web and complete tasks on behalf of users (mobile).
Google Desktop AgentGoogle-AgentMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; Google-Agent; +https://developers.google.com/crawling/docs/crawlers-fetchers/google-agent) Chrome/W.X.Y.Z Safari/537.36Used by Google AI agents to autonomously browse the web and complete tasks on behalf of users (desktop).
NameUser AgentFull User AgentDescription
Perplexity BotPerplexityBotMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; PerplexityBot/1.0; +https://perplexity.ai/perplexitybot)Used to surface and link websites in Perplexity search results.
Perplexity CitationsPerplexity-UserMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; Perplexity-User/1.0; +https://perplexity.ai/perplexity-user)Used for user actions in Perplexity when visiting web pages to answer questions.
NameUser AgentFull User AgentDescription
Cohere AIcohere-aiMozilla/5.0 (compatible; cohere-ai/1.0; +http://www.cohere.ai/bot.html)Collects textual data for Cohere’s language models, helping refine large-scale text generation.
NameUser AgentFull User AgentDescription
Mistral AI CitationsMistralAI-UserMozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; MistralAI-User/1.0; +https://docs.mistral.ai/robots)Used for user actions in LeChat when visiting web pages to answer questions.
NameUser AgentFull User AgentDescription
DeepSeekDeepSeekBotMozilla/5.0 (compatible; DeepSeekBot/1.0; +http://www.deepseek.com/bot.html)Used to crawl content for training DeepSeek’s generative AI models.
NameUser AgentFull User AgentDescription
Grok BotGrokBotGrokBot/1.0 (+https://x.ai)Used for training Grok AI.
Grok SearchxAI-GrokxAI-Grok/1.0 (+https://grok.com)Used for Grok’s search capabilities.
Grok Deep SearchGrok-DeepSearchGrok-DeepSearch/1.0 (+https://x.ai)Used for Grok’s advanced search capabilities.

Step 5: Verify Cloudflare Proxy is Enabled

Verify your domain’s DNS records have the Cloudflare proxy enabled (orange cloud icon). Logpush for HTTP Requests only captures traffic that flows through the Cloudflare network. If the proxy is off (gray cloud / “DNS only”), Cloudflare never sees the requests and can’t push logs. Go to your Cloudflare dashboard → DNSRecords and make sure the Proxy status shows the orange cloud (“Proxied”) for your domain’s A/AAAA/CNAME records. Cloudflare DNS proxy enabled

Step 6: Finish

Once submitted, your Cloudflare Logpush job will automatically send crawler logs to Promptwatch when an AI crawler visits your website. Depending on how active your website is, this can take a few minutes to appear.