Build your first embedded data product now. Talk to our product experts for a guided demo or get your hands dirty with a free 10-day trial.
Building data visualizations from scratch can be both time-consuming and cumbersome, requiring significant effort to design and implement. Developing these capabilities in-house often involves complex coding, ongoing maintenance, and a deep understanding of data management and visualization best practices.
Luzmo addresses these challenges by offering an analytics platform that integrates with your application to provide powerful data visualization and insights. It supports real-time data syncing, customizable dashboards with a drag-and-drop interface, and AI-enhanced chart creation.
With its API-first design and advanced query engine, Luzmo offers a flexible, scalable solution for turning data into actionable insights, making it an essential tool for modern digital environments.
Whether you are using Next.js, Astro, or other app frameworks, you can create and embed low-code Luzmo dashboards, or build custom charts through code using our new Flex SDK. But whichever approach you take, you’ll need to generate an access token server-side first.
For any data product you’re building on top of Luzmo, this server-side token is the stepping stone to securely access and manage data. It ensures that only authorized requests are made and protects sensitive information. In this guide, we’ll explain how you can use Next.js App Router with Luzmo’s Node.js SDK to generate a token for use with our client-side components.
For your reference, we’ve prepared a GitHub repository which you can find on the following link.
If you don’t already have a Luzmo account, sign up now before moving to the next step.
With your account created, click on your initial (in the top right of the screen) and select Profile, then API Tokens. To create a new API token, click the Create API token button.
Make a note of the API key and API token generated, as you’ll need them in the following step. You might also like to give your API token a description so you know which application it's for.
That completes the Luzmo setup part of this guide. In the next step, you’ll create a Next.js application using the App Router.
To create a new Next.js application, head over to the docs, and follow the install instructions.
For reference, these are the options we selected from the available CLI prompts.
// .env.local
LUZMO_API_KEY=
LUZMO_API_TOKEN=
# Ensure you don’t include a trailing slash with any URLs.
NEXT_PUBLIC_LUZMO_APP_SERVER=
NEXT_PUBLIC_LUZMO_API_HOST=
Ensure you don’t include a trailing slash with any URLs.
Luzmo’s Node.js SDK is used server-side to generate access tokens for use with client-side components.
⚠️ This is for security reasons, you do not want to expose your API key & token client-side, as that would mean that users would be able to change filters or grant access to your securables.
To get started, run the following in your terminal to install the dependency.
npm install @luzmo/nodejs-sdk
// src/app/page.tsx
import Luzmo from '@luzmo/nodejs-sdk';
const client = new Luzmo({
api_key: process.env.LUZMO_API_KEY!,
api_token: process.env.LUZMO_API_TOKEN!,
host: process.env.NEXT_PUBLIC_LUZMO_API_HOST!,
});
export default async function Home() {
const response = await client.create('authorization', {
type: 'embed',
username: 'user id',
name: 'first name last name',
email: 'name@email.com',
access: {
datasets: [
{
id: '<dataset_id>',
rights: 'use',
},
],
},
});
const { id, token } = response;
return <pre>{JSON.stringify({ id, token }, null, 2)}</pre>;
}
The above code sets up the Luzmo Node.js SDK client and is provided with the environment variables you set earlier.
With a client defined, you can now make a “create” request for authorization credentials that are safe to use with client-side code.
E.g.
...
access: {
datasets: [
{
id: '<dataset_id>',
rights: 'use',
},
],
dashboards: [
{
id: '<dashboard_id>',
rights: 'use',
},
],
collections: [
{
id: '<collection_id>',
rights: 'use',
},
],
},
In the next step, we’ll show you how to use those values with a client-side Next.js component.
// src/app/components/luzmo-client-component.tsx
'use client';
interface Props {
authKey: string;
authToken: string;
}
export default function LuzmoClientComponent({ authKey, authToken }: Props) {
console.log({ authKey, authToken });
return <section>Luzmo client component</section>;
}
// src/app/page.tsx
import Luzmo from '@luzmo/nodejs-sdk';
+ import LuzmoClientComponent from './components/luzmo-client-component';
const client = new Luzmo({
api_key: process.env.LUZMO_API_KEY!,
api_token: process.env.LUZMO_API_TOKEN!,
host: process.env.NEXT_PUBLIC_LUZMO_API_HOST!,
});
export default async function Home() {
const response = await client.create('authorization', {
type: 'embed',
username: 'user id',
name: 'first name last name',
email: 'name@email.com',
access: {
datasets: [
{
id: '<dataset_id>',
rights: 'use',
},
],
},
});
if (!response) return null;
const { id, token } = response;
+ return <LuzmoClientComponent authKey={id} authToken={token} />;
- return <pre>{JSON.stringify({ id, token }, null, 2)}</pre>;
}
That just about wraps things up! You now have all the pieces in place to build with Luzmo and Next.js. You can create low-code dashboards and embed them into your application, personalize charts and dashboards based on user logins, and render charts dynamically using Luzmo Flex.
These features allow you to efficiently create and customize data visualizations, improving your application’s functionality and end-user experience.
Build your first embedded data product now. Talk to our product experts for a guided demo or get your hands dirty with a free 10-day trial.