Fabric is Generally Available. Browse Fabric Presentations. Work towards your Fabric certification with the Cloud Skills Challenge.
I recently had the requirement to save the monthly Dataset of a Power BI Report. I remembered a blog post by Chris Webb on how to use Power Automate to access the Power BI Rest API. The following post describes how I use this to create a monthly PBIX backup.
In the first step, we have to register a new application that can access the Power BI APIs of our tenants. I will not describe the process in detail. Take a look at the Microsoft documentation.
The application can be registered on page
https://dev.powerbi.com/apps
Now we “Register” the application and save the “Application ID” and “Application secret” somewhere safe. They will be needed later.
Navigate to Power Automate and select “Custom connectors” under “Data” in the left navigation. Here we select the “Import an OpenAPI from URL” option from the “Create custom connector” menu.
Enter a name for your connector and import the OpenAPI definition. An OpenAPI definition for the Power BI REST API can be found here. https://raw.githubusercontent.com/microsoft/PowerBI-CSharp/master/sdk/swaggers/swagger.json
The next dialog requires some general information about the connector.
I uploaded an icon for the connector and set the background color to: #F2C811
The next dialog is to configure security.
Konstantinos has determined the following values for Azure authentication here.
After clicking on “Create connector” the Redirect URL is displayed. Depending on your location, this URL may be different.
Add the Redirect URL to the previously registered Application. Sign in to the Azure portal https://portal.azure.com
“Azure Active Directory” -> “App registrations” -> “Name of our app”. Under “Authentication”, replace the “Redirect URIs” with the URL from Power Automate.
Now we create the Power Automate Flow. First we determine the GUID of the workspace and the Power BI report that is to be archived. After opening the report, the values can be read from the address line.
For the monthly execution we choose a “Scheduled flow” in Power Automate.
Give the flow a name and set up the schedule.
In the flow, the Custom Connector can now be used with all Power BI API calls.
When you access for the first time, you must sign in and agree to the requested permissions.
You can then set up the following Power Automate Flow.
Select the Custom Connector action “Exports the specified report from the specified workspace to a .pbix file.” and rename it “Export PBIX”.
Select the “Compose” action to convert the export body into the “multipart/form-data” structure required for the import.
{
"$content-type": "multipart/form-data",
"$multipart": [
{
"body": @{body('Export_PBIX')}
}
]
}
Select the Custom Connector action “Creates new content on the specified workspace from .pbix, .json, Excel, Rdl, or file path in OneDrive for Business.” and rename it “Import PBIX”.
concat('DIAD ',
formatDateTime(utcNow(),'yyyyMMdd') ,
'.pbix')
After creation, the Power Automate Flow can be tested.
A look at the Power BI workspace shows that the copy of the report has been saved successfully.
And one last thing: Konstantinos & Chris mention in their posts, if you get a 404 error (or 403 error), just wait a few minutes.
Links:
Marcus Wegener work at KUMAVISION AG , one of the world's largest
implementation partners for Microsoft Dynamics. #
"Get the most out of data, with Power BI."
twitter - LinkedIn - YouTube - website - podcast
Hello,
This is perfect and got me excited. However, i am getting errors with the swagger file. It's some kind of schema error. Any idea whats wrong with the swagger file?
Appreciate your help.
Hello, I try to add the link but doens't work ... one idea ?
Hi @Vanessa250919 ,
It seems that the swagger.json file has become too large in the meantime.
With the following workaround it should still work.
Shrink the swagger.json by the json-minify.
Copy the minified json with copy & past into notepad and save it as swagger.json file.
https://www.cleancss.com/json-minify/
And load the minified json file via "Import an OpenAPI file".
Marcus Wegener work at KUMAVISION AG , one of the world's largest
implementation partners for Microsoft Dynamics. #
"Get the most out of data, with Power BI."
twitter - LinkedIn - YouTube - website - podcast
I haven't looked into this in a while, can you share screenshots of the problem?
Marcus Wegener work at KUMAVISION AG , one of the world's largest
implementation partners for Microsoft Dynamics. #
"Get the most out of data, with Power BI."
twitter - LinkedIn - YouTube - website - podcast
Check out the November 2023 Power BI update to learn about new features.
Read the latest Fabric Community announcements, including updates on Power BI, Synapse, Data Factory and Data Activator.