Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.
Hello. I am trying to figure out how to stream/download the exported PDF file from a Power BI API Export call. I'm using a NodeJS backend with a React frontend. Here's what I'm trying to do in the backend:
const queryResults = await fetch(`https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`, {
method: 'GET',
headers: {
'content-type': 'application/pdf',
authorization: `Bearer ${(await getAccessToken()).accessToken}`
}
});
return queryResults;
Solved! Go to Solution.
Hi @trpeel ,
It sounds like you are trying to download a PDF file that has been exported from a Power BI report using the Power BI API. However, it return size 0. The possible reason is the API call is not correctly authenticated. Please update the code as below and check if it can return the expected result...
const fetch = require('node-fetch');
const workspaceId = '<your workspace ID>';
const reportId = '<your report ID>';
const exportId = '<your export ID>';
const accessToken = '<your access token>';
const url = `https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`;
const options = {
method: 'GET',
headers: {
'Content-Type': 'application/pdf',
'Authorization': `Bearer ${accessToken}`
}
};
fetch(url, options)
.then(response => {
if (!response.ok) {
throw new Error(`HTTP error ${response.status}`);
}
return response.buffer();
})
.then(buffer => {
// Do something with the PDF buffer, such as write it to a file or send it to the client
})
.catch(error => {
console.error(error);
});
Best Regards
Thank you very much. The response.buffer was the part I was missing. I appreciate the help.
Hi @trpeel ,
It sounds like you are trying to download a PDF file that has been exported from a Power BI report using the Power BI API. However, it return size 0. The possible reason is the API call is not correctly authenticated. Please update the code as below and check if it can return the expected result...
const fetch = require('node-fetch');
const workspaceId = '<your workspace ID>';
const reportId = '<your report ID>';
const exportId = '<your export ID>';
const accessToken = '<your access token>';
const url = `https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`;
const options = {
method: 'GET',
headers: {
'Content-Type': 'application/pdf',
'Authorization': `Bearer ${accessToken}`
}
};
fetch(url, options)
.then(response => {
if (!response.ok) {
throw new Error(`HTTP error ${response.status}`);
}
return response.buffer();
})
.then(buffer => {
// Do something with the PDF buffer, such as write it to a file or send it to the client
})
.catch(error => {
console.error(error);
});
Best Regards
User | Count |
---|---|
14 | |
4 | |
2 | |
1 | |
1 |
User | Count |
---|---|
20 | |
3 | |
2 | |
2 | |
2 |