The Xquik REST API v1 provides programmatic access to X data and automation. Endpoints are organized into these categories:Documentation Index
Fetch the complete documentation index at: https://docs.xquik.com/llms.txt
Use this file to discover all available pages before exploring further.
Monitors & Events
Create account and keyword monitors, retrieve events, manage webhooks
Draws & Extractions
Run giveaway draws, extract tweet data
X Data
User lookups, tweet search, trends, media downloads
X Write Actions
Post tweets, like, retweet, follow, DM, profile updates
Account & Billing
Account info, API keys, drafts, styles, subscriptions
Base URL
301 redirect to HTTPS. Always use the full base URL.
OpenAPI spec
The full API specification is available as an OpenAPI 3.1 document:Authentication
Pass your API key via thex-api-key header:
Machine Payments Protocol
31 X-API endpoints also accept anonymous MPP payments. The server returns a 402 challenge; your client pays via Tempo (USDC) and retries with a payment credential. No API key needed. See the MPP overview for eligible endpoints and pricing.First request
Copy-paste this to verify your API key works:xq_YOUR_KEY_HERE with your actual API key from the dashboard. If you get 401, double-check that the header name is x-api-key (lowercase) and the key starts with xq_.
Integration readiness checklist
Run this checklist before connecting a production client, workflow builder, or agent to the API.Authentication
Send
x-api-key on subscription endpoints or use the documented MPP flow on eligible X data endpoints. Handle 401 unauthenticated, 402 no_subscription, or an MPP 402 payment challenge.Response contract
Default REST examples use the v1 shape. Send
xquik-api-contract: 2026-04-29 only when your client expects snake_case, structured errors, has_more, and next_cursor. This prevents field-name drift between generated clients, MCP calls, and hand-written REST code.Pagination
Use
after with nextCursor on events, draws, extractions, and drafts. Use cursor with next_cursor on X data endpoints. Handle missing pages, duplicate records, and opaque cursors.Billing
Handle
402 no_credits and 402 insufficient_credits. Estimate extraction cost before creating extraction jobs so partial paid result pages, failed draws, or blocked jobs are expected states.Rate limits
Respect
Retry-After. Read calls are 10 per 1s, write calls are 30 per 60s, and delete calls are 15 per 60s. Back off on repeated 429 rate_limit_exceeded responses.Ambiguous writes
Treat
202 x_write_unconfirmed as pending confirmation. Store writeActionId, call GET /x/write-actions/{id}, and do not retry-send while status is pending_confirmation.Rate limits
Read requests
GET, HEAD, and OPTIONS requests share a 10 per 1s user bucket.
Standard read throttles return Retry-After: 1.Write requests
POST, PUT, and PATCH requests share a 30 per 60s user bucket.
Throttled writes return Retry-After: 60.Delete requests
DELETE requests use a separate 15 per 60s user bucket. Throttled deletes
return Retry-After: 60.429 rate_limit_exceeded with Retry-After and a JSON retryAfter field. See the Rate Limits guide for backoff implementations in multiple languages.
Conventions
IDs are strings
IDs are strings
All IDs are returned as strings representing bigint values. Always treat IDs as opaque strings - never parse them as numbers:
Timestamps are ISO 8601 UTC
Timestamps are ISO 8601 UTC
All timestamps use ISO 8601 format in UTC. Store and compare timestamps as strings or parse them into proper date objects:
Errors follow a consistent format
Errors follow a consistent format
All errors return a JSON body with an Common errors:See Error Handling for the full error code list and handling strategies.
error field containing a machine-readable error code:400 validation
invalid_input means the request body, query, or path failed
validation. Fix the schema, field types, or required parameters before
retrying.401 authentication
unauthenticated means the API key or bearer token is missing or
invalid. Send x-api-key or a valid Authorization bearer token.402 billing state
no_subscription, no_credits, and insufficient_credits mean the
request needs an active plan, credit balance, or top-up before retrying.404 missing resource
not_found means the requested resource does not exist or is not
available to the authenticated account.429 rate limit
rate_limit_exceeded includes Retry-After and JSON retryAfter.
Wait for the window and retry with backoff.502 read service retry
x_api_unavailable means the read service is temporarily unavailable.
Retry with exponential backoff.Cursor-based pagination
Cursor-based pagination
- Platform endpoints
- X endpoints
Events, draws, extractions, and drafts use cursor-based pagination. When more results exist, the response includes Pass
hasMore: true and a nextCursor value:nextCursor as the after query parameter to fetch the next page:Opt-in response contract
Opt-in response contract
v1 keeps the default response contract unchanged for existing clients. Send Opt-in responses use snake_case field names, Unix timestamps in seconds, structured error objects, Legacy dependency failures that return
xquik-api-contract: 2026-04-29 to opt in to the normalized v1 response contract.has_more and next_cursor pagination fields, an object field on recognized resources, and prefixed IDs where available.502 by default return 424 Failed Dependency in the opt-in contract:Event types
Monitor events
Used across monitors, webhooks, and events:tweet.new
Original tweet posted by the monitored account or matching query. Used when
no reply, quote, or retweet signal is present.
tweet.quote
Quote tweet posted by the monitored account or matching query. Classified
when quote metadata is present.
tweet.reply
Reply posted by the monitored account or matching query. Classified from
reply flags or reply target IDs.
tweet.retweet
Retweet posted by the monitored account or matching query. Classified from
retweet flags or
RT @ text.Next steps
Error Handling
Handle errors gracefully with retries and fallbacks.
Rate Limits
Understand limits and implement backoff strategies.
Workflows
End-to-end examples: monitors, events, and webhooks.
X Data Endpoints
User lookups, tweet search, trends, and media downloads.
X Write Actions
Post tweets, like, retweet, follow, DM, and more.
Monitors
Track X accounts and receive real-time events.