Accessing Ads accounts
User accounts vs Ad accounts
There are two different types of accounts involved in using the Ads API: advertising accounts and X user accounts. Throughout Ads API documentation, the term “account” usually refers to the advertising account.
- Advertising accounts are registered on business.x.com and identified in the API by account_id. Advertising accounts link directly to funding sources and leverage content from one or more X user accounts as ‘promotable users’. Each advertising account can grant permission to one or more X user accounts. The advertising account, or “current account,” is represented in nearly every URL executed as an in-line :account_id parameter.
- X user accounts (such as @AdsAPI) are identified by user_id in the Ads API. One or more of these accounts can be associated with an advertising account. The authenticated X user account making requests on the API is referred to as the ‘current user.’ A listing of advertising accounts that the current user has access to can be found with GET accounts. ‘Promotable users’ are X handles that can be promoted by a specific advertising account. For more details about this, see Obtaining Ads Account Access.
Methods for Ad account access
There are two methods you can use to make Ads API requests for an advertiser’s account:
- Making requests on behalf of an Advertiser (recommended)
- Making requests using your account that has been granted access to an Advertiser’s account, e.g. an Agency supporting multiple accounts.
This document is a brief overview of the differences between these options and should be used in conjunction with our other resources, such as the multi-user login FAQ.
As described in Authorizing a request, all requests to the Ads API require Authorization headers using OAuth 1.0a with an access token obtained via 3-leggedOAuth flow. Your application will need to implement a web-based OAuth flow to obtain access tokens. Ads API developers should never request that our X advertisers share their login credentials.
By default, each X developer application contains a static access token that can be used to make Ads API requests for the account that owns the application. These credentials are ideal for single-account use cases without requiring a 3-legged or PIN-based OAuth flow. If you aren’t accessing another X Ads Account, use these single-user credentials instead of the following steps.
Levels of access
App-level permissions
Each user will have a level of access as requested upon application to the Ads API:
- Conversion Only: User has access to Mobile and Web Conversion endpoints with read & write access.
- Standard Access: User has access to Analytics, Campaign Management, Creatives, Custom Audiences, and Conversion endpoints with read & write access.
Note: Ads API developers who requested access prior to July 2023 may have different levels of access and permissions, and may be limited to five OAuth tokens. See our guide on increasing access to access to additional endpoints or lift token limits for existing applications.
Ad Account-level permissions
Each user that has access to an Ads Account will have a specific account-level permission: Account administrator, Ad manager, Campaign analyst, Organic analyst, and Creative Manager; see business.x.com for the latest documentation for account-level permissions. Applications should retrieve the permissions for the currently authenticated user via the Authenticated User Access API endpoint to determine which API endpoints and Ads features they can access.
Note: Any user tokens used with the Conversion API must be for users with Account administrator or Ad manager account-level permissions.
Methods of obtaining access tokens
1. Obtain an advertiser’s (User) access token
There are two methods of obtaining an advertiser’s access token. The most common method is via a 3-legged OAuth flow directly from within your web UI. Applications that do not have a publicly accessible UI exposed to advertisers can implement an PIN-based Oauth process. After the user completes the 3-legged flow, your application will have credentials to make request for their Ads account via the API.
Obtaining user credentials via OAuth flow is the method we highly recommend for the majority of Ads API developers to gain access to an advertiser account. It allows you to call the API on behalf of a user and take actions as that user. These tokens do not expire but can be revoked by the user at any time.
2. Obtain your (Developer) access token
This option requires the advertiser to grant your @username (or @usernames) access to their X Ads account via the X UI at business.x.com. Access tokens obtained through the 3-legged OAuth flow for your account will be able to access the advertiser’s X Ads account.
This allows you to call the API using the OAuth tokens of your own @username rather than the advertiser’s OAuth tokens. The key distinction on this option is that you may only create Promoted-Only Posts if the Post delegation/composer permission has been granted to your @username.
To gain access to create Promoted-Only Posts on behalf of the FULL
promotable user on the account, you must also be granted access to create Posts in this flow. That will enable access via the TWEET_COMPOSER
permission on the GET accounts/:account_id/authenticated_user_access endpoint.
Differences between these methods
Advertiser (User) OAuth Token | (Developer) OAuth Token (@username added to separate account) | |
Access Ads Account | ✔ | ✔ |
Create Posts on Behalf of User | ✔ | ✔* |
Manage Campaigns | ✔ | ✔ |
Access Analytics | ✔ | ✔ |
Create Cards on Behalf of User | ✔ | ✔ |
Developer ability to Access via X Ads UI | ✔ | |
Rate Limits | Distinct per Advertiser | Distinct per Advertiser Account |
Note: See Obtain your (Developer) access token section above for details.
Sample Use-Case
Advertiser’s access token via OAuth 3-legged web flow
The standard flow is web-based and uses the 3-legged authorization OAuth flow. The screen shots outlined here are part of a sample that you can view the source of at https://github.com/xdevplatform/twauth-web.
At some point in your application, you will want to redirect to X in order to authorize your application
When you redirect to X with the request token, the user will be prompted to authorize your application
Upon authorizing your application, the user will be redirected to the callback URL provided when you generated the request token. You will use this to obtain the permanent access token for this user and store it locally!