Dashboard Embedding
To unlock the full potential of your data and analytic dashboards you will want to share them securely with your users. This is where embedding comes in. You can embed any dashboard in your application using the JavaScript Embedding API. No Iframes needed.
If you are looking to share dashboards publicly, you can do so by creating a public link instead:
The general embedding workflow is as follows:
- Get an API key
- Generate a JWT token in your backend to give a user access to the specific dashboard
- Use the JWT token to authenticate the user in your frontend
You can use the Embedding JS API directly or use the shaper-react library to embed Shaper into a React application.
Example Applications
Section titled “Example Applications”The fastest way to understand how to embed Shaper is to look at a complete example application:
Step by Step
Section titled “Step by Step”- 
Create an API key - In Shaper, click on “Admin” in the bottom-left.
- Then click on “API Keys” and then on “New”.
- Give the key a name and click “Create Key”.
- Copy the key and save it somewhere safe before closing the dialog.
 
- 
Get a dashboard ID - Open the dashboard you want to embed.
- Copy the ID from the sidebar on the left.
 
- 
Include Shaper in your application: <script src="http://localhost:5454/embed/shaper.js"></script>Terminal window npm install shaper-react
- 
Embed a dashboard into your frontend: <div id="dashboard-container"></div><script>const dashboard = shaper.dashboard({container: document.getElementById("dashboard-container"),dashboardId: "<your-dashboard-id>",async getJwt() {// Call your backend, then return a valid JWT},});</script>import { ShaperDashboard } from "shaper-react";// ...<ShaperDashboardbaseUrl={"http://localhost:5454"}id={"<your-dashboard-id>"}jwt={jwt}refreshJwt={() => {// Call your backend, then set the `jwt` variable to a valid JWT}}/>
- 
Call the Shaper API from your backend to generate a JWT. Endpoint: POST http://localhost:5454/api/auth/tokenRequest: {"token": "<your-api-key>","dashboardId": "<your-dashboard-id>"}Response: {"jwt": "<generated-jwt>"}const { jwt } = await fetch(`http://localhost:5454/api/auth/token`, {method: "POST",headers: {"Content-Type": "application/json",},body: JSON.stringify({token: "<your-api-key>",dashboardId: "<your-dashboard-id>",}),})By default, the JWT is valid for 10 minutes. Make sure your application logic allows for generating a new JWT when the old one expires. Make sure to authenticate the user in your backend before generating the JWT and only allow access to the dashboard if the user is allowed to see it. 
JWT Variables
Section titled “JWT Variables”Optional: Use variables to customize the dashboard to the user’s context and restrict what they are able to see.
You can pass an optional variables property to /api/auth/token to bind the generated JWT to specific variables.
Pass an object where each key is the name of the variable and the values are either strings or array of strings.
For example, your response body could look like this:
{    "token": "<your-api-key>",    "dashboardId": "<your-dashboard-id>",    "variables": {        "user_id": "123",        "project_id": ["456", "789"]    }}In SQL you can then use the variables like this:
SELECT count() FROM events WHERE user_id = getvariable('user_id');SELECT * FROM projects WHERE project_id IN getvariable('project_id');How might have noticed the “Variables” section in the dashboard editor in the sidebar on the left. You can use this to emulate setting a JSON object as “variables” attribute in the JWT token.
In the above example apps you could try passing something like this:
{ "user_id": "user_1" } 
 