Microsoft Monetize - Supported creative macros
We have creative macros that can be used for all, mobile, and video impressions. We also support privacy and function macros.
Note
Creative macros are case-sensitive and aren't available for piggyback conversion pixels.
Creative macros for all impressions
The following macros can be used for all impressions:
Macro | Description |
---|---|
${CLICK_URL} |
The click tracking URL. For example: https://xandr.com |
${CLICK_URL_ENC} |
The encoded click tracking URL (only necessary for some third-party ad servers). For example: https%3A%2F%2Fxandr.com |
The following macros can be used in creative third-party tags and landing page URLs:
Macro | Description |
---|---|
${ADV_CODE} |
The code of the advertiser to which the creative belongs. |
${ADV_FREQ} |
The total number of impressions seen by a user across all advertiser campaigns. |
${ADV_ID} |
The ID of the advertiser to which the creative belongs. |
${AGE} |
The age of the user if available. Supported values are an integer or 0. |
${APPNEXUS_AUCTION_ID} |
This macro is an alias for ${AUCTION_ID} , and behaves in the same manner. |
${AUCTION_ID} |
The 64-bit character string representing the individual auction that led to the impression. |
${BID_PRICE} |
The first price bid for this impression, as opposed to the price paid after price reduction. |
${BIDPRICE} |
This macro is an alias for ${BID_PRICE} , and behaves in the same manner. |
${CACHEBUSTER} |
A random number string used to limit caching of the URL. Note: This macro ensures that a fresh call is made to the ad server every time the tag is called to accurately count all impressions. If you don't add this macro to the tag, you may see inaccurate impression totals. |
${CP_CODE} |
The campaign code of the served impression. |
${CP_ID} |
The campaign or split ID of the served impression. |
${CPG_CODE} |
The line item code of the served impression. |
${CPG_ID} |
The line item ID of the served impression. |
${CREATIVE_CODE} |
The code of the creative served if available. |
${CREATIVE_HEIGHT} |
The height of the creative served. |
${HEIGHT} |
This is an alias for ${CREATIVE_HEIGHT} , and behaves in the same manner. |
${CREATIVE_ID} |
The creative ID that won the impression. |
${CREATIVE_SIZE} |
The width and height of the creative served. For example: 300x250. |
${CREATIVE_WIDTH} |
The width of the creative served. |
${WIDTH} |
This macro is an alias for ${CREATIVE_WIDTH} , and behaves in the same manner. |
${CUSTOM_MODEL_ID} |
The id of the custom model used in the auction. When no custom model is used, this macro will return 0 .Note: This custom macro will only work for APB Alpha Test clients. |
${CUSTOM_MODEL_LAST_MODIFIED} |
The date and time (in Unix Epoch time) since the custom model that was used in the auction was last modified. If no model was used, this macro will return 0 .Note: This custom macro will only work for APB Alpha Test clients. |
${CUSTOM_MODEL_LEAF_NAME} |
The leaf_name specified in the leaf that determined the winning bid. If no name is specified or if a model was not used, this macro will return --- . This aligns with the leaf_name field in the Standard Feed in Log Level Data. For more information, see Standard Feed.Note: This custom macro will only work for APB Alpha Test clients. |
${DATACENTER} |
The data center ID (1 = NYM, 2 = LAX, 3 = AMS, 4 = FRA, 5 = SIN). |
${DEAL_ID} |
The Microsoft Advertising Deal ID associated with the winning bid if applicable. If there is no deal, this macro will return 0 . |
${ECP} |
The publisher-side estimated clear price (ECP) for the auction. |
${EXTENDED_IDS} |
The Universal ID values passed by the seller, which the buyer has permission to view. |
${GENDER} |
The gender of the user if available. Possible values include: - f (female)- m (male)- u (unknown) |
${INV_SOURCE_ID} |
Deprecated |
${IO_CODE} |
The insertion order code of the served impression. |
${IO_ID} |
The insertion order ID of the served impression. |
${OZONE_ID} |
Deprecated |
${PMT_RULE_ID} |
The ID of the payment rule used to price the impression. |
${POSTAL_CODE} |
The postal code of the user. |
${PRICE_PAID} |
The price paid for this impression after price reduction. This is the second price. |
${SECOND_PRICE} |
The price that represent the second highest bid in auction. |
${PT1} , ${PT2} , ${PT3} , ${PT4} , ${PT5} , ${PT6} , ${PT7} , ${PT8} , ${PT9} |
These macros can be populated with arbitrary custom data that you send when using the following placement tag query string parameters: - pt1 - pt2 - pt3 - pt4 - pt5 - pt6 - pt7 - pt8 - pt9 For more information, see Create a Placement Tag Macro. |
${PUBLISHER_CODE} |
The code of the publisher selling the impression. Note: This ID is available only if the publisher uses a code and has exposed it for reporting. |
${PUBLISHER_ID} |
The ID of the publisher selling the impression. Note: This ID is available only if the publisher is exposed for reporting. |
${REFERER_URL} |
Deprecated Note: Use ${REFERER_URL_ENC} instead. |
${REFERER_URL_ENC} |
The encoded referring URL if available. For mobile app impressions, this macro returns the app store URL if available. |
${REM_USER} |
A boolean value that indicates if the user is being remarketed. |
${RESERVE_PRICE} |
The reserve price set by the publisher. When there isn't a reserve price, this macro will return 0 . |
${SCHEME} |
Populates the appropriate application protocol (HTTP or HTTPS) depending on the inventory type. |
${SEG_CODES} |
The codes for the segments that the winning buyer owns or has access to within this user's cookie (in order of last seen time). If the user is in more than 15 of your accessible segments, this macro will only return the first 15 (ordered by most recently seen segment to oldest segment). |
${SEG_IDS} |
The IDs of the segments that the winning buyer owns or has access to within this user's cookie (in order of last seen time). If the user is in more than 15 of your accessible segments, this macro will only return the first 15 (ordered by most recently seen segment to oldest segment). |
${SELLER_MEMBER_ID} |
The member ID of the member that is selling the impression. |
${SITE_ID} |
The ID of the site that the impression is being served on. |
${SSP_DATA} |
Required for server-side conversion pixels. For more information, see Server-Side Conversion Pixels. |
${TAG_CODE1} |
The integration code set on the placement. |
${TAG_CODE2} |
The additional integration code set on the placement. |
${TAG_ID} |
The Microsoft Advertising placement ID that initiated the bid request. |
${TIMESTAMP} |
The UNIX timestamp for the auction. |
${USE_COOKIES} |
This is used for third-party creatives to indicate whether cookies should be set for the user viewing the impression. Allowed values include: - 0 for no- 1 for yesFor more information about cookie-related settings, see Cookie Privacy Settings and the Publisher Service. |
${USER_AGENT} |
The user agent string from the request's HTTP header. The user agent often identifies information such as the application, operating system, and software vendor acting on behalf of the user. For example: Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10.5; en-US; rv:1.9.0.4) Gecko/2008102920 Firefox/3.0.4. |
${USER_AGENT_ENC} |
The encoded user agent string from the request's HTTP header. |
${USER_CITY} |
The character string of the user's city. |
${USER_COUNTRY} |
The character string of the user's country. |
${USER_ID} |
The Microsoft Advertising 64-bit character string representing the user for the impression. |
${USER_IP} |
The IP address of the user, which is truncated. |
${USER_LOCALE} |
The language and dialect (aa-DD) reported by the user's device. For example, en-ZA represents English (en) used in South Africa (ZA). |
${USER_STATE} |
The character string of the user's state or region. - In the USA: 2 letter abbreviation - Outside of USA: An encoded URL with the user's country followed by the user's region ID (FIPS 10-4 or Microsoft Advertising-generated). For example, the region surrounding Riva, Latvia is LV%3A25 (encoding for LV:A25). |
Content ID creative support
The content_ID creative macro enables content-level reporting for ads. This macro allows advertisers to track exactly where their ads are shown, instead of relying on bundle IDs.
When the creative includes the content_ID
macro, it triggers a third-party (3P) tag embedded in the creative. This tag calls Peer39, which processes the macro data to generate reports. Advertisers can then view detailed reports showing the specific content where their ads were displayed.
Data flow and reporting
The data flow works as follows:
- The
content_ID
macro in the creative triggers a 3P tag. - The tag communicates with Peer39, which processes the macro data for content-specific reporting.
- The macro data is used to generate content-level reports, allowing advertisers to view exactly where their ads ran. This level of reporting provides more detailed insights than traditional bundle ID tracking, helping advertisers optimize their content-level targeting and campaign performance.
Publisher and market targeting
The following publishers are targeted to send the content_ID signal for reporting:
- DirecTV
- Philo
- Xumo
GroupM Nexus ATV has tested the Peer39 pixel in the following regions:
Canada: 100% of campaigns use the Peer39 pixel for reporting. United States: Approximately 30-40% of campaigns use the Peer39 pixel for reporting.
The next phase includes continuing tests in Canada and the US, with a gradual move toward applying the Peer39 pixel to all campaigns. Mexico has also expressed interest in using the Peer39 pixel for content-level targeting and reporting.
Global expansion plans
Finecast (part of GroupM Nexus ATV) plans to assess the global need for the Peer39 pixel and standardize its usage across markets. Currently, GroupM operates in 20 markets globally, with plans to expand into 11 new markets within the next 3-6 months, including the UK.
According to internal assessments, the use of the Peer39 pixel could contribute $14 million in additional growth globally, supporting GroupM’s current growth trajectory and its programmatic buying strategy.
Usage and impact updates
GroupM Nexus ATV plans to expand the usage of the Peer39 pixel and will continue to evaluate its impact throughout 2024. Users can expect updates on global market availability and adoption as the testing progresses.
Creative macros for video impressions
The following macros can be used specifically for video impressions:
Macro | Description |
---|---|
${VIDEO_CONTEXT} |
The context of the video ad. Allowed values include: - 0 : In-stream unknown- 1 : In-stream pre-roll- 2 : In-stream mid-roll- 3 : In-stream post-roll- 4 : Out-stream |
${VIDEO_PLAYBACK_METHOD} |
Specifies how the video was played. Allowed values include: - 0 : Unknown- 1 : Auto-play, sound-on- 2 : Auto-play, sound-off- 3 : Click-to-play- 4 : Mouse-over- 5 : Auto-play, sound unknown |
${VIDEO_PLAYER_HEIGHT} |
The height of the video player, expressed in pixels. |
${VIDEO_PLAYER_WIDTH} |
The width of the video player, expressed in pixels. |
Creative macros for mobile impressions
The following macros can be used specifically for mobile impressions:
Macro | Description |
---|---|
${CARRIER_ID} |
The Microsoft Advertising integer representing the mobile carrier ID. For a complete list of carrier IDs, see the Carrier Service. |
${DEVICE_AAID} |
The Android advertising identifier when the impression is delivered from an Android device. |
${DEVICE_APPLE_IDA} |
The Apple advertising identifier when the impression is delivered from an Apple device. |
${DEVICE_IFA_TYPE} |
The type of identifier represented by the ${DEVICE_IFA} . Possible values include:- AAID (Android Advertising ID/Google) - IDFA (Identifier for Advertising/Apple) - AFAI (Amazon Fire ID) - RIDA (Roku ID) - OPENUDID - TIFA (Tizen Identifier for Advertising (Samsung Ad ID)) - VIDA (Vizio Advertising ID) - LGUDID (LG Unique Device ID) ${DEVICE_IFA_TYPE} should be used in conjunction with ${DEVICE_IFA} , and this setup is recommended over individual device macros specific to each IFA type. These macros are applicable to both mobile and CTV device types. |
${DEVICE_IFA} |
The unique identifier representing the device. |
${DEVICE_MAKE_ID} |
The Microsoft Advertising integer representing the ID of the make of the mobile device such as 26 . For a complete list of mobile device make IDs, see the Device Make Service. |
${DEVICE_MD5} |
The MD5-encrypted unique identifier representing the mobile device. |
${DEVICE_MODEL_ID} |
The Microsoft Advertising integer representing the ID of the mobile device model such as 301 . For a complete list of mobile device model IDs, see the Device Model Service. |
${DEVICE_ODIN} |
The ODIN-encrypted unique identifier representing the mobile device. For more information, see ODIN. |
${DEVICE_OPENUDID} |
The OPENUDID-encrypted unique identifier representing the mobile device. |
${DEVICE_SHA1} |
The SHA1-encrypted unique identifier representing the mobile device. |
${DEVICE_WIN_ID} |
The Windows Ad ID for the device on which this impression occurred if applicable. |
${EXT_APP_ID} |
The external identifier for the application requesting the impression. This macro is only useful for mobile app impressions. |
${GEO_LAT} |
The latitude of the user's location when GPS data is available from a mobile device, expressed using the snn.ddd,snn.ddd format such as +12.345 or -45.123 . South is represented as a negative in this example. To comply with privacy standards, the maximum is five decimal places of precision. |
${GEO_LON} |
The longitude of the user's location when GPS data is available from a mobile device. expressed using the format snn.ddd,snn.ddd . For example: +12.345 or -45.123 . West is represented as a negative in this example. To comply with privacy standards, the maximum is five decimal places of precision. |
${IS_PREVIEW} |
A flag can be passed to the third-party server so that production impressions don't get counted in the total number of impressions when previewing creatives. Possible values include: - 0 for no- 1 for yes |
${SUPPLY_TYPE} |
This macro will be populated with a numeric value that denotes the supply type of the impression. Allowed values include: - 0 : web- 1 : mobile web- 2 : mobile app- 4 : toolbar |
Privacy macros
In order for our clients to meet their transparency, notice, and choice/consent requirements under US state privacy law, the GDPR and the ePrivacy Directive, Microsoft Advertising supports the Global Privacy Platform and the IAB Europe Transparency & Consent Framework (the "Framework"). For more information, see the IAB Europe Transparency & Consent Framework. Publishers should reference Part of Privacy Regulations when using macros, such as the ones noted in the table below, to surface notice, transparency, and choice to end users located in the EEA, signal approved vendors, and pass consent to Microsoft Advertising and demand sources as well as their vendors through the Microsoft Advertising Platform. For more information, see Part of Service Policies.
Macro | Description |
---|---|
${GDPR_APPLIES} |
Designates whether GDPR regulations are applied. It specifically indicates whether the user is located in a GDPR impacted country, or if we have a GDPR-required signal passed with the request. Possible values include: - 0 for no- 1 for yesNote: 0 may be received from an EEA country. It is the publisher's choice to signal in this manner. |
${GDPR} |
This is an alias for ${GDPR_APPLIES} , and behaves in the same manner. |
${GDPR_CONSENT_STRING} |
This macro specifies the IAB GDPR consent string. If the GDPR applies, it will contain a list of user-approved vendors based on the IAB GDPR Transparency and Consent Framework. For more information, see IAB GDPR Transparency and Consent Framework. |
${GDPR_CONSENT} |
This macro is an alias for ${GDPR_CONSENT_STRING} , and behaves in the same manner. |
${GDPR_CONSENT_[0-9]+} |
For example, GDPR_CONSENT_1, GDPR_CONSENT_12345 etc. These all resolve to the same GDPR consent string as explained above in '${GDPR_CONSENT_STRING}' . |
${XANDR_DOMAIN} |
Dynamically retrieves the appropriate Microsoft Advertising domain based on the cookie consent settings included in the TCF string. If the user has cookies enabled from their browser settings but has: - not given consent for their cookies to be included in the TCF string, the adnxs-simple.com domain will be used to prevent the browser from attaching cookies to subsequent ad calls.- given consent for their cookies to be included in the TCF string, the adnxs.com domain will be used to pass cookies in the header of each ad call.Note: This macro should only be used if you plan on serving impressions in countries that require consent for cookies. |
${GPP_SID} |
Designates whether a section (i.e. regulatory framework) of the Global Privacy Platform should be applied. Specifically, it indicates whether the user is located in a country affected by legislation covered by the GPP. |
${GPP_STRING_XXXXX*} |
This is the IAB Global Privacy Platform (GPP) string. If a section of the GPP applies, then this will contain framework-dependent information reflecting the consent elections of the user. Note: * XXXXX can represent any numerical ID. |
Function macros
A function macro performs a function on another macro. Function macros can be used in combination with any other creative macro, including custom macros. If they are not recognized at render time, they will not be translated and the function will not be called.
Microsoft Advertising currently supports the {$URL_ENC}
function macro, which can be used for a variety of purposes related to encoding. A key use case is when a URL needs to be passed from ad server to ad server using a creative macro. Due to the presence of unsupported characters in standard URL formatting, the {$URL_ENC}
function macro must be encoded at various stages of the process.
This function macro takes the following form:
${URL_ENC(${MACRO_NAME},#)}
${MACRO_NAME}
is the macro to be encoded and #
is the integer representing the number of times to encode the contents. Possible values include:
1
2
3
Each encoding corresponds to a step in the redirect chain, as well as how a given third-party click tracker works with the macro. Double encoding will usually be needed for final destination URLs when a second ad server is involved, and triple encoding for a third ad server.
To determine whether you will need to use single, double, or triple encoding, you should check with your third-party click tracker and then test your URL_ENC
macro to ensure it works. If your macro is not working, one consequence of this may be link breakage, which will result in users not reaching the intended destination URL.
Encoding Example | Format |
---|---|
Encoding click URLs once | Use the following format:${URL_ENC(${CLICK_URL},1)} Note: If https://xandr.com is passed as the click URL, using ${URL_ENC(${CLICK_URL},1)} to single encode the URL would result in https%3A%2F%2Fxandr.com populating the creative. |
Encoding media URL once | Use the following format:${URL_ENC(${MEDIA_URL},1)} |
Encoding media URL twice | Use the following format:${URL_ENC(${MEDIA_URL},2)} |
Encoding a custom macro called ADFORMAT once | Use the following format:${URL_ENC(#{ADFORMAT},1)} |
Digital Services Act (DSA) macros
According to Article 26 of the DSA, online platforms, including Microsoft Advertising's publisher clients must provide clear, concise, and unambiguous information about advertisements by February 17th, 2024. These requirements include:
- Clearly identifying that the information is an advertisement.
- Disclosing the identity of an individual or legal person on whose behalf the advertisement is presented.
- Indicating the identity of an individual or legal person who made payment for the advertisement, if different from the advertiser.
- Providing information about the primary parameters used to determine the ad recipient and, where applicable, instructions on how to modify those parameters.
Macro | Description |
---|---|
${DSA_REQUIRED} |
Indicates if DSA information should be made available. Possible values include: - 0 : Not required.- 1 : Required. Bid responses with or without DSA object will be accepted.- 2 : Required. Bid responses without DSA object will not be accepted.- 3 : Required. Bid responses without DSA object will not be accepted. Here, the publisher is an Online Platform. |
${DSA_BEHALF} |
The free UNICODE text string with a name on whose behalf the ad is being displayed. This macro is populated from the DSA bid response. For example, Advertiser . |
${DSA_PAID} |
The free UNICODE text string of who paid for the ad. This macro is populated from the DSA bid response. For example, Advertiser . |
${DSA_PARAMS} |
The combination of integer values representing user parameters, separated by an underscore “_”. For example, 1_2_3 .Possible values include: - 1 : Information on your online activity indicating your similarity to groups targeted by the advertiser. For example, age group, gender, education level, or interests.- 2 : Information on the setting in which you view a specific advertisement. For example, website content, device type, IP address, location (country or city).- 3 : Information on your precise geographic location, with an accuracy of approximately 500 meters. |