- About Veeam Backup for Microsoft Azure REST API
- Overview
- How To
- Changelog
- Authorization
- Availability Sets
- Availability Zones
- Asynchronous Operations
- Azure Key Vaults
- Azure Network Security Groups
- Azure Regions
- Azure Resource Groups
- Service Accounts
- getGet Collection of Service Accounts
- getGet Service Account Data
- delRemove Service Account
- postVerify Service Account Permissions
- postExport Service Account Required Permissions
- postExport Permissions by Application
- postExport Permissions by Token
- postExport Collection of Service Accounts
- postGet List of Tenants by Token
- postGet List of Subscriptions by Application
- postGet List of Microsoft Entra Groups
- postValidate User
- postAdd Service Account Using Existing Application
- putEdit Service Account Created Using Existing Application
- putValidate Editing of Service Account Created Using Existing Application
- getGet Service Accounts Suitable for Worker Management
- putSpecify Service Account for Worker Management
- Azure SQL Elastic Pools
- Azure Storage Accounts
- Azure Subscriptions
- Azure Tags
- Microsoft Entra Tenants
- Azure Virtual Networks
- Azure VM Schedule-Based Backup Policies
- getGet Collection of Azure VM Schedule-Based Backup Policies
- postCreate Backup Policy
- getGet Backup Policy Data
- putModify Backup Policy
- delRemove Backup Policy
- getGet Resources Selected for Backup Policy
- getGet Azure Regions Specified in Policy Settings
- getGet Resources Excluded from Backup Policy
- postSet Backup Policy Priority
- postEnable Backup Policy
- postDisable Backup Policy
- postStart Backup Policy
- postStop Backup Policy
- postResets Backup Policy CBT
- postExport Backup Policies
- getGet Collection of Protected Items
- getGet Resources Protected by Backup Policy
- Azure VM SLA-Based Backup Policies
- getGet Collection of SLA-Based Backup Policies
- postCreate SLA-Based Backup Policy
- postExport Collection of SLA-Based Backup Policies
- getGet SLA-Based Backup Policy Data
- putModify SLA-Based Backup Policy
- delRemove SLA-Based Backup Policy
- getGet SLA Compliance Information
- getGet Resources Protected by SLA-Based Backup Policy
- getGet Azure Regions Specified in SLA-Based Backup Policy Settings
- getGet Resources Excluded from SLA-Based Backup Policy
- postSet SLA-Based Backup Policy Priority
- postEnable SLA-Based Backup Policy
- postDisable SLA-Based Backup Policy
- getGet Collection of Protected Items
- getGet Resources Protected by SLA-Based Backup Policy
- postCalculate Estimated Cost of SLA-Based Backup Policy
- postExport Estimation Cost Report
- Azure VM Policy Cost Estimation
- Azure VMs
- Azure VM Sizes
- Azure VMs Protected by Veeam Backup for Microsoft Azure
- getGet Collection of Protected Azure VMs
- getGet Protected Azure VM Data
- postExport Collection of Protected Azure VMs
- postRemove Backups of Protected Azure VM
- postRemove Snapshots of Protected Azure VM
- postRemove Backups of Protected Azure VMs
- postRemove Snapshots of Protected Azure VMs
- postRemove Manual Snapshots of Protected Azure VMs
- postRemove Manual Snapshots of Protected Azure VM
- Azure VM Restore Points
- getGet Azure VM Restore Points
- getGet Azure VM Restore Point Data
- delRemove Azure VM Restore Point
- postPerform Virtual Disk Restore
- postPerform Azure VM Restore
- postPerform Azure VM File-Level Restore
- postRetrieve Data from Archive
- postExtend Data Availability Period
- getGet Collection of Virtual Disk Snapshots
- postVirtual Disk Snapshots Rescan
- getGet Collection of Azure VM Snapshots
- Backup Repositories
- getGet Collection of Backup Repositories
- postAdd Backup Repository
- getGet Backup Repository Data
- putModify Backup Repository Settings
- delRemove Backup Repository
- postGet Backup Repository Metadata
- postVerify Backup Repository Password
- postExport Collection of Backup Repositories
- getValidate Repository Deletion
- Configuration
- Configuration Backup
- getGet Backup Appliance Statistics
- postCreate Configuration Backup
- getGet Configuration Backup Settings
- putModify Configuration Backup Settings
- postStart Configuration Backup Export
- getCheck Status of Configuration Backup Export
- postDownload Configuration Backup File
- getGet Configuration Backup Restore Points
- getGet Configuration Backup Restore Point Data
- delRemove Configuration Backup Restore Point
- Cosmos DB Accounts
- Cosmos DB Account Point-in-Time Restore Information
- Cosmos DB Accounts Protected by Veeam Backup for Microsoft Azure
- getGet Collection of Protected Cosmos DB Accounts
- getGet Protected Cosmos DB Account Data
- postExport Collection of Protected Cosmos DB Accounts
- postRemove Backups of Protected Cosmos DB Account
- postRemove Manual Backups of Protected Cosmos DB Account
- postRemove Continuous Backups of Protected Cosmos DB Account
- postPerform Cosmos DB Account Point-in-time Restore
- Cosmos DB Backup Policies
- getGet Collection of Cosmos DB Backup Policies
- postCreate Backup Policy
- getGet Backup Policy Data
- putModify Backup Policy
- delRemove Backup Policy
- getGet Resources Selected for Backup Policy
- getGet Azure Regions Specified in Policy Settings
- getGet Resources Excluded from Backup Policy
- postSet Backup Policy Priority
- postEnable Backup Policy
- postDisable Backup Policy
- postStart Backup Policy
- postStop Backup Policy
- postExport Backup Policies
- getGet Collection of Protected Items
- getGet Resources Protected by Backup Policy
- Cosmos DB Policy Cost Estimation
- Cosmos DB Restore Points
- File-Level Recovery
- File Share Backup Policies
- getGet Collection of File Share Backup Policies
- postCreate Backup Policy
- getGet Backup Policy Data
- putModify Backup Policy
- delRemove Backup Policy
- getGet Resources Selected for Backup Policy
- getGet Azure Regions Specified in Policy Settings
- getGet Resources Excluded from Backup Policy
- postSet Backup Policy Priority
- postEnable Backup Policy
- postDisable Backup Policy
- postStart Backup Policy
- postStop Backup Policy
- postExport Backup Policies
- getGet Collection of Protected Items
- getGet Resources Protected by Backup Policy
- File Share Policy Cost Estimation
- File Share Restore Points
- File Shares
- File Shares Protected by Veeam Backup for Microsoft Azure
- Job Sessions
- getGet Collection of Sessions
- getGet Retention Session Data
- getGet Backup Session Data
- getGet Health Check Session Data
- getGet Restore Session Data
- getGet SQL Restore Session Data
- getGet Azure VM File-Level Restore Session Data
- getGet File Share File-Level Restore Session Data
- getGet Virtual Network Configuration Restore Session Data
- getGet Session Data
- getGet Session Log Details
- postStop Session
- postExport Collection of Sessions
- getGet Cosmos DB Restore Session Data
- License
- License Agreements
- Overview
- Retention Settings
- Security Certificates
- SLA Details
- SLA Templates
- SMTP and Database Accounts
- Storage Templates
- SQL Backup Policies
- getGet Collection of SQL Backup Policies
- postCreate Backup Policy
- getGet Backup Policy Data
- putModify Backup Policy
- delRemove Backup Policy
- getGet Resources Selected for Backup Policy
- getGet Azure Regions Specified in Policy Settings
- getGet Resources Excluded from Backup Policy
- postSet Backup Policy Priority
- postCheck Configuration of Backup Policy
- postEnable Backup Policy
- postDisable Backup Policy
- postStart Backup Policy
- postStop Backup Policy
- postExport Backup Policies
- getGet Collection of Protected Items
- getGet Resources Protected by Backup Policy
- SQL Databases
- SQL Databases Protected by Veeam Backup for Microsoft Azure
- SQL Policy Cost Estimation
- SQL Restore Points
- SQL Servers
- SSO Settings
- System
- Users
- Virtual Network Configuration Backup Policy
- getGet Virtual Network Configuration Backup Policy
- putModify Virtual Network Configuration Backup Policy
- postStart Virtual Network Configuration Backup Policy
- postStop Virtual Network Configuration Backup Policy
- postEnable Virtual Network Configuration Backup Policy
- postDisable Virtual Network Configuration Backup Policy
- postExport Virtual Network Configuration Backup Policy
- Virtual Network Configuration Protected by Veeam Backup for Microsoft Azure
- Virtual Network Configuration Restore Points
- Workers
- getGet Collection of Worker Instances
- delRemove Worker Instance
- postExport Collection of Worker Instances
- getGet Worker Instance Statistics
- getGet Collection of Worker Configurations
- postAdd Worker Configuration
- getGet Worker Configuration Data
- putModify Worker Configuration
- delRemove Worker Configuration
- postExport Worker Configurations
- postSpecify Worker Location and Service Account
- getGet Collection of Worker Profiles
- postAdd Worker Profiles
- getGet Worker Profiles for Region
- putModify Worker Profiles
- delRemove Worker Profiles
- postExport Worker Profiles
- getGet Worker Custom Tags
- putModify Worker Custom Tags
To perform complex operations using the Veeam Backup for Microsoft Azure REST API, refer to this section for specific usage scenarios describing the sequence of HTTP requests that must be sent to achieve a particular result.
Veeam Backup for Microsoft Azure provides a set of requests that allow you to recover corrupted or missing files of an Azure VM to their original location from a cloud-native snapshot or image-level backup.
- Veeam Backup for Microsoft Azure does not support downloading files to a local machine using the REST API.
- Before you start file-level recovery, consider the limitations and prerequisites described in the Veeam Backup for Microsoft Azure User Guide, section Performing File-Level Recovery.
To recover files and folders of a protected Azure VM, use the following requests:
To start an FLR session, send the HTTP POST request to the
/restorePoints/virtualMachines/{restorePointId}/restoreFile
endpoint:- In the
restorePointId
path parameter, specify a system ID assigned to a restore point to which you want to restore of files and folders of the Azure VM. - In the request body, provide a reason for performing the operation, choose whether you want to restore data to the original location and specify a service account whose permissions will be used to restore data to the original location.
Request: POST https://51.11.247.127/api/v8/restorePoints/virtualMachines/{restorePointId}/restoreFile Request Parameters: restorePointId=7987aa56-a6fe-432b-a513-6af976a6e6 Request Body: { "reason": "restore corrupted items", "serviceAccountId": 45645njn-4jn5-8im6-f345-lknkjn664, "flrRto": true, }
A successfully completed operation returns the 202 response code. In the response body, Veeam Backup for Microsoft Azure returns the ID assigned to the FLR session that must be saved locally.
- In the
To retrieve the result of the FLR session, send the HTTP GET request to the
/jobSessions/{sessionId}
endpoint and specify the system ID assigned to the FLR session in thesessionId
path parameter. Then, verify whether the value of theisFlrSessionReady
parameter is true.To browse files and folders by a specific directory, send the HTTP POST request to the
/flr/{flrSessionId}/browse
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session whose items you want to browse. - In the
Offset
query parameter, specify the number that must be excluded from a response the first N items of a resource collection. The default value is0
. - In the
Limit
query parameter, specify the maximum number of items of a resource collection that must be returned in a response. The default value is200
. - In the request body, specify the absolute path to the necessary directory on Azure VM whose items will be returned in the response.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/browse Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 Limit=10 Offset=2 Request Body: { "path": "/user1/accountingdata" }
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the detailed information on each item.
Response: 200 Response Body: { "results": [ { "itemPath": "/accountingdata", "name": "report_1.txt", "type": "File", "size": 8, "lastModificationTime": "2025-02-28T11:29:18.898Z" } ], "count": 1 }
- In the
To start searching through files and folders by a specific directory and name, send the HTTP POST request to the
/flr/{flrSessionId}/search/start
endpoint:In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session in which you want to start searching for items.In the request body, specify the following information:
path
— the absolute path to the necessary directory on the Azure VM where the items you want to search are located.limit
— the number of results that must be returned in the response.traverse
— a Boolean value defining whether you want the search to be performed through all subdirectories and nested elements.searchPattern
— a name of the file or part of the name that will be used as a search template.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/search/start Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 Request Body: { "path": "/accountingdata", "limit": 10, "traverse": true, "searchPattern": "report_1" }
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the ID assigned to the search task that must be saved locally.
Response: 200 Response Body: { "searchId": "3fa85f64-5717-4562-b3fc-2c963f66afa6" }
To retrieve the results of the search task, send the HTTP GET request to the
flr/{flrSessionId}/search/{searchTaskId}/results
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session in which the search for items was performed. - In the
searchTaskId
path parameter, specify the ID assigned to the search task in the response received as a result of the request performed at step 2.
Request: GET https://51.11.247.127/api/v8/flr/{flrSessionId}/search/{searchTaskId}/results Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 searchTaskId=3fa85f64-5717-4562-b3fc-2c963f66afa6
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the state of the search task, the number of found items and information on each item.
Response: 200 Response Body: { "searchState": "Ready", "count": 3, "results": [ { "itemPath": "/accountingdata", "name": "report_1.txt", "type": "File", "size": 7, "lastModificationTime": "2025-02-26T11:29:18.898Z" }, { "itemPath": "/accountingdata", "name": "report_10.txt", "type": "File", "size": 10, "lastModificationTime": "2025-02-27T11:29:18.898Z" }, { "itemPath": "/accountingdata", "name": "report_110.txt", "type": "File", "size": 10, "lastModificationTime": "2025-02-28T11:29:18.898Z" } ] }
- In the
If the number of results exceeds the limit set in the initial search query, continue the search. To do that, send the HTTP POST request to the
/flr/{flrSessionId}/search/{searchTaskId}/nextPage
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session in which the search for items was performed. - In the
searchTaskId
path parameter, specify the ID assigned to the search task in the response received as a result of the request performed at step 2.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/search/{searchTaskId}/nextPage Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 searchTaskId=3fa85f64-5717-4562-b3fc-2c963f66afa6
NOTE
To retrieve the results of the continued search, send the HTTP GET request to the
/flr/{flrSessionId}/search/{searchTaskId}/results
endpoint as described at step 3. Note that the results obtained in the previous query will be lost.- In the
To stop the search task, send the HTTP POST request to the
/flr/{flrSessionId}/search/{searchTaskId}/stop
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session in which the items were searched. - In the
searchTaskId
path parameter, specify the ID assigned to the search task from the response that was received as a result of the request made at step 2.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/search/{searchTaskId}/stop Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 searchTaskId=3fa85f64-5717-4562-b3fc-2c963f66afa6
A successfully completed operation returns the 202 response code.
- In the
To restore specific files and folders, send the HTTP POST request to the
/flr/{flrSessionId}/restore
endpoint:In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session from which you want to restore items.In the request body, specify the absolute paths to the items you want to restore, an alternative absolute path to the directory to which the items will be restored if the original directory no longer exists, and choose whether you want to download a copy of items or restore the original items:
To download the selected files and folders to the source Azure VM, enter Keep. The files will be saved with the
restored-
prefix to the same directory where the source files are located.To restore the selected files and folders to the source Azure VM, enter Overwrite.
IMPORTANT
If the original directory no longer exists and you do not specify an alternative path to the directory on the Azure VM to restore the items, the completed operation will return the 500 response code.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/restore Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 Request Body: { "itemPaths": [ "/accountingdata/report_1.txt", "/var/log/journal/376b1a5b5e8e7064ad8b0edc1ad42/system.journal", "/billingdata/report_15.txt" ], "restoreType": "Keep", "alternativePath": "/auditdata/report_25.txt" }
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the ID assigned to the restore task that must be saved locally.
Response: 200 Response Body: { "restoreTaskId": "2044e84c-768a-47ce-8bf8-69aaa6f8540d" }
To retrieve the results of the restore task, send the HTTP GET request to the
/flr/{flrSessionId}/restore/{restoreTaskId}/status
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session from which you restored the items. - In the
restoreTaskId
path parameter, specify the ID assigned to the restore task in the response received as a result of the request performed at step 6.
Request: GET https://51.11.247.127/api/v8/flr/{restoreTaskId}/restore/{searchTaskId}/status Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 restoreTaskId=791bef75-4e10-40cf-9dcd-f9f627e14854
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the status of the restore task.
Response: 200 Response Body: { "restoreTaskId": "791bef75-4e10-40cf-9dcd-f9f627e14854", "results": [ { "path": "/accountingdata/report_1.txt", "status": "Success" } ] }
- In the
To get a detailed log for each item processed by the restore task, send the HTTP GET request to the
/flr/{flrSessionId}/restore/{restoreTaskId}/logs
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session from which you restored the items. - In the
restoreTaskId
path parameter, specify the ID assigned to the restore task in the response received as a result of the request performed at step 6. - In the
Offset
query parameter, specify the first N items of a resource collection that will be excluded from the response. - In the
Limit
query parameter, specify the maximum number of items to return in the response. - In the request body, specify a path to the item you have restored.
Request: POST https://51.11.247.127:<%PORT%>/api/v8/flr/{flrSessionId}/restore/{restoreTaskId}/logs Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 restoreTaskId=791bef75-4e10-40cf-9dcd-f9f627e14854 Request Body: { "path": "/accountingdata/report_1.txt" }
A successfully completed operation returns the 200 response code. In the response body, Veeam Backup for Microsoft Azure returns the total number of log records and detailed information on the restored items.
Response: 200 Response Body: { "path": "string", "pagination": { "totalCount": 2, "count": 2, "offset": 0, "limit": 0 }, "results": [ { "message": "/accountingdata/report_1.txt has been successfully restored", "status": "Success", "id": 1, "startTime": "2025-02-27T12:05:10.358Z", "stopTime": "2025-02-28T12:05:11.367Z" }, { "message": "Item File /accpuntingdata/report_1_RESTORED_20241003_095150.txt and its attributes were restored", "status": "Success", "id": 2, "startTime": "2025-02-28T12:05:10.358Z", "stopTime": "2025-02-28T12:05:11.367Z" } ] }
- In the
To stop the restore task, send the HTTP POST request to the
/flr/{flrSessionId}/restore/{restoreTaskId}/stop
endpoint:- In the
flrSessionId
path parameter, specify a system ID assigned to the FLR session in which the items were searched. - In the
restoreTaskId
path parameter, specify the ID assigned to the restore task from the response that was received as a result of the request made at step 6.
Request: POST https://51.11.247.127/api/v8/flr/{flrSessionId}/restore/{restoreTaskId}/stop Request Parameters: flrSessionId=7857aa56-a6fe-432b-a513-6afc6516a6e6 restoreTaskId=2044e84c-768a-47ce-8bf8-69aaa6f8540d
A successfully completed operation returns the 202 response code.
- In the
To stop the FLR session, send the HTTP POST request to the
/jobSessions/{sessionId}/stop
endpoint and specify the system ID assigned to the FLR session in thesessionId
path parameter. A successfully completed operation returns the 200 response code.