Overview
Benefits of Custom Exports API
Use the Branch Custom Exports API to find and queue log records that match your search criteria for export. You can do so either via the Custom Exports section in your Branch Dashboard or via the API (this page).
API Limitations
| Limitation | Details | 
|---|---|
| Data Availability | The data will typically be available within 2-4 hours. However, under certain conditions, it may take as long as 6 hours. | 
| Max number of records returned by API | If you want to limit the number of records returned to 15 million or less, do so using the  | 
| Max number of days that can be queried at a time | The maximum number of days that be queried at once is 60. | 
| Rate Limit for creating exports* | 
 | 
| Rate Limit for checking the status of a report* | 
 | 
| Exporting from test environments | At this moment, it is not possible to export data out of a Branch Test environment | 
| Repeated requests within 60 minutes will be cached | If you make identical requests within 60 minutes of each other, you will not see multiple export jobs running. Instead, the same export job will be used. If you are using the API, the same job_id will be returned. This is to avoid the case of hundreds or thousands of requests being made for the exact same data set, within seconds or minutes of each other.After 60 minutes, your request will kick off a new job to retrieve data. | 
You will get the following response once you've hit the rate limit:
{
    "errors": [
        {
            "message": "Limit is exceeded for org-525983469347282987, retry after 3418 seconds",
            "error_code": 7
        }
    ]
}Prerequisites & API Access
In order to use the Custom Exports API, you need to have completed the following:
- Created a Branch Dashboard 
- Implemented the Branch SDK into your mobile app (iOS | Android) 
- Opt into sharing device data through Apple's AppTrackingTransparency framework. When an install is attributed to paid ads, a 2nd install event will fire post user opt-in. - Data Changes Post iOS - Opt-ins will affect your final install count. We recommend using a different identifier (ex. IDFV) to de-dupe install events on your internal systems. - For additional information on changes post iOS 14.5, visit our FAQ Pages 
- Logged into the Branch Dashboard with the Sensitive Data and Export Access Permission enabled. 
Providing Agencies API Access
Any user with access to an account’s API keys will be able to access Branch’s Custom Export API (and thus unfiltered, log-level data). As a result, we would recommend against providing third parties with the permissions required to view API keys during the invitation process.
Data Purge
Branch will purge last-attributed data after 60 days.
If you work with an agency that runs your advertising campaigns and want to give them access to export the subsequent data, you can provide them with access to the Custom Export API.
To provide an agency team member with access to the Custom Export API:
- In the left-hand navigation, under Configure, click on Account Settings. 
- On the Account Settings page, click on the Agencies tab. 
- Expand the agency in question, find the agency team member you want to give access to, hover on the button in the Actions column and click Edit. 
- In the Edit Agency Team Member modal: - Under Access Level, check the Export box. 
- Under Permissions, check the Sensitive Data box. 
 
- Optional: add data filters - Under Data Filters, toggle any necessary data filters on/blue. Exported data will be filtered accordingly. 
 
- Click Save. 

Agency-Tagged Data
If you do not enable the Only Show Agency-Tagged Data data filter, the Agency Team Member will be able to export sensitive data associated with all of your campaigns, regardless if they are associated with them or not.
Authentication
Calls to the Custom Export API require an access token parameter to be passed with each request. Access tokens are generated on a per-user basis and are permanent.
Learn how to retrieve your Access Token (a.k.a. an API Key).
API Usage
Create Export Request
POST /v2/logs?organization_id=ORG_ID
POST /v2/logs?app_id=APP_ID
Headers:
Access-Token: API_KEY
Content-Type: application/json
Body: JSON parameters
Host: api2.branch.ioRequest Headers
| Header | Description | Required | 
|---|---|---|
| Access-Token | Key that encapsulates the user's permission w.r.t an org. Obtained from the Branch Dashboard needed for authentication. | Yes | 
| Content-Type | application/json | Yes | 
Request Body Parameters
| Parameter | Type | Description | Required | 
|---|---|---|---|
| start_date | Date | The beginning datetime for the requested results, provided in ISO-8601 format including Hours, Minutes, Seconds and Milliseconds.Dates without offsets (i.e. a timezone) default to the value provided for the timezone parameter. If the timezone parameter is not specified, the dates timezone defaults to UTC. Date must be within the last 120 days. Example: 2016-01-01T00:00:00Z | Yes | 
| end_date | Date | The end datetime for the requested results, provided in ISO-8601 format including Hours, Minutes, Seconds and Milliseconds.Dates without offsets (i.e. a timezone) default to the value provided for the timezone parameter. If the timezone parameter is not specified, the dates timezone defaults to UTC. Example: 2016-01-01T23:59:59:999Z | Yes | 
| report_type | String | The Branch EO topic to be exported. | Yes | 
| fields | Comma Separated List | List of comma-separated fields desired in results. | Yes | 
| limit | Integer | If you want to limit the number of records returned to 15 million or less, do so using the  | Yes | 
| timezone | String | Timezone for results. Accepts tz database strings like ‘America/Los_Angeles’.Optional parameter; results are returned in the dashboard timezone if not provided. Will default to UTC only if dashboard timezone is not set. | No | 
| filter | Comma Separated List | Filter by fields and boolean operators against fields of the LogInstalls model; must be URI encoded and JSON parsed. Example: ["gt","last_attributed_touch_timestamp", 1604015756] | No | 
| response_format | String | Format of the response; can be either "json" or "csv". If not selected, defaults to CSV. Branch uses UTF-8 encoding for CSV files. | No | 
| allow_multiple_files | Boolean | Set this parameter to  | No | 
| response_format_compression | String | The file compression method to use for the data. | Yes if you set  | 
Response Body Parameters
| Parameter | Description | 
|---|---|
| handle | Unique request handle generated against the endpoint call. | 
| export_job_status_url | The URL of the export request. | 
Example Request/Response
curl -X POST 'https://api2.branch.io/v2/logs?app_id=123456700098765432'
	-H "Content-Type: application/json"
	-H "Access-Token: YOUR_ACCESS_TOKEN_HERE"
	-d '{"report_type": "eo_open",
			"limit": 100,
			"fields": ["timestamp","name"],
			"start_date": "2019-12-09T00:00:00Z",
			"end_date": "2019-12-09T01:59:59Z",
			"filter": ["gt","last_attributed_touch_timestamp", 1604015756]
			}'{"handle":"1612dbb3-85ef-49f8-b1c5-5818c163600c","export_job_status_url":"https://api2.branch.io/v2/logs/1612dbb3-85ef-49f8-b1c5-5818c163600c?app_id=123456700098765432"}Response Codes
| Response Code | Description | 
|---|---|
| 200 | Status of aggregate export. | 
| 400 | Authentication Failed. | 
Get Export Request
GET /v2/logs/JOB_ID
Headers:
Access-Token: API_KEY
Host: api2.branch.ioRequest Headers
| Header | Description | Required | 
|---|---|---|
| Access-Token | Key that encapsulates the user's permission w.r.t an org. Obtained from the Branch Dashboard needed for authentication. | Yes | 
| Content-Type | application/json | Yes | 
Response Path Parameters
| Parameter | Type | Description | Required | 
|---|---|---|---|
| request_handle | String | The ID returned by the log export queue. | Yes | 
Request Query Parameters
| Parameter | Type | Description | Required | 
|---|---|---|---|
| limit | Integer | The maximum number of results to return. | No | 
| format | String | Format of returned data. json or csv | No | 
Response Body Parameters
| Parameter | Type | Description | 
|---|---|---|
| code | Integer | The response code. | 
| lines_exported | Integer | Number of lines exported against the originated request. | 
| status | String | Request status over the current execution time. | 
| status_url | String | The URL of the export request. | 
Example Request/Response
curl -X GET https://api2.branch.io/v2/logs/<YOUR_HANDLE>\?app_id\=<YOUR_BRANCH_APP_ID>
  -H "Content-Type: application/json" 
  -H "Access-Token:<YOUR_ACCESS_TOKEN>"{"code":200,"lines_exported":2000000,"status":"complete","response_url":"https://branch-exports-web.s3.amazonaws.com/732662944269095814-eo_open-2019-12-10-2019-12-10-1612dbb3-85ef-49f8-b1c5-5818c163600c-bUlN2lwyTE10qIVH.csv?Signature=YOUR_ACCESS_TOKEN_HERE&AWSAccessKeyId=YOUR_ACCESS_TOKEN_HERE&Expires=1577305615"}Response Codes
| Response Code | Description | 
|---|---|
| 200 | Status of aggregate export | 
| 400 | Authentication Failed | 
| 404 | Job ID Not Found | 
Status Values
| Status | Description | 
|---|---|
| 
 | Request is pending. | 
| 
 | Request is still running. | 
| 
 | Request is complete. | 
| 
 | Request failed. | 
Check Data Readiness
POST /v2/data/ready
Headers:
Access-Token: YOUR_API_KEY_HERE
Content-Type: application/json
Body: JSON parameters
Host: api2.branch.ioRequest Headers
| Header | Description | Required | 
|---|---|---|
| Access-Token | Key that encapsulates the user's permissions with regard to an org. Obtained from the Branch Dashboard and needed for authentication. | Yes | 
| Content-Type | application/json | Yes | 
Request Body Parameters
| Parameter | Type | Description | Required | 
|---|---|---|---|
| date | String | The start of the interval time range, in the format  | Yes | 
| warehouse_meta_type | String | The type of data to check for. Can be either  | Yes | 
| topic | String | The Branch EO topic to be exported. | Yes | 
| app_id | Integer | Your Branch App ID, found under Account Settings in your Branch Dashboard. | Yes | 
Response Body Parameters
| Parameter | Description | 
|---|---|
| data_ready | Whether or not the requested data is ready; can be  | 
| date | The date and time associated with the requested data, in the format  | 
Examples
Successful Request/Response:
curl -X POST 'http://api2.branch.io/v2/data/ready'
	-H 'Content-Type: application/json' 
	-H 'Accept: application/json'
	-H 'Access-Token: <YOUR_API_KEY_HERE>'
	-d '{"date":"2024-01-05 17:00:00",
		"warehouse_meta_type":"EVENT",
		"topic":"eo_click",
		"app_id":"<YOUR_APP_ID_HERE>"}'{ "data_ready": true, "date": "2024-01-05 17:00:00" }Invalid Request/Response:
curl -X POST 'http://api2.branch.io/v2/data/ready'
	-H 'Content-Type: application/json' 
	-H 'Accept: application/json'
	-H 'Access-Token: <YOUR_API_KEY_HERE>'
	-d '{"date":"2024-01-06 17:00:00",
		"warehouse_meta_type":"EVENT",
		"topic":"eo",
		"app_id":"<YOUR_APP_ID_HERE>"}'{"errors":[{"message":"Report type eo is invalid. It has to be one of: [eo_branch_cta_view, eo_click, eo_commerce_event, eo_content_event, eo_custom_event, eo_impression, eo_install, eo_open, eo_pageview, eo_reinstall, eo_user_lifecycle_event, eo_web_session_start, eo_web_to_app_auto_redirect, eo_dismissal, eo_san_touch, webhook2, skadnetwork_invalid_messages, skadnetwork_valid_messages, eo_branch_cta_view_blocked, eo_click_blocked, eo_commerce_event_blocked, eo_content_event_blocked, eo_custom_event_blocked, eo_impression_blocked, eo_install_blocked, eo_open_blocked, eo_pageview_blocked, eo_reinstall_blocked, eo_user_lifecycle_event_blocked, eo_web_session_start_blocked]","error_code":7}]}Response Codes
| Response Code | Description | 
|---|---|
| 200 | Status of data successfully retrieved. | 
| 400 | Topic is invalid or data retention for requested data has expired. | 
| 500 | Internal server error (Branch failure). | 
Appendix
Available EO Fields
| Fields | Type | Description | 
|---|---|---|
| 
 | Long | App ID (capitalize ID in Liveview) | 
| 
 | String | App Name | 
| 
 | Boolean | Attributed | 
| 
 | ArrayStruct | Content Items | 
| 
 | MapStringString | Custom Data | 
| 
 | String | Customer Event Alias | 
| 
 | Integer | Days From Last Attributed Touch To Event | 
| 
 | Boolean | Deep Linked | 
| 
 | Long | DI Match Click Token | 
| 
 | enum { BANNER, INTERSTITIAL, REWARDED_VIDEO, NATIVE } | Ad Type | 
| 
 | String | Affiliation | 
| 
 | String | Coupon | 
| 
 | String | Currency | 
| 
 | String | Event Description | 
| 
 | Double | Exchange Rate | 
| 
 | Double | Revenue | 
| 
 | Double | Revenue In USD | 
| 
 | String | Search Query | 
| 
 | Double | Shipping | 
| 
 | Double | Tax | 
| 
 | String | Transaction ID | 
| 
 | String | Local Currency | 
| 
 | String | Local Currency Exchange Rate | 
| 
 | String | Revenue in Local Currency | 
| 
 | String | Custom parameter for event | 
| 
 | String | Custom parameter for event | 
| 
 | String | Custom parameter for event | 
| 
 | Long | Event Timestamp | 
| 
 | Boolean | Existing User | 
| 
 | String | External Intent URI | 
| 
 | Boolean | First Event For User | 
| 
 | String | Hash Version | 
| 
 | Integer | House From Last Attributed Touch To Event | 
| 
 | String | ID | 
| 
 | Boolean | Install Attributed | 
| 
 | Boolean | Install Has Clicked Ad | 
| 
 | Boolean | Install Has Clicked Email | 
| 
 | Long | Install Timestamp | 
| 
 | String | Install Ad ID | 
| 
 | String | Install Ad Set ID | 
| 
 | String | Install Campaign ID | 
| 
 | String | Install Creative ID | 
| 
 | String | Install Partner 3p Value | 
| 
 | Boolean | Whether Meta's mobile data terms have been signed for the Install Touch. When true, Meta does not require Branch to scrub Meta-related data from this record. | 
| 
 | ArrayString | Install Features | 
| 
 | String | Install Web Format | 
| 
 | String | Install Ad Name | 
| 
 | String | Install Ad Set Name | 
| 
 | String | Install Ad Partner ID | 
| 
 | String | Install Ad Partner | 
| 
 | String | Install Agency | 
| 
 | Long | Install Agency ID | 
| 
 | String | Install Campaign | 
| 
 | String | Install Channel | 
| 
 | String | Install Creative Name | 
| 
 | String | Install Customer Ad Name | 
| 
 | String | Install Customer Ad Set Name | 
| 
 | String | Install Customer Campaign | 
| 
 | String | Install Customer Keyword | 
| 
 | String | Install Customer Placement | 
| 
 | String | Install Customer Secondary Publisher | 
| 
 | String | Install Customer Sub Site Name | 
| 
 | String | Install Feature | 
| 
 | String | Install Journey Name | 
| 
 | String | Install Keyword | 
| 
 | String | Install Placement | 
| 
 | String | Install Secondary Publisher | 
| 
 | String | Install Stage | 
| 
 | ArrayString | Install Tags | 
| 
 | String | Install View Name` | 
| 
 | String | Install Touch Type | 
| 
 | String | Last Attributed Touch Custom Fields | 
| 
 | String | Ad Partner (3p) | 
| 
 | Boolean | Whether Meta's mobile data terms have been signed for the Last Attributed Touch. When true, Meta does not require Branch to scrub Meta-related data from this attribution record. | 
| 
 | String | Marketing Title | 
| 
 | String | Current Feature | 
| 
 | Long | Last Attributed Touch ID | 
| 
 | String | Last Attributed Touch Touch ID | 
| 
 | String | URL | 
| 
 | String | Last CTA View Touch ID | 
| 
 | ArrayString | Via Features | 
| 
 | String | Web Format | 
| 
 | String | Ad ID | 
| 
 | String | Ad Name | 
| 
 | String | Ad Set ID | 
| 
 | String | Ad Set Name | 
| 
 | String | Advertising Account Name | 
| 
 | String | Advertising Account ID | 
| 
 | String | Ad Partner ID | 
| 
 | String | Ad Partner | 
| 
 | String | Agency | 
| 
 | String | Agency ID | 
| 
 | String | Banner Dimensions | 
| 
 | String | Branch Ad Format | 
| 
 | String | Campaign | 
| 
 | String | Campaign ID | 
| 
 | String | Campaign Type | 
| 
 | String | Channel | 
| 
 | String | Creative Name | 
| 
 | String | Creative ID | 
| 
 | String | Customer Ad Name | 
| 
 | String | Customer Ad Set Name | 
| 
 | String | Customer Campaign | 
| 
 | String | Customer Keyword | 
| 
 | String | Customer Placement | 
| 
 | String | Customer Secondary Publisher | 
| 
 | String | Customer Sub Site Name | 
| 
 | String | External Touch ID | 
| 
 | String | Feature | 
| 
 | String | Journey ID | 
| 
 | String | Journey Name | 
| 
 | String | Keyword | 
| 
 | String | Keyword ID | 
| 
 | String | Optimization Model | 
| 
 | String | Placement | 
| 
 | String | Placement ID | 
| 
 | String | Secondary Ad Format | 
| 
 | String | Secondary Publisher | 
| 
 | String | Secondary Publisher ID | 
| 
 | String | Stage | 
| 
 | String | Sub Site Name | 
| 
 | ArrayString | Tags | 
| 
 | String | Technology Partner | 
| 
 | String | Google Video Ads "Engaged View" | 
| 
 | String | View ID | 
| 
 | String | View Name | 
| 
 | Long | Last Attributed Touch Timestamp | 
| 
 | String | Last Attributed Touch Timestamp (ISO) | 
| 
 | String | Last Attributed Touch Type | 
| 
 | String | Last CTA View Custom Fields | 
| 
 | String | Last CTA View Ad Partner (3p) | 
| 
 | Boolean | Whether Meta's mobile data terms have been signed for the Last CTA View Touch. When true, Meta does not require Branch to scrub Meta-related data from this CTA view record. | 
| 
 | String | Referring Domain | 
| 
 | ArrayString | Last CTA View Via Features | 
| 
 | String | Last CTA View Web Format | 
| 
 | String | Last CTA View Ad ID | 
| 
 | String | Last CTA View Ad Name | 
| 
 | String | Last CTA View Ad Set ID | 
| 
 | String | Last CTA View Ad Set Name | 
| 
 | String | Last CTA View Ad Partner | 
| 
 | String | Last CTA View Agency | 
| 
 | String | Last CTA View Banner Dimensions | 
| 
 | String | Last CTA View Branch Ad Format | 
| 
 | String | Last CTA View Campaign | 
| 
 | String | Last CTA View Campaign ID | 
| 
 | String | Last CTA View Campaign Type | 
| 
 | String | Last CTA View Channel | 
| 
 | String | Last CTA View Creative ID | 
| 
 | String | Last CTA View Creative Name | 
| 
 | Long | Last CTA View External Touch ID | 
| 
 | String | Last CTA View Feature | 
| 
 | Long | Last CTA View ID | 
| 
 | String | Last CTA View Keyword ID | 
| 
 | String | Last CTA View Optimization Model | 
| 
 | String | Last CTA View Placement | 
| 
 | String | Last CTA View Secondary Ad Format | 
| 
 | String | Last CTA View Secondary Publisher< | 
| 
 | String | Last CTA View Stage | 
| 
 | ArrayString | Last CTA View Tags | 
| 
 | String | Last CTA View Technology Partner | 
| 
 | Long | Last CTA View Timestamp | 
| 
 | String | Last CTA View Timestamp (ISO) | 
| 
 | boolean | Flag that determines if the app session was made with 100% accuracy. Only available in Custom Exports API | 
| 
 | Integer | Minutes From Last Attributed Touch To Event | 
| 
 | String | Name of event based on selected topic | 
| 
 | Long | Organization ID | 
| 
 | String | Organization Name | 
| 
 | String | Origin | 
| 
 | Boolean | Reengagement Activity Attribute | 
| 
 | Boolean | Reengagement Has Clicked Ad | 
| 
 | Boolean | Reengagement Has Clicked Email | 
| 
 | Long | Reengagement Timestamp | 
| 
 | String | Reengagement Ad ID | 
| 
 | String | Reengagement Ad Set ID | 
| 
 | String | Reengagement Campaign ID | 
| 
 | String | Reengagement Creative ID | 
| 
 | String | Reengagement Partner 3p Value | 
| 
 | Boolean | Whether Meta's mobile data terms have been signed for the Reengagement Touch. When true, Meta does not require Branch to scrub Meta-related data from this reengagement record. | 
| 
 | ArrayString | Reengagement Features | 
| 
 | String | Reengagement Web Format | 
| 
 | String | Reengagement Ad Name | 
| 
 | String | Reengagement Ad Set Name | 
| 
 | String | Reengagement Advertising Partner ID | 
| 
 | String | Reengagement Advertising Partner Name | 
| 
 | String | Reengagement Agency | 
| 
 | Long | Reengagement Agency ID | 
| 
 | String | Reengagement Campaign | 
| 
 | String | Reengagement Channel | 
| 
 | String | Reengagement Creative Name | 
| 
 | String | Reengagement Customer Ad Name | 
| 
 | String | Reengagement Customer Ad Set Name | 
| 
 | String | Reengagement Customer Campaign | 
| 
 | String | Reengagement Customer Keyword | 
| 
 | String | Reengagement Customer Placement | 
| 
 | String | Reengagement Customer Secondary Publisher | 
| 
 | String | Reengagement Customer Sub Site | 
| 
 | String | Reengagement Feature | 
| 
 | String | Reengagement Journey Name | 
| 
 | String | Reengagement Keyword | 
| 
 | String | Reengagement Placement | 
| 
 | String | Reengagement Secondary Publisher | 
| 
 | String | Reengagement Stage | 
| 
 | ArrayString | Reengagement Tags | 
| 
 | String | Reengagement View Name | 
| 
 | String | Reengagement Touch Type | 
| 
 | Long | Referrer Click Timestamp | 
| 
 | Integer | Seconds From Install To Event | 
| 
 | Integer | Seconds From Last Attributed Touch To Event | 
| 
 | Integer | Seconds From Touch To Store Install Begin | 
| 
 | Integer | Content Items Count | 
| 
 | Long | Store Install Begin Timestamp | 
| 
 | Long | Timestamp | 
| 
 | String | Timestamp (ISO) | 
| 
 | String | AAID | 
| 
 | String | Android ID | 
| 
 | String | App Version | 
| 
 | String | Brand | 
| 
 | String | Browser | 
| 
 | String | Build | 
| 
 | String | The Consumer Protection Preference level | 
| 
 | String | CPU Type | 
| 
 | String | Cross Platform ID | 
| 
 | String | Developer Identity | 
| 
 | String | Device Type | 
| 
 | String | Environment | 
| 
 | Integer | City Code | 
| 
 | String | City | 
| 
 | String | Country Code | 
| 
 | String | Country | 
| 
 | Integer | DMA Code | 
| 
 | Float | Latitude | 
| 
 | Float | Longitude | 
| 
 | String | Postal Code | 
| 
 | String | Region | 
| 
 | String | Region Code | 
| 
 | String | HTTP Referrer | 
| 
 | String | IDFA | 
| 
 | String | IDFV | 
| 
 | String | Internet Connection Type | 
| 
 | String | IP Address | 
| 
 | Boolean | IIs Jailbroken | 
| 
 | String | Kindle ID | 
| 
 | String | Language | 
| 
 | Boolean | Limit Ad Tracking | 
| 
 | String | Model | 
| 
 | String | Huawei OAID | 
| 
 | String | OS | 
| 
 | String | OS Version | 
| 
 | String | OS Version (Android) | 
| 
 | ArrayString | Past Cross Platforms IDs | 
| 
 | ArrayString | Platform | 
| 
 | ArrayStruct | Probabilistic Cross Platform IDs | 
| 
 | String | Roku Device ID | 
| 
 | Integer | Screen Height | 
| 
 | Integer | Screen Width | 
| 
 | String | SDK Version | 
| 
 | String | User Agent | 
| 
 | String | Windows AID | 
| 
 | String | Device Locale | 
| 
 | String | Carrier Name | 
| 
 | String | Whether user opted in to ATT or not | 
| 
 | String | The app store the user downloaded from | 
Available SKAdNetwork (SKAN) Message Fields
| Field | Type | Description | 
|---|---|---|
| 
 | varchar | SKAN Message ID | 
| 
 | varchar | SKAN Transaction ID | 
| 
 | varchar | SKAN Version | 
| 
 | varchar | SKAN Ad Network ID | 
| 
 | integer | SKAN Campaign ID | 
| 
 | bigint | SKAN App ID (App Store ID) | 
| 
 | varchar | Body Attribution Signature | 
| 
 | boolean | SKAN Redownload | 
| 
 | bigint | SKAN Source App ID | 
| 
 | integer | Body Conversion Value | 
| 
 | integer | Body Fidelity Type | 
| 
 | boolean | Body Did Win | 
| 
 | varchar | Coarse Conversion Value (SKAN 4 and above) | 
| 
 | varchar | Source Domain | 
| 
 | integer | Apple Source Identifier (SKAN 4 and above) | 
| 
 | integer | Postback Window (SKAN 4 and above) | 
| 
 | boolean | Whether the SKAN postback is a test record. When true, the record should be filtered out as it represents test data rather than production attribution. | 
| 
 | varchar | Ad Partner Creative Id | 
| 
 | varchar | Ad Partner Creative Name | 
| 
 | varchar | Ad Partner Ad Name | 
| 
 | varchar | Ad Partner Ad Id | 
| 
 | varchar | Ad Partner Ad Set Name | 
| 
 | varchar | Ad Partner Ad Set ID | 
| 
 | varchar | Ad Partner Campaign ID | 
| 
 | varchar | Ad Partner Campaign Name | 
| 
 | varchar | Invalid Reason | 
| 
 | bigint | Timestamp (when Branch received data) | 
| 
 | bigint | Timestamp (provided by Partner) | 
| 
 | varchar | Annotation Dollar 3P | 
| 
 | varchar | Annotation Conversion Vale Mapped Value | 
| 
 | varchar | Annotation Customer Event Alias | 
| 
 | varchar | Annotation Revenue Lower Bound | 
| 
 | varchar | Annotation Revenue Upper Bound | 
| 
 | bigint | Branch App ID | 
| 
 | bigint | Branch Organization ID | 
| 
 | boolean | Advertiser Copy for iOS 15+ devices | 
IP Discrepancies
Geographic data, such as country and city, may not be available for a very small percentage of events where the IP cannot be resolved to a location.
Available Topics
| Topicz | Human Readable Name | 
|---|---|
| 
 | Blocked Clicks | 
| 
 | Blocked Commerce Events | 
| 
 | Blocked Content Events | 
| 
 | Blocked CTA Views | 
| 
 | Blocked Custom Events | 
| 
 | Blocked Impressions | 
| 
 | Blocked Installs | 
| 
 | Blocked Opens | 
| 
 | Blocked Pageviews | 
| 
 | Blocked Reinstalls | 
| 
 | Blocked SMS Sent | 
| 
 | Blocked User Lifecycle Events | 
| 
 | Blocked Web Session Starts | 
| 
 | Clicks | 
| 
 | Commerce Events | 
| 
 | Content Events | 
| 
 | CTA Views | 
| 
 | Custom Events | 
| 
 | Impressions | 
| 
 | Installs | 
| 
 | Opens | 
| 
 | Pageviews | 
| 
 | Postback Records | 
| 
 | Reinstalls | 
| 
 | SKAdNetwork Invalid Messages | 
| 
 | SKAdNetwork Valid Messages | 
| 
 | SMS Sent | 
| 
 | User Lifecycle Events | 
| 
 | Web Session Starts | 
| 
 | Self-Attributing Network Touch | 
Blocked Topics
Branch allows the export of blocked topics for up to 60 days from the time of the request.
Cthulhu Filter Specification
Cthulhu is a prefix notation syntax written in JSON for specifying filters on records (usually column-based records).
Purpose
Easily parses into an abstract syntax tree.
Glossaryany - any valid json basic value (number, string)... - previous item in a list can repeat as many times as necessary
| Name | Spec | Example | SQL Equivalent | 
|---|---|---|---|
| eq | ["eq",<> | ["eq","x", 1] | x= 1 | 
| gt | ["gt",<> | ["gt","x", 1] | x> 1 | 
| gte | ["gte",<> | ["gte","x", 1] | x >= 1 | 
| lt | ["lt",<> | ["lt","x", 1] | x< 1 | 
| lte | ["lte",<> | ["lte","x", 1] | x <= 1 | 
| like | ["like",<> | ["like", "x", ". *foobar"] | x LIKE "% | 
| between | ["between",<> | ["between", "x",1, 2] | x | 
| In | ["in", ,="">,=""> | ["in","x", 1,2, 3] | x IN (1,2,3) | 
| and | ["and", , ...] | ["and",["gt","x", 1],["lt","x", 2]] | x> 1 AND x < 2 | 
| or | ["or", , ...] | ["or",["eq","x", 1],["eq", | x = 1 OR x= 2 | 
| not | ["not",] | ["not",["eq","x", 1]] | x != 1 | 
| array_contains | ["array_contains", , ] | ["array_contains","last_attributed_touch_data_tilde_tags","Share"] | array_contains(array(1, 2, 3), 2) | 
Additional Examples
| Filter | Meaning | 
|---|---|
| 
 | Where  | 
| 
 | Where  | 
| 
 | Where  | 
| 
 | Where  |