import { getSoapboxConfig } from 'soapbox/actions/soapbox'; import type { RootState } from 'soapbox/store'; import type { Card } from 'soapbox/types/entities'; /** Map of available provider modules. */ const PROVIDERS: Record Promise> = { soapbox: async() => (await import(/* webpackChunkName: "features/ads/soapbox" */'./soapbox-config')).default, rumble: async() => (await import(/* webpackChunkName: "features/ads/rumble" */'./rumble')).default, }; /** Ad server implementation. */ interface AdProvider { getAds(getState: () => RootState): Promise, } /** Entity representing an advertisement. */ interface Ad { /** Ad data in Card (OEmbed-ish) format. */ card: Card, /** Impression URL to fetch when displaying the ad. */ impression?: string, } /** Gets the current provider based on config. */ const getProvider = async(getState: () => RootState): Promise => { const state = getState(); const soapboxConfig = getSoapboxConfig(state); const isEnabled = soapboxConfig.extensions.getIn(['ads', 'enabled'], false) === true; const providerName = soapboxConfig.extensions.getIn(['ads', 'provider'], 'soapbox') as string; if (isEnabled && PROVIDERS[providerName]) { return PROVIDERS[providerName](); } }; export { getProvider }; export type { Ad, AdProvider };