UNPKG

@mediarithmics/plugins-nodejs-sdk

Version:

This is the mediarithmics nodejs to help plugin developers bootstrapping their plugin without having to deal with most of the plugin boilerplate

95 lines (76 loc) 3.86 kB
import { map } from '../../../utils'; import { TemplatingEngine } from '../../common/TemplatingInterface'; import { AdRendererBaseInstanceContext, AdRendererBasePlugin } from '../base/AdRendererBasePlugin'; export interface AdRendererTemplateInstanceContext extends AdRendererBaseInstanceContext { width: string; height: string; creative_click_url?: string; render_click_url?: (...args: unknown[]) => string; ias_client_id?: string; render_additional_html?: (...args: unknown[]) => string; } export abstract class AdRendererTemplatePlugin extends AdRendererBasePlugin<AdRendererBaseInstanceContext> { /** * The engineBuilder that can be used to compile the template * during the InstanceContext building * * Have to be overriden (see examples) */ protected abstract engineBuilder: TemplatingEngine<unknown, string | undefined, (...args: unknown[]) => string>; constructor(enableThrottling = false) { super(enableThrottling); } /** * Build a basic InstanceContext for "template" aware AdRenderer. * This method can be overriden by your implementation (and you can then still call it with `super.instanceContextBuilder(creativeId, forceReload)`) * * This instanceContext takes the hypothesis that: * - You have exactly one "URL" Plugin property on your instance * - You have one "STRING" Plugin property on your instance called "additional_html" that contains 'templateable' HTML * - You have one "STRING" Plugin property on your instance called "ias_client_id" that contains an IAS Client Id as a String * * If your Plugin instance don't respect those hypothesis, the returned InstanceContext will have `undefined` values in some/all fields. * * If you want to do Templating but you don't want to validate the above hypothesis, you're encouraged to build your Plugin Impl. by extending `AdRendererBasePlugin<AdRendererBaseInstanceContext>` * instead of this class. This class should then only be used as an example. * * @param creativeId * @param forceReload */ protected async instanceContextBuilder( creativeId: string, forceReload = false, ): Promise<AdRendererTemplateInstanceContext> { const baseInstanceContext = await super.instanceContextBuilder(creativeId, forceReload); if (!this.engineBuilder) { throw new Error(`No engine builder have been added to the plugin An engine builder is mandatory to extend this plugin class`); } this.engineBuilder.init(); const urlProperty = baseInstanceContext.properties.findUrlProperty(); if (!urlProperty) { const msg = `crid: ${creativeId} - url property is undefined`; this.logger.warn(msg); } const creativeClickUrl = map(urlProperty, (p) => p.value.url); const compiledClickUrl = map(creativeClickUrl, (url) => this.engineBuilder.compile(url)); const additionalHTMLProperty = baseInstanceContext.properties.findStringProperty('additional_html'); const additionalHTML = map(additionalHTMLProperty, (p) => p.value.value); const compiledAdditionalHTML = map(additionalHTML, (html) => this.engineBuilder.compile(html)); const IASProperty = baseInstanceContext.properties.findStringProperty('ias_client_id'); const IASClientId = map(IASProperty, (p) => p.value.value); const width = baseInstanceContext.displayAd.format.split('x')[0]; const height = baseInstanceContext.displayAd.format.split('x')[1]; const context: AdRendererTemplateInstanceContext = { displayAd: baseInstanceContext.displayAd, properties: baseInstanceContext.properties, width: width, height: height, creative_click_url: creativeClickUrl, render_click_url: compiledClickUrl, render_additional_html: compiledAdditionalHTML, ias_client_id: IASClientId, }; return context; } }