vast-builder

An awesome library with great API which offer a complete support for IAB Video Ad Serving Template standard: VAST2, VAST3 and VAST4

Main features are :
- validate a VAST from string input
- awesome API to create 100% iab valid VAST 2, 3 & 4
- validate created VAST
Why is it the best ? :
- made by developers for developers
- fully maintained
- 100% test coverage, including stress test and memory leak test see
- build directly on top of the documentation see
- extermly fast, without any native dependancy
- full JSdoc for functionnal intellisense autocomplete (including params)
with only one stand alone dependance.
All APIs are directly generated on top of standard IAB specifications documents : https://www.iab.com/vast/
Getting started
Install
It requires node 8 or above.
# with npm npm i vast-builder --save # with yarn yarn add vast-builder
Validate existing VAST
const validate = ; // simply pass the vast string to validateconst bool = ;
Option | Default | Description |
---|---|---|
logWarn |
false |
Validation warning and error will be printed to stderr. |
throwOnError |
false |
Validation errors will now throw an exception. |
Create new VAST
const createVast = ; // vast1 is deprecated and not supportedconst vast2 = createVast;const vast3 = createVast;const vast4 = createVast;
Sample
Here is a sample VAST3 Ad :
const vast3 = createVast;vast3 const render = vast3;
Will render this VAST :
<![CDATA[imp_link]]> <![CDATA[Society]]> <![CDATA[Title]]> <![CDATA[content]]> <![CDATA[00:30:00]]> <![CDATA[my_video]]> <![CDATA[ressource_link]]>
You can also use intermediates objects, the result will be exactly the same :
const vast3 = createVast;const Ad = vast3;const InLine = Ad;Inline;Inline;Inline;const Creatives = Inline;// etc ...
Fast learn
This is a recursive API, meaning all elements can invoke all same methods from each returned object. This way and you can navigate between elements easly.
As XML is a tree, in this API:
- when you "attach" an element to another, you move on the new child a level lower
- when you "add" an element to another, you stay on the current object on the same level
Here is a demo with helping indentation :
vast3 // Ad // Inline // Inline : add = same level // Inline // Creatives : attach = lower level // Creative // Linear // TrackingEvents // Linear : and = upper level // Linear // MediaFiles // etc ...
API
This package does no magic under the hood, the API is very redondant and always the same, for easy learn and easy maintainability
Full API
Full APIs are availables here :
Common Node API
Every elements inherits from a generic VastElement, all methods return a VastElement child allowing to chain methods calls.
// You can init Tag with nothing, content, attribute or both// each detailled methods signature is available in full documentation (below) // add*()// return the current VastElement itself, allowing chaining at same level// nb: Replace ValidTag by a spec valid tag, depending on current VastElementVastElement;VastElement;VastElement;VastElement; // attach*()// return VastElement child, alowing chaining at lower level// nb: Replace ValidTag by a spec valid tag, depending on current VastElementVastElement;VastElement;VastElement;VastElement; // dangerouslyAttachCustomTag// dangerouslyAddCustomTag// attach or add wathever Tag you need, usefull for <Extensions> childs// name is the <Tag> you want, cannot be validatedconst child = VastElement;const self = VastElement; // and: can be called on every object to return the parent tagconst father = VastElement; // back: is an alias for element.and().and()const grandFather = VastElement; // cdata: turn content into cdata, return the current object// apply recursively to be able to make addValidTag().cdata() apply to childs// nb: if option cdata is true, it does nothingVastElement; // content: return the string content (without any cdata)const stringContent = VastElementcontent; // content: return the raw attributes objectconst attributes = VastElementattrs; // getAttrs: return sanitized attributes object (invalid attributes are removed)const attrsObject = VastElement; // getChilds: return an array with childs filtered by "name"const childs = VastElement;// nb: childs are available via :const childs = VastElementchilds; // getVastVersion: return an integer of current vast versionconst intVersion = VastElement; // validate: assert the entire VAST is valid// nb: if "logWarn" option is true, it will print errors to stderr// nb: if "throwOnError" option is true, it will throw an exception if the vast is not validconst boolValid = VastElement; // toXml: return the generated Vast xml stringconst xmlVast = VastElement;
Options
You can pass options to the createVast.vX(options)
method.
Availables options are :
Option | Default | Description |
---|---|---|
cdata |
true |
Force all contents to use <![CDATA[ ]]></a> tags. |
logWarn |
true |
Validation warning and error will be printed to stderr. |
throwOnError |
false |
Validation errors will now throw an exception. |
validateOnBuild |
false |
Run a validation before build, usefull for development environment. |
spaces |
2 |
Number of spaces to be used for indenting XML output. Passing characters like ' ' or '\t' are also accepted. |
Following options are also available and inherited from awesome xml-js package :
Option | Default | Description |
---|---|---|
fullTagEmptyElement |
false |
Whether to produce element without sub-elements as full tag pairs <a></a> rather than self closing tag <a/> . |
indentCdata |
false |
Whether to write CData in a new line and indent it. Will generate <a>\n <![CDATA[foo]]></a> instead of <a><![CDATA[foo]]></a> . |
indentAttributes |
false |
Whether to print attributes across multiple lines and indent them (when spaces is not 0 ). |
ignoreDeclaration |
false |
Whether to ignore writing declaration directives of xml. For example, <?xml?> will be ignored. |
ignoreInstruction |
false |
Whether to ignore writing processing instruction of xml. For example, <?go there?> will be ignored. |
ignoreAttributes |
false |
Whether to ignore writing attributes of the elements. For example, x="1" in <a x="1"></a> will be ignored |
ignoreComment |
false |
Whether to ignore writing comments of the elements. That is, no <!-- --> will be generated. |
ignoreCdata |
false |
Whether to ignore writing CData of the elements. That is, no <![CDATA[ ]]> will be generated. |
ignoreDoctype |
false |
Whether to ignore writing Doctype of the elements. That is, no <!DOCTYPE > will be generated. |
ignoreText |
false |
Whether to ignore writing texts of the elements. For example, hi text in <a>hi</a> will be ignored. |
Contribute
All PR are welcome. This project and it's documentation are automatically generated from specs/*.yml files.
This command do all builds :
yarn build-api
The tests fixtures are generated by the tests if they not existed. To clean them use :
yarn clean-fixtures
Thinks to check in the next commit if the result is still valid.
Stress test
You can clone this project to compare performance between this package and a native based one (vast-xml) : https://github.com/DavidBabel/vast-builder-stress-test
Actual mesured speed test for 50000 generated VAST is :
- this package: 28s
- vast-xml package: 29s
and we have a much better api ;)
License
MIT. Copyright (c) David Babel.
Contribs
Thanks for your gentle contribs :
Donations: If you like this package, want it to be maintened and use it to makes millions, you can buy me a coffee ☕ or a beer 🍺.