Register providers that supply metadata, audio streams, dashboard content, and more to Nuclear.
Providers API for Plugins
Providers are modules that fulfill specific data requests from Nuclear. When the player needs to search for tracks, stream audio, or populate the dashboard, it queries the providers for that kind of request. Different provider kinds serve different purposes, and plugins can register as many providers as they need.
All registration and lookup goes through api.Providers.
Every provider extends the ProviderDescriptor base type, which requires an id, kind, and name. Each provider kind then adds its own domain-specific methods (e.g., search for metadata, getStreamUrl for streaming).
register() returns the provider's ID, which you pass to unregister() later.
Provider lifecycle
Always register in onEnable and unregister in onDisable. If you skip unregistration, the provider stays in Nuclear's registry after your plugin is disabled, and the player may still pass queries to that phantom provider.
Hook
Action
onEnable
api.Providers.register(provider)
onDisable
api.Providers.unregister(providerId)
Base type
All providers share this shape:
Each provider kind (e.g., MetadataProvider, StreamingProvider, DashboardProvider) extends ProviderDescriptor with its own methods. See the individual guides linked above for details.