Consistency
Consistency across the X API v2 endpoints
One of the main aspects of the new v2 version of the X API is consistency across endpoints. This means that objects returned, features, and behaviors of the API are uniform across similar endpoints.
You can expect the following elements to be the same across all endpoints:
Path naming
Path naming always includes the endpoint version, followed by the resource. Beyond that, the path can contain an ID that relates to the earlier resource, a selection verb which helps to determine which data to return (e.g., search
or sample
), a delivery verb which helps to determine how the data will deliver (e.g., stream
), or other resources that have a relationship with the primary resource (e.g., /user/12/tweets
). Finally, you can append a query parameter to the end if the endpoint includes any query parameters.
Here are some examples of how these path and query items could be organized:
/version/resource/id?param1=value¶m2=value /version/resource/delivery/selection?param1=value¶m2=value
Examples of actual requests:
/2/tweets/1067094924124872705?expansions=attachments.media_keys&tweet.fields=author_id /2/users/2244994945?user.fields=created_at,description /2/tweets/search/stream /2/tweets/search/recent?query=snow
JSON Schema
Responses to requests are defined using JSON Schema. This means that requests consistently return sets of objects as arrays, with each element having an ID. Requests do not return maps with IDs as keys.
Response object and parameters
The default object returned is the same for each endpoint of that object type:
id
objects are always strings.- Parameters and response fields consistently use American-English spelling.
- Fields are empty or not returned if there is no value.
- The
entities
object only contains entities sourced from the Post text: this includesurls
,hashtags
,mentions
, andcashtags
. - All cards-related information, including the
media_keys
andpoll_ids
fields, are returned in theattachments
object.
Here is an example response object from the single Post lookup endpoint (with the tweet.fields parameter set to author_id
, entities
):
Authentication
All X API v2 endpoints require authentication. Many of them accept the OAuth 2.0 Bearer Token method, requiring a Bearer Token with the request to the endpoint to make a successful request.
For endpoints requiring authorization to create, manipulate, or retrieve data on behalf of another user, use OAuth 1.0a User Context. This means providing your developer App’s API keys and tokens as well as a set of user Access Tokens that you generate for the user on behalf of whom you’re making a request. The 3-legged OAuth flow can help you retrieve Access Tokens. Use a tool or library that automatically builds this authorization header.
More information on authentication can be found in our documentation on authentication.
Fields
The object returned on each endpoint is condensed. To allow developers more customization in the response they get back from the API, the fields
parameter is used to request the fields desired. Fields will remain consistent across endpoints. The Post object will return the same fields across all endpoints where the Post object is returned. The same set of fields can be queried across similar endpoints.
For example, the same Post fields can be queried in the Posts lookup and for the expanded pinned Post in the Users lookup.
Expansions
Where appropriate, expansions are available for all nested id fields (e.g., all fields named *_id
, such as author_id
). Expansions are also available for all fields that have an id that is not the top-level identifier of the current object. For example, in the Posts lookup, the Post is the current object with field id
as the top-level identifier. The author_id
or referenced_tweets.id
fields are available to expand into complete user or Post objects by adding these comma-separated values to the expansions
parameter.
Please report any inconsistencies that you notice, related to these fields.