Impression-level revenue data helps you better understand your users, calculate ROI precisely, and build accurate LTV models.
For supported networks, MAX gives you data about each impression: information about revenue, the demand source, and the creative.
You can process this data directly yourself.
You can also have the data analyzed by any of our supported analytics providers (a list of these providers can be found in the “MMP Integration: MAX to MMP” section of this page).
Direct Integration: MAX to You
There are three ways you can get user-level revenue data:
User Revenue API:
Use this API to retrieve user-level revenue data on a daily basis.
You can retrieve this data in two forms: aggregated for a particular user or with one row per impression.
Data is available eight hours after UTC day end.
Learn more on the User Revenue API documentation page.
Client-Side:
Since SDK version 10.3.0+, you can access impression-level user revenue data on the client side in real-time.
You can find integration instructions for Android and iOS in this documentation.
Server-to-Server:
You can also access real-time revenue data on the server side.
To do this, provide an impression postback that tracks impression-level user ad revenue data.
Contact your account team or the support team to enable this feature.
This feature, and the macros that the impression postback supports, are described in the “Server-to-Server Impression Revenue API” section of this page.
MMP Integration: MAX to MMP
MAX has a variety of analytics partners who can help you easily access your data in a single dashboard.
You can work with any of our supported partners to access impression-level ad revenue or aggregated ad revenue data.
These supported partners include Adjust, GameAnalytics, AppsFlyer, and Singular.
Refer to the documentation pages maintained by those partners for more information about their capabilities.
Server-to-Server Impression Revenue API
Contact your account team or the support team to enable this feature.
AppLovin’s servers can send postbacks to an external endpoint whenever a MAX impression is recorded.
You define which endpoint receives these requests.
The postbacks are in the form of HTTP or HTTPS GET requests.
AppLovin makes these postbacks soon after the impression, but they may be delayed by up to a few minutes.
You can use an impression timestamp macro to reconcile any delay between the impression and the postback times.
The postback request times-out if five seconds pass without a response from your endpoint.
There are no retries for postback requests.
Example
Available Macros
You can incorporate any of the macros in the following table into your postback URL.
The example URL above incorporates the {IDFA}, {USER_ID}, {EVENT_ID}, and {EVENT_TOKEN} macros.
AppLovin’s servers replace these macro names with accurate values when the servers make the request to your endpoint.
Name
Description
{AD_UNIT_ID}
MAX ad unit ID (16 hex characters)
Example:9ad0816ac071552a
{AD_UNIT_NAME}
Ad unit name (URL-encoded)
Example:My%20App%20Banners
{AD_UNIT_TEST_NAME}
Name of the ad unit test, URL-encoded
Example:Control
{ALL_REVENUE}
Estimated revenue, including FB Bidding estimates
Examples:0.0121, 5.74466e-05
{CC}
Two-letter country code of the user
Example:gb
{CUSTOM_DATA}
Custom data passed in from the integration (URL-encoded). AppLovin recommends that you keep the size of the string under 8192 characters. You must not include ampersand (&) characters in the custom data if you include this macro.
Example:my%20custom%20data
{DEVICE_TYPE}
User’s device type.
Example:Tablet
{EVENT_ID}
Unique event ID, 40 hex characters
Example:8dc948013d71f04264b8e5c1c61933154b226e08
{EVENT_TOKEN}
sha1( «event-ID» + «your-event-key» )
Example:e000949f6d851c1f34adae08e6ef1076ba43cf31
{EVENT_TOKEN_ALL}
sha256( «All macros alphabetically, URL-decoded» + «your-event-key» )Note: If EVENT_TOKEN is one of your macros, it is omitted from the “All macros alphabetically” string.
Name of the ad network that served the impression. Names should match the names used in the Management API.
Example:APPLOVIN_NETWORK
{NETWORK_PLACEMENT}
Placement name of the external ad network
Example:ca-app-pub-12345678%2F0987654321
{PACKAGE_NAME}
App Package Name (Android) or Bundle ID (iOS). URL-encoded.
{PLACEMENT}
Publisher-defined MAX ad placement name (URL-encoded)
Example:Launch%20Screen
{PLATFORM}
Platform
Examples:android, ios
{PRECISION}
Information on how precise the revenue value is. Options are:
publisher_defined
if revenue is the price assigned to the line item by the publisher
exact
if revenue is the resulting price of a real-time auction
estimated
if the revenue amount is based on Auto-CPM or FB Bidding estimates
undefined
if no line item amount is defined and there is not enough data to estimate
Example:exact
{REVENUE}
Estimated revenue. Set to 0 when FB Bidding.
Examples:0.0121, 5.74466e-05
{TS}
Timestamp of impression (integer, seconds since epoch)
Example:1546300800
{USER_ID}
Publisher-defined, URL-encoded, user ID; maximum length is 8192 characters
Example:7634657898
{WATERFALL_NAME}
The name of the Ad Unit waterfall
Example:LAT
Setting an Ad Placement Name
The following code snippets show you how you can add a placement name to an ad unit.
The value of the placement name replaces the {PLACEMENT} macro in postback requests:
The following code snippets show you how to add custom String data to postbacks.
This String data replaces the {CUSTOM_DATA} macro in these postbacks.
AppLovin recommends that your string contain fewer than 8192 characters.