Apache Superset's extension system is designed to enable powerful customization while maintaining stability, security, and performance. This page explains the architectural principles, system design, and technical mechanisms that make the extension ecosystem possible.
The extension architecture is built on six core principles that guide all technical decisions and ensure extensions can be developed safely and predictably:
Superset's core should remain minimal, with many features delegated to extensions. Built-in features use the same APIs and extension mechanisms available to external developers. This approach:
All extension points are clearly defined and documented. Extension authors know exactly where and how they can interact with the host system. Each extension declares its capabilities in a metadata file, enabling the host to:
Public interfaces for extensions follow semantic versioning, allowing for:
Extensions are loaded and activated only when needed, which:
The architecture encourages reusing extension points and patterns across different modules, promoting:
The system evolves based on real-world feedback and contributions. New extension points and capabilities are added as needs emerge, ensuring the platform remains relevant and flexible.
The extension architecture is built around three main components that work together to create a flexible, maintainable ecosystem:
Two core packages provide the foundation for extension development:
Frontend: @apache-superset/core
This package provides essential building blocks for frontend extensions and the host application:
By centralizing these resources, both extensions and built-in features use the same APIs, ensuring consistency, type safety, and a seamless user experience. The package is versioned to support safe platform evolution while maintaining compatibility.
Backend: apache-superset-core
This package exposes key classes and APIs for backend extensions:
It includes dependencies on critical libraries like Flask-AppBuilder and SQLAlchemy, and follows semantic versioning for compatibility and stability.
apache-superset-extensions-cli
The CLI provides comprehensive commands for extension development:
By standardizing these processes, the CLI ensures extensions are built consistently, remain compatible with evolving versions of Superset, and follow best practices.
The Superset host application serves as the runtime environment for extensions:
Extension Management
/api/v1/extensions endpoint for registration and managementextensions database tableExtension Storage
The extensions table contains:
The following diagram illustrates how these components work together:
The diagram shows:
Extensions can depend on any combination of packages based on their needs. For example:
Frontend-only extension (e.g., a custom chart type):
@apache-superset/core for UI components and React APIsFull-stack extension (e.g., a custom SQL editor with new API endpoints):
@apache-superset/core for frontend componentsapache-superset-core for backend APIs and modelsThis modular approach allows extension authors to choose exactly what they need while promoting consistency and reusability.
One of the most sophisticated aspects of the extension architecture is how frontend code is dynamically loaded at runtime using Webpack's Module Federation.
The architecture leverages Webpack's Module Federation to enable dynamic loading of frontend assets. This allows extensions to be built independently from Superset.
Extension Configuration
Extensions configure Webpack to expose their entry points:
new ModuleFederationPlugin({ name: 'my_extension', filename: 'remoteEntry.[contenthash].js', exposes: { './index': './src/index.tsx', }, externalsType: 'window', externals: { '@apache-superset/core': 'superset', }, shared: { react: { singleton: true }, 'react-dom': { singleton: true }, 'antd-v5': { singleton: true } } })
This configuration does several important things:
exposes - Declares which modules are available to the host application. The extension makes ./index available as its entry point.
externals and externalsType - Tell Webpack that when the extension imports @apache-superset/core, it should use window.superset at runtime instead of bundling its own copy. This ensures extensions use the host's implementation of shared packages.
shared - Prevents duplication of common libraries like React and Ant Design. The singleton: true setting ensures only one instance of each library exists, avoiding version conflicts and reducing bundle size.
The following diagram illustrates the module loading process:
Here's what happens at runtime:
@apache-superset/core, which resolves to window.supersetOn the Superset side, the APIs are mapped to window.superset during application bootstrap:
import * as supersetCore from '@apache-superset/core'; import { authentication, core, commands, environment, extensions, sqlLab, } from 'src/extensions'; export default function setupExtensionsAPI() { window.superset = { ...supersetCore, authentication, core, commands, environment, extensions, sqlLab, }; }
This function runs before any extensions are loaded, ensuring the APIs are available when extensions import from @apache-superset/core.
This architecture provides several key benefits:
Now that you understand the architecture, explore: