How to get power bi dashboard in our own application? - powerbi

I am new to power bi. I have power bi account there I created some dashboards with some reports, now I want to consume those dashboard and report using power bi rest API (https://learn.microsoft.com/en-us/rest/api/power-bi/)in our own application. Our application we used the .net core for back-end and angular 6 for the front end. We need to call power bi API from the .net core. If I change report in power it should also reflect in our application. I am new so I am not understanding from where to start?

Start by reading these:
Embedding with Power BI
Tutorial: Embed a Power BI report, dashboard, or tile into an application for your customers
Microsoft Power BI Embedded Playground
In essence, you need to authenticate using Azure Active Directory Authentication Libraries (ADAL), obtain the embedUrl of the dashboard, it's id and the id of the group in which it is. It will be loaded in a div section of a html file using the embedded client. For more details look at the official samples. App Owns Data means that for authenticating you are using one account, which your application knows (e.g. user name and password stored in the configuration), while User Owns Data means that each user uses his own Power BI credentials to access the embedded elements.

Related

Create a report in powerbi service through APIs in React

We have a React app.
What I actually want to do is to send JSON to power-bi service, and on the basis of that json data, powerbi service should create a visual/graphical report for me.
I want this whole process to be automated
What I have done so far is-
I have created a push dataset using powerbi REST APIs mentioned in this doc.
https://learn.microsoft.com/en-us/rest/api/power-bi/push-datasets/datasets-post-dataset-in-group
Additionally have created a table inside that dataset through this REST API in the following doc.
https://learn.microsoft.com/en-us/rest/api/power-bi/push-datasets/datasets-post-rows-in-group#code-try-0
Now, what I want is to create a visual report/graph from this table inside this dataset.
There are APIs to clone an existing report.
There are APIs to update/delete a report.
But I could not find any APIs that can be used to create a report from JSON or from an existing dataset.
MORE-
Additionally in regard to creating a report what i have found is just this page in the whole powerbi docs.
https://learn.microsoft.com/en-us/javascript/api/overview/powerbi/create-edit-report-embed-view?tabs=embed-for-your-organization#how-to-create-a-report
This could be helpful as i also want to embed the created report in my React app at the end.
however I tried it in my react app, and couldn't make it work.
Is this even possible to create a powerbi visual report (not a paginated report) with the help of REST APIs, or they can only be created manually?
Please lead my way!
PowerBI Rest APIs are used to Manage PowerBI Content, Embed Power BI Content, Perform Admin operations.
Create a Report in Power BI Service:
Follow the documentation to create a report in Power BI service.
Please note that, Currently Power BI service only supports published dataset or pasting or manually entering data in a table. To connect to other resources, download Power BI desktop.
Create a Report in Power BI Embedded:
Power BI Embedded allows us to create, edit and save reports.
Please note that, a report can be created in powerbi-embedded only if we have an existing dataset. Refer to this documentation on how to create, edit and save reports in powerbi-embedded.
References:
GitHub - microsoft/PowerBI-Developer-Samples: A collection of Power BI samples for developer use.
Embed Power BI content using a sample embed for your organization application
Embed Power BI content using a sample embed for your organization application

how to export the dashboard to excel report at power BI

I'm new at the Power BI.
I created dashboard on Power BI and I have published to the web
when opening the dashboard on custom URL I need to export the dashboard to excel report
can I do this in Power BI or not
I new I can to do this in Power BI web APP but I need do that in my dashboard URL
thank you
This "custom URL" that you mention makes me think that you used Publish to web. One of the limitations of this feature is that you can't export the data:
Reports using row level security.
Reports using any Live Connection data source, including Analysis Services Tabular hosted on-premises, Analysis Services Multidimensional, and Azure Analysis Services.
Reports shared to you directly or through an organizational content pack.
Reports in a group in which you are not an edit member.
"R" Visuals are not currently supported in Publish to web reports.
Exporting Data from visuals in a report, which has been published to the web.
ArcGIS Maps for Power BI visuals.
Reports containing report-level DAX measures.
Single sign-on data query models.
Secure confidential or proprietary information.
The automatic authentication capability provided with the Embed option doesn't work with the Power BI JavaScript API. For the Power BI JavaScript API, use the user owns data approach to embedding.
You can vote for this feature though.

How to implement user specific dashboards in Microsoft PowerBI

We have a multi tenant webapp which is used by around 300/400 users and growing. We want to use PowerBI to visualize the data and embed it inside our web app. Our ultimate goal is that each user can have their own dashboard based on their role and if PowerBI allows we also want users to edit dashboards from within the Web App. Is it possible? What should be the best practice to implement it and what type of Power BI license would it require?
App: MVC 5 Azure Web App
Database: Azure SQL database with Row Level Security
It is not possible to edit dashboards in Power BI Embedded, only reports. So lets assume each user will have his own report. When a new user is registered, you can use Clone Report In Group API to provide a standard template report to start with.
When embedding, there are two models - user owns data and app owns data. In the first mode each user needs Power BI Pro license, while in the second you need a single "master" account with Pro license. It is highly recommended to buy a dedicated capacity by purchasing Power BI Premium or Power BI Embedded.
For best practices and details about the implementation, you can read Tutorial: Embed Power BI content into an application for your organization article.

Azure portal's active directory app integration with power bi content

I have created an native app enabling powerbi service permissions in azure portal going through azure active directory -> app registration. Now I want to create power bi reports, workspace on that created app but if I go to https://app.powerbi.com I can't see that created app on my power bi app.
I am confused here actually how to add power bi reports under that app because I want to access power bi rest api using adal.js lib where I need app id and want to access reports under that app.
Anybody can clear my confusion here?
Your confusion is with the terms "Apps" in Power BI. The app you registered has nothing in common with these. It is a guid, used from Power BI to identify your native app.
When you create a native app, you register it (what you did) and Power BI REST API uses this appID (also called ClientID) to identify your app and the permissions it has. When you call the API, you need an access token. It will be acquired in the context of some user. This user must have rights for the reports you want to access. So simply make a workspace, grant rights to users and publish your reports there. Then you will be able to embed them in your app.

Power BI embedded - Publishing to Azure Workspace - Issue

As said in many reference link, in case of embedding the power bi to a application where we are going to build a secure website, we need to embed the Power BI report by publishing the power bi report to Azure Workspace right.
In that case , for registering the power bi report in Azure AD we followed the steps specified in the below link
https://azure.microsoft.com/en-in/documentation/articles/power-bi-embedded-iframe/
While trying to import the .pbix file using REST API by using the POST request to api.powerbi.com, we were receiving 403 error. Hence we were not able to proceed further with the registeration/upload of PBIX file using Import API.
Also, for standalone or anonymous public embedding website we can go with Power BI Publish to Web option, using this we can get the embed code for the power bi report, which can be embedded into the web page. In case of standalone reports we can use this option to embed the power bi report on to our application, but since in our requirement we need to filter the data based on the user selection on the custom web page, we have to go with option 1 i.e. with publishing the report to AAD (Azure AD). Since we are facing authentication issue, we are unable to proceed with the process further.
Once the report is being publish we havethought of using either Power BI JavaScript or Angular JS API to pass the filter data from custom filter pane to the power BI as shown in the demo site.