---
title: Account Data Transfer
framework: accountdatatransfer
role: collection
role_heading: Framework
path: accountdatatransfer
---

# Account Data Transfer

Download App Store information, app install, and push notification activity on behalf of people who use your app.

## Overview

Overview Use the Account Data Transfer web API to request and download information about the people who use your app. The data available relates to someone’s use of Apple’s App Store, including information such as previous transactions and downloads. It also contains information related to app install and push notification activity. Understand scopes A scope identifies a subset of data that your apps and website can access from a single Apple Account, with approval from the individual whose data you request. Only select the applicable scopes for your apps and website. User information scope The developer portal selects the data-transfer-user-profile scope automatically when you request access to another scope. App Store information scopes note: If you’ve previously requested access to App Store information using the appstore-user-profile scope along with older scope names, the system accepts these scopes and automatically approves them for both EU and UK scopes. You don’t need to make a new token request. App install and push notification activity scopes Request permission for the specific scopes To get permission for your App ID or Services ID to request App Store information and app install and push notification scopes for users in the EU, the UK, or Japan, follow the instructions at Request access to the Account Data Transfer API. note: This API returns account data about users in the EU, UK, and Japan. If you’re an app developer and need to transfer data related to App Store information, app install, or push notification activity for your app instead, use the App Data Transfer API. If you request access to the Account Data Transfer API, and Apple grants your request, you don’t need to supply the consent_mode query parameter when you request an authorization token for the App Data Transfer API. If you have any questions about the data made available in this API, including about how Apple applies privacy measures to protect user privacy and complies with legal obligations, contact Apple through Feedback Assistant by selecting the following option: Developer Tools & Resources > Data Portability > Account Data Transfer API Learn more about how to use Feedback Assistant. Understand the difference between scope types When making requests, it’s important to understand the scopes you can combine in a single request, and the scopes you need to request separately, as well as which are one-time requests and which can be either one-time or recurring requests. The following table describes the relationships between the available scopes:.  |  |   |  |   |  |   |  |   |  |   |  |   |  |  Set required HTTP headers for the requested scopes Set the request frequency When making an HTTP POST request to the Submit request endpoint, requesting the App Store or app install activity scope, you can request a one time or recurring request, depending on the specified scopes: To make a one-time request, set the mode key to ONE_TIME. To make recurring requests, for app install or push notification activity, use one of the following values: note: If you already have a recurring request pending and make another recurring request, the system returns an error, along with the ID of the existing request. Save the server request ID and check delay value The Apple server returns a request ID, which you use when you get the request status, request download URLs, or cancel the request. For recurring requests, the Apple server returns a request ID, along with the parent ID that identifies the series of recurring requests. The response from the server also contains a statusCheckDelay, which is the number of seconds you need to wait before checking the status of the request. You can cancel a request before this time by making a POST request to the Cancel request endpoint. If you submit a DAILY_30 recurring request and don’t resubmit the recurring instance each subsequent day, the recurring request expires 40 days after submission of the initial request. If you submit a WEEKLY_180 recurring request and don’t resubmit the recurring instance each subsequent week, the recurring request expires 190 days after submission of the initial request. Find the request status The data corresponding to the request you submitted isn’t available immediately. After the status-check delay expires, make a GET request to Get one-time request status or Get recurring request status. Use the endpoint that corresponds to the scope of the requested report and include the request identifier in the path. If the job status is completed or completed_with_error, the data associated with the request is ready to download. Transfer data Get the download URLs for a completed request by making a GET request to Get one-time request download URLs or Get recurring request download URLs, including the request identifier in the path. The response contains a list of URLs to which you make GET requests, to retrieve the person’s data. Download URLs are available for 3 days after the download request completes. The URLs you receive are valid for 15 minutes after you request them. For information on the content and terms used in the files you download, see Data and Privacy. Resubmit recurring requests For app install or push notification requests, add the next instance of a recurring request to the queue by making a POST request to the Resubmit request endpoint. Include the parent request identifier and the request identifier of the most recent instance in your request. The server’s response contains the request identifier of the new request, and a delay to wait before you can check the new request’s status.

## Topics

### Request creation

- [Submit request](accountdatatransfer/submit-request.md)
- [JobSubmission](accountdatatransfer/jobsubmission.md)
- [CreatedJob](accountdatatransfer/createdjob.md)
- [Resubmit request](accountdatatransfer/resubmit-request.md)
- [ResubmissionRequest](accountdatatransfer/resubmissionrequest.md)
- [ResubmissionResponse](accountdatatransfer/resubmissionresponse.md)

### Status

- [Get one-time request status](accountdatatransfer/get-one-time-request-status.md)
- [Get recurring request status](accountdatatransfer/get-recurring-request-status.md)
- [RequestStatus](accountdatatransfer/requeststatus.md)

### Downloads

- [Get one-time request download URLs](accountdatatransfer/get-one-time-request-download-urls.md)
- [Get recurring request download URLs](accountdatatransfer/get-recurring-request-download-urls.md)
- [DownloadLinks](accountdatatransfer/downloadlinks.md)
- [DownloadError](accountdatatransfer/downloaderror.md)

### Cancellation

- [Cancel request](accountdatatransfer/cancel-request.md)
- [CancellationRequest](accountdatatransfer/cancellationrequest.md)
- [CancellationResponse](accountdatatransfer/cancellationresponse.md)
