Skip to content

Commit

Permalink
adds module docs
Browse files Browse the repository at this point in the history
  • Loading branch information
karimMourra committed Oct 21, 2022
1 parent 4a5ddef commit 6d4aae5
Show file tree
Hide file tree
Showing 4 changed files with 201 additions and 0 deletions.
25 changes: 25 additions & 0 deletions modules/jwplayerVideoProvider.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Overview

Module Name: JW Player Video Provider
Module Type: Video Submodule
Video Player: JW player
Player website: https://www.jwplayer.com/html5-video-player/
Maintainer: [email protected]

# Description

Video provider to connect the Prebid Video Module to JW Player.

# Requirements

Your page must embed a build of JW Player.
i.e.
```html
<head>
<script src="https://cdn.jwplayer.com/players/UVQWMA4o-kGWxh33Q.js"></script>
</head>
```

[Additional embed instructions](https://docs.jwplayer.com/platform/docs/players-get-started)

[Obtaining a license](https://info.jwplayer.com/contact-us/)
154 changes: 154 additions & 0 deletions modules/videoModule/addingSubmodule.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,154 @@
# How to Add a Video Submodule

Video submodules interact with the Video Module to integrate Prebid with Video Players, allowing Prebid to automatically:
- render bids in the desired video player
- mark used bids as won
- trigger player and media events
- populate the oRTB Video Impression and Content params in the bid request

## Overview

The Prebid Video Module simplifies the way Prebid integrates with video players by acting as a single point of contact for everything video.
In order for the Video Module to connect to a video player, a submodule must be implemented. The submodule acts as a bridge between the Video Module and the video player.
The Video Module will route commands and tasks to the appropriate submodule instance.
A submodule is expected to work for a specific video player. i.e. the JW Player submodule is used to integrate Prebid with JW Player. The video.js submdule connects to video.js.
Publishers who use players from different vendors on the same page can use multiple video submodules.

## Requirements

The Video Module only supports integration with Video Players that meet the following requirements:
- Must support parsing and reproduction of VAST ads
- Input can be an ad tag URL or the actual Vast XML.
- Must expose an API that allows the procurement of [Open RTB params](https://www.iab.com/wp-content/uploads/2016/03/OpenRTB-API-Specification-Version-2-5-FINAL.pdf) for Video (section 3.2.7) and Content (section 3.2.16).
- Must emit javascript events for Ads and Media
- see [Event Registration](#event-registration)

## Creating a Submodule

### Step 1: Add a markdown file describing the submodule

Create a markdown file under `modules` with the name of the module suffixed with 'VideoProvider', i.e. `exampleVideoProvider.md`.

Example markdown file:
```markdown
# Overview

Module Name: Example Video Provider
Module Type: Video Submodule
Video Player: Example player
Player website: example-player.com
Maintainer: [email protected]

# Description

Video provider for Example Player. Contact [email protected] for information.

# Requirements

Your page must link the Example Player build from our CDN. Alternatively yu can use npm to load the build.
```

### Step 2: Add a Vendor Code

Vendor codes are required to indicate which submodule type to instantiate. Add your vendor code constant to an export const in `vendorCodes.js` in Prebid.js under `libraries/video/constants/vendorCodes.js`.
i.e. in `vendorCodes.js`:

```javascript
export const EXAMPLE_PLAYER_VENDOR = 3;
```

### Step 2: Build the Module

Now create a javascript file under `modules` with the name of the module suffixed with 'VideoProvider', e.g., `exampleVideoProvider.js`.

#### The Submodule factory

The Video Module will need a submodule instance for every player instance registered with Prebid. You will therefore need to implement a submodule factory which is called with a `videoProviderConfig` argument and returns a Video Provider instance.
Your submodule should import your vendor code constant and set it to a `vendorCode` property on your submodule factory.
Your submodule should also import the `submodule` function from `src/hook.js` and should use it to register as a submodule of `'video'`.

**Code Example**

```javascript
import { submodule } from '../src/hook.js';

function exampleSubmoduleFactory(videoProviderConfig) {
const videoProvider = {
// implementation
};

return videoProvider;
}

exampleSubmoduleFactory.vendorCode = EXAMPLE_VENDOR;
submodule('video', exampleSubmoduleFactory);
```

#### The Submodule object

The submodule object must adhere to the `VideoProvider` interface defined in the `coreVideo.js` inline documentation.

| param name | type | Scope | Description | Arguments | Return type |
| :---------- | :---- | :---- | :---------- | :-------- | :---------- |
| init | function | required | Initializes the submodule and the video player, if not already instantiated. | n/a | void |
| getId | function | required | Returns the divId (unique identifier) of the associated video player. | n/a | string |
| getOrtbVideo | function | required | Returns the oRTB Video object for the associated video player. See [oRTB spec’s](https://www.iab.com/wp-content/uploads/2016/03/OpenRTB-API-Specification-Version-2-5-FINAL.pdf) video section 3.2.7. | n/a | object |
| getOrtbContent | function | required | Returns the oRTB Content object for the associated video player and its media's metadata. See [oRTB spec’s](https://www.iab.com/wp-content/uploads/2016/03/OpenRTB-API-Specification-Version-2-5-FINAL.pdf) content section 3.2.16. | n/a | object |
| setAdTagUrl | function | required | Requests that the video player load and begin playing the given ad tag url. | adTagUrl: string | void |
| onEvent | function | required | Registers event listeners for the given event strings to the player instance. | externalEventName: string, callback: function, basePayload: object | void |
| offEvent | function | required | Removes event listeners for the given event strings to the player instance. | event: string, callback: function | void |
| destroy | function | required | Deallocates the submodule and destroys the associated video player. n/a | void | void |

For example:
```javascript
const exampleSubmodule = {
init: init,
getId: getId,
getOrtbVideo: getOrtbVideo,
getOrtbContent: getOrtbContent,
setAdTagUrl: setAdTagUrl,
onEvent: onEvent,
offEvent: offEvent,
destroy: destroy
};
```

<a name="event-registration" />

#### Event registration

Submodules must support attaching and detaching event listeners on the video player. The list of events and their respective params are defined in the [Video Module docs's Events section]({{site.github.url}}/prebid-video/video-module.html#events).

##### onEvent

| argument name | type | description |
| ------------- | ---- | ----------- |
| event | string | Name of event for which the listener should be added |
| callback | function | Function that will get called when the event is triggered. The function will be called with a payload argument containing metadata for the event |
| basePayload | object | Base payload for every event; includes common parameters such as divId and type. The event payload should be built on top of this |

##### offEvent

| argument name | type | description |
| ------------- | ---- | ----------- |
| event | string | name of event for which the attached listener should be removed |
| callback | function | function that was assigned as a callback when the listener was added |

#### Update .submodules.json

In prebid.js, add your new submodule to `.submodules.json` under the `videoModule` as such:
{% highlight text %}
```
{
"parentModules": {
"videoModule": [
"exampleVideoProvider"
]
}
}
```

### Shared resources for developers

A video library containing reusable code and constants has been added to Prebid.js for your convenience. We encourage you to import from this library.
Constants such as event names can be found in the `libraries/video/constants/` folder.
5 changes: 5 additions & 0 deletions modules/videoModule/coreVideo.js
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,11 @@ import { ParentModule, SubmoduleBuilder } from '../../libraries/video/shared/par
* @property {Object} vendorConfig - the settings object which can be used as an argument when instantiating a player. Specific to the video player's API.
*/

/**
* @typedef videoEvent
*
*/

/**
* Routes commands to the appropriate video submodule.
* @typedef {Object} VideoCore
Expand Down
17 changes: 17 additions & 0 deletions modules/videojsVideoProvider.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Overview

Module Name: Video.js Video Provider
Module Type: Video Submodule
Video Player: video.js
Player website: https://videojs.com/
Maintainer: Prebid Video Task Force

# Description

Video provider to connect the Prebid Video Module to video.js.

# Requirements

- Your page must include a build of video.js. For instructions see https://videojs.com/getting-started .
- Your video.js instance must include the Google IMA plugin.
- The Google IMA plugin must be accessible publicly in order for the Video.js Video Provider to reference it.

0 comments on commit 6d4aae5

Please sign in to comment.