Introduction
The Apache Superset Userview Menu plugin is used to integrate Apache Superset dashboards into Joget DX Userview Menu. User can choose to embed their dashboard in either public or protected. Customisation options can be configured to show or hide before rendering the dashboard.
This plugin is created with the use of Superset Embedded SDK to embed the Superset dashboards into Joget DX.
This plugin source code and jar is available in JogetOSS repository at https://github.com/jogetoss/superset-menu.
Plugin Information
Plugins Available in the Bundle:
- Apache Superset Userview Menu 
This plugin bundle is compatible with Joget DX 8.
Expected Outcome
Able to display an Apache Superset dashboard in Joget Userview Menu as shown in Figure 1.
Figure 1: A dashboard from Apache Superset displayed in userview menu
Get Started
Prerequisites / Assumptions
Before proceeding, make sure you have the following prerequisites:
- Docker installed on your system
- Basic familiarity with Docker Compose
- Familiarity with Apache Superset
Please follow the link to setup Apache Superset using Docker: https://superset.apache.org/docs/installation/installing-superset-using-docker-compose/.
If you wish to use other means other than Docker to setup Apache Superset, please dive into their documentation under Installation and Configuration for more details.
How to install Apache Superset (Simplified Version)
1. Install a Docker Engine and Docker Compose
2. Clone Superset's GitHub repository
git clone https://github.com/apache/superset.git
3. Launch Superset Through Docker Compose
Enter the "superset" folder
cd superset
Run in development mode using the following code:
docker compose up
In docker, you can see that the superset container is running:
Figure 2: Docker Superset Container Running
4. Log in to Superset
Wait for a short while, after that you can launch http://localhost:8088/ which is the default hosting location, and you can see the following login page.
Username "admin", password "admin" will be the default user credentials.
Figure 3: Hosting Apache Superset Locally
After logging in, this will be the main page of superset.
Figure 4: Landing page of Superset
First steps to get started in Apache Superset
Problem: If you are not able to login
Figure 5: Invalid Login
You might need to run following command to setup username and password manually:
docker-compose exec superset bash docker/docker-init.sh
Steps
Where to get plugin
Please refer to Source Code and Plugin Download.
How to install and use the plugin
1. In Joget, go to UI Builder. Under Marketplace section, drag the Apache Superset Userview Menu into the UI.
Figure 6: UI Builder
2. Fill in all the plugin configuration properties by referring to Apache Superset Userview Menu Properties.
3. Save and run in UI. You will be able to see the Apache Superset Dashboard.
Figure 7: Apache Superset Dashboard shown
Apache Superset Userview Menu Properties
Configure Apache Superset Dashboard Menu
Figure 3: Plugin Configurations with no Dashboard Type
Figure 4: Plugin Configurations with Public Dashboard Type
Figure 5: Plugin Configurations with Protected Dashboard Type
| Name | Description | 
|---|---|
| Label | Menu label. Mandatory field. | 
| Menu ID | Menu element unique ID. | 
| Dashboard Type | The type of dashboard that is shown to the user. 
 | 
| Dashboard URL | This field is visible when "Dashboard Type" is public. Defines the entire URL of the dashboard. Example: http://localhost:8088/superset/dashboard/5/ (Assuming your Apache Superset is running on default http://localhost:8088/). | 
| Apache Superset URL | This field is visible when "Dashboard Type" is protected. Defines the domain running Apache Superset. Example: http://localhost:8088 (Assuming your Apache Superset is running on default http://localhost:8088/) | 
| Superset Username | This field is visible when "Dashboard Type" is protected. Superset username used to create guest token. Refer to Configure Superset User Permissions. | 
| Superset Password | This field is visible when "Dashboard Type" is protected. Superset user password used to create guest token. | 
| Dashboard Embed ID | This field is visible when "Dashboard Type" is protected. Embed ID retrieved from Superset dashboard. Refer to Retrieve Superset Dashboard Embed ID. | 
| Show Title | This option is visible when "Dashboard Type" is protected. Show or hide the title of the dashboard. 
 | 
| Show Tabs | This option is visible when "Dashboard Type" is protected. Show or hide the tabs of the dashboard. 
 | 
| Show Chart Controls | This option is visible when "Dashboard Type" is protected. Show or hide the chart controls of the dashboard. 
 | 
| Show Filters | This option is visible when "Dashboard Type" is protected. Show or hide the filter bar of the dashboard. 
 | 
Apache Superset Dashboard Configurations
Please navigate to the domain where your superset is hosted, if you follow the documentation in Get Started -> Prerequisites / Assumptions, the default host location will be http://localhost:8088/.
Configure All Dashboard to be Public
- Settings > List Roles > Edit Record for "Public" role 
- Add Permissions: - can read on chart 
- can read on Dashboard 
- can dashboard on Superset 
- can explore json on Superset 
- all datasource access on all_datasource_access 
- all database access on all_database_access 
 
And any other permissions if required.
Figure 6: Edit Role for "Public"
Configure Specific Dashboard to be Public
- Settings > List Roles > Edit Record for "Public" role
- Add Permissions:- can read on chart
- can read on Dashboard
- can dashboard on Superset
- can explore json on Superset
- datasource access on [examples]
- database access on [examples]
 
And any other permissions if required.
Figure 7: Permission "datasource access on [examples]"
Figure 8: Permission "database access on [examples]"
Configure Superset User Permissions
When "Dashboard Type" is protected, username and password is required. The user is required to generate guest token for end user to access the dashboard anonymously. The guest token that is generated follows the role configured in config.py for Superset (Figure 5). Note: the guest does not follow the role of the user configured in Apache Superset Userview Menu. The default role for guest is "Public".
To generate the least permission user to only be used to generate guest token, create a new user and role for it.
Create a new role (Figure 6):
- Settings > List Roles > Add a new record
- Add Permissions:- can read on SecurityRestApi
- can grant guest token on SecurityRestApi
 
Create a new user (Figure 7):
- Settings > List Users > Add a new record
- Link Role (Role created in Figure 6)
To read more on roles, refer to Apache Superset Documentation on roles: Apache Superset: Security > Provided Roles.
Figure 9: Default setting for Guest Role at Config.py for Superset
Figure 10: Add new role to generate guest token
Figure 11: Add new user to generate guest token
Retrieve Superset Dashboard Embed ID
- At config.py for Superset, enable "EMBEDDED_SUPERSET" to True. 
- Dashboards > any dashboard > Settings > Embed dashboard 
- Copy the embed ID 
Figure 12: Enable Embedded_Superset to True at Config.py for Superset
Figure 13: Embed dashboard option enabled after setting in Config.py
Figure 14: Embed ID in Embed dashboard
Customising Options for Superset Dashboard before Render
- Show Title 
- Show Tabs 
- Show Chart Controls 
- Show Filters 
Figure 15: Original dashboard without customisation
Figure 16: Show Title
Figure 17: Show Chart Controls
Disabling CSRF protection
- If you face any CSRF errors, at config.py for Superset, enable "WTF_CSRF_ENABLED" to False. This will disable all CSRF protection.
Figure 18: Disabling CSRF protection
Source Code and Plugin Download
- Please visit https://github.com/jogetoss/superset-menu for the plugin's source code.
- You can find the latest release at https://github.com/jogetoss/superset-menu/releases.
- Upload the plugin to your Joget by navigating to Settings > Manage Plugins > Upload Plugin as admin.
Related Links
- https://github.com/jogetoss/superset-menu
- https://github.com/jogetoss/superset-menu/releases
- https://github.com/apache/superset/tree/master/superset-embedded-sdk
- https://superset.apache.org/docs/installation/installing-superset-using-docker-compose/
- https://superset.apache.org/docs/security/





















