title |
---|
Embedded analytics SDK - quickstart with sample app |
{% include beta-blockquote.html %}
{% include plans-blockquote.html feature="Embedded analytics SDK" sdk=true %}
This guide sets up the embedded analytics SDK with a sample React app, but you can follow along with your own application.
- Node.js 20.x LTS or higher (for the sample application).
- Metabase version v1.51 or higher.
We're going to do some setup in Metabase, and in the sample application.
- Install Metabase Enterprise Edition (if you haven't already)
- Activate your license
- Enable embedding
- Enable SSO with JWT
- Get the sample application.
- Set up the application environment.
- Run the app server to handle authentication with JWT and server the embedded Metabase components.
- Run the client application that will contain Metabase components built with the SDK.
And then fiddle around with styling.
Let's go.
You can run Metabase Pro on a Cloud plan with a free trial.
Or run it locally. Here's a docker one-liner:
docker run -d -p 3000:3000 --name metabase metabase/metabase-enterprise:latest
You can also download the JAR, and run it like so:
java --add-opens java.base/java.nio=ALL-UNNAMED -jar metabase.jar
By default, Metabase will run at http://localhost:3000
.
If you get stuck, check out our installation docs.
To enable SSO with JWT when self-hosting, you'll need to activate your license. Metabase Pro plans on Cloud take care of this for you.
From any Metabase page, click on the gear icon in the upper right and select Admin Settings > Settings > Embedding.
Turn on:
- Embedded analytics SDK
- Static embedding
Otherwise, this whole thing is hopeless.
From any Metabase page, click on the gear icon in the upper right and select Admin Settings > Settings > Authentication.
On the card that says JWT, click the Setup button.
In JWT IDENTITY PROVIDER URI field, paste
localhost:9090/sso/metabase
Or substitute your Cloud URL for /localhost
.
Click the Generate key button.
Copy the key and paste it in your .env
file into the env var METABASE_JWT_SHARED_SECRET
.
The application server will use this key to sign tokens so Metabase knows the application's requests for content are authorized.
Be sure to hit the Save and enable button, or all is void.
Clone the Metabase Node JS React SDK embedding sample app.
git clone git@github.com:metabase/metabase-nodejs-react-sdk-embedding-sample.git
In the sample app's main directory, copy the .env.example
template to .env
.
cp .env.example .env
In .env
, make sure REACT_APP_METABASE_INSTANCE_URL
and METABASE_INSTANCE_URL
point to your Metabase instance URL, e.g., http://localhost:3000
.
Your .env
will look something like:
# FRONTEND
PORT=3100
REACT_APP_METABASE_INSTANCE_URL="http://localhost:3000"
REACT_APP_AUTH_PROVIDER_URI="http://localhost:9090/sso/metabase"
# BACKEND
BACKEND_PORT=9090
METABASE_INSTANCE_URL="http://localhost:3000"
METABASE_JWT_SHARED_SECRET="TODO"
Change into the server
directory:
cd server
Install packages:
npm install
Start the server:
npm start
Change into the client
directory.
Install packages:
npm install
This command will install the Metabase embedded analytics SDK, in addition to the application's other dependencies.
In a different terminal, change into the client
directory:
cd client
Install dependencies:
npm install
Start the client app:
npm start
Your browser should automatically open the app. By default, the app runs on http://localhost:3100.
In your app, you'll see an embedded InteractiveQuestion
component.
<MetabaseProvider authConfig={authConfig} theme={theme}>
<InteractiveQuestion questionId={questionId} />
</MetabaseProvider>
Try changing some of the theme
options in the client app to style the components.