To build your own plugin for the Kaltura Player, you’ll need to go through a few simple steps:

  • Import the player library.
  • Write your plugin logic and implement the plugin API methods and properties.
  • Register the plugin in the player framework.

In this guide we’ll go through these steps and elaborate with examples of both Plain JavaScript & ES6.

The player core library exposes two main utilities:

  • BasePlugin - The class that your plugin will inherit from.
  • registerPlugin - The static player method that will register your plugin in the player registry.

Lets take a look at the BasePlugin API.

Base Plugin API

constructor(name, player, config)

Parameters

Name Type Description
name string Plugin name
player playkit.core.Player Player instance
config Object Plugin config

#

Properties

config

Type: Object - The runtime plugin config.

player

Type: playkit.core.Player - The player instance.

name

Type: string - The plugin registry name.

logger

Type: playkit.core.Logger - The logger of the plugin.

eventManager

Type: playkit.core.EventManager - The plugin event manager.

#

Properties to Implement

(static) defaultConfig

Type: Object - The default plugin config.

#

Methods

getConfig(attr)

Parameters

Name Type Description
attr string config key (optional)

Returns: any - If an attribute is provided, returns the value of the config attribute. If not, returns the plugin config.

updateConfig(update)

Parameters

Name Type Description
update Object New full or partial config

Returns: void - Merges the update config with the existing config.

getName()

Returns: string - The plugin name.

dispatchEvent(name, payload)

Parameters

Name Type Description
name string The event name
payload Object The event payload object

Returns: void - Dispatches an event from the player.

#

Methods to Implement

(static) isValid(player)

Parameters

Name Type Description
player playkit.core.Player Player instance

Returns: boolean - Whether the plugin is valid or not.

You can help the player instance API with your decision logic. For example, if you want to enable your plugin on a Chrome browser only, you can simply implement the following:

// Plain JavaScript
MyPlugin.isValid = function() {
  return player.env.browser.name === 'Chrome';
};
// ES6
class MyPlugin extends BasePlugin {
  static isValid(player) {
    return player.env.browser.name === 'Chrome';
  }
}

destroy()

Returns: void - Runs the plugin destroy logic.

The player will call this method before destroying itself.

reset()

Returns: void - Runs the plugin reset logic.

The player will call this method before changing media.

#

Now, lets take a look at the registerPlugin API.

Register Plugin API

registerPlugin(pluginName, pluginClass)

Parameters

Name Type Description
pluginName string The plugin name
pluginClass playkit.core.BasePlugin The plugin class

Writing a Basic Plugin

In this section, we’ll learn how to write a simple plugin, one that doesn’t require any installation or setup steps except for a player script in hand (remotely or locally).

We’ll use both Vanilla JavaScript & ES6 examples.

Note: If you’re using ES6 already, you can use that syntax with your transpiler/language of choice (Babel, TypeScript, Flow, etc).

Step 1: Import the Player Library

1 . In your index.html file, include a path to the player script:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>MyPlugin</title>
    <script src="PATH/TO/PLAYER/LIB/FILENAME.js"></script>
</head>
</html>

2 . Create a new file called my-plugin.js and include it in your index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>MyPlugin</title>
    <script src="PATH/TO/PLAYER/LIB/FILENAME.js"></script>
    <script src="PATH/TO/FILE/my-plugin.js"></script>
</head>
<body>
</body>
</html>

Step 2: Create Your Plugin Class

1 . In my-plugin.js, define the plugin class:

Plain JavaScript

var MyPlugin = function(name, player, config) {};

ES6

class MyPlugin {
  constructor(name, player, config) {}
}

2 . Next, and add the code that will inherit from BasePlugin:

Plain JavaScript

var MyPlugin = function(name, player, config) {
  KalturaPlayer.core.BasePlugin.call(this, name, player, config);
};

MyPlugin.createPlugin = KalturaPlayer.core.BasePlugin.createPlugin;

MyPlugin.prototype = new KalturaPlayer.core.BasePlugin();

ES6

class MyPlugin extends KalturaPlayer.core.BasePlugin {
  constructor(name, player, config) {
    super(name, player, config);
  }
}

Step 3: Override the BasePlugin Methods

In my-plugin.js, add the necessary methods and properties to override as explained above:

Plain JavaScript

var MyPlugin = function(name, player, config) {
  KalturaPlayer.core.BasePlugin.call(this, name, player, config);
};

MyPlugin.createPlugin = KalturaPlayer.core.BasePlugin.createPlugin;

MyPlugin.prototype = new KalturaPlayer.core.BasePlugin();

MyPlugin.defaultConfig = {};

MyPlugin.isValid = function(player) {};

MyPlugin.prototype.destroy = function() {};

MyPlugin.prototype.reset = function() {};

ES6

class MyPlugin extends KalturaPlayer.core.BasePlugin {
  static defaultConfig = {};

  static isValid(player) {}

  constructor(name, player, config) {
    super(name, player, config);
  }

  destroy() {}

  reset() {}
}

Step 4: Fill in Simple Implementations

To see the plugin in action, lets fill in some simple implementations:

Plain JavaScript

var MyPlugin = function(name, player, config) {
  KalturaPlayer.core.BasePlugin.call(this, name, player, config);
  this.logger.debug('Hello from ' + this.getName() + ' plugin constructor!');
  this._myCollection = [this.config.myValue];
  this._addBindings();
};

MyPlugin.createPlugin = KalturaPlayer.core.BasePlugin.createPlugin;

MyPlugin.prototype = new KalturaPlayer.core.BasePlugin();

MyPlugin.defaultConfig = {
  myValue: 1
};

MyPlugin.isValid = function(player) {
  return true;
};

MyPlugin.prototype.destroy = function() {
  this.logger.debug('Empty collection');
  this._myCollection = [];
};

MyPlugin.prototype.reset = function() {
  this.logger.debug('Reset collection');
  this._myCollection = [this.config.myValue];
};

MyPlugin.prototype._addBindings = function() {
  this.eventManager.listen(
    this.player,
    this.player.Event.SEEKED,
    function() {
      this.logger.debug(this.player.currentTime + ' Added to my collection');
      this._myCollection.push(this.player.currentTime);
      this.dispatchEvent('collectionUpdate', {collection: this._myCollection});
    }.bind(this)
  );
};

ES6

class MyPlugin extends KalturaPlayer.core.BasePlugin {
  _myCollection;

  static defaultConfig = {
    myValue: 1
  };

  static isValid(player): boolean {
    return true;
  }

  constructor(name, player, config) {
    super(name, player, config);
    this.logger.debug('Hello from ' + this.getName() + ' plugin constructor!');
    this._myCollection = [this.config.myValue];
    this._addBindings();
  }

  destroy() {
    this.logger.debug('Empty collection');
    this._myCollection = [];
  }

  reset() {
    this.logger.debug('Reset collection');
    this._myCollection = [this.config.myValue];
  }

  _addBindings() {
    this.eventManager.listen(this.player, this.player.Event.SEEKED, () => {
      this.logger.debug(this.player.currentTime + ' Added to my collection');
      this._myCollection.push(this.player.currentTime);
      this.dispatchEvent('collectionUpdate', {collection: this._myCollection});
    });
  }
}

Step 5: Register Your Plugin

Use the factory registerPlugin method to register your plugin in the player framework:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>MyPlugin</title>
    <script src="PATH/TO/PLAYER/LIB/FILENAME.js"></script>
    <script src="PATH/TO/FILE/my-plugin.js"></script>
</head>
<body>
<script>
	KalturaPlayer.core.registerPlugin("myPlugin", MyPlugin);
</script>
</body>
</html>

Step 6: Configure Your Plugin

All that’s left now is to verify that the player activates the plugin during runtime.

Include the new plugin name and plugin configuration in the player configuration. For example:

var config = {
  plugins: {
    myPlugin: {
      myValue: 10
    }
  }
};

Let’s expand our test page and add a placeholder div to the player:

<div id="player-div" style="width: 360px; height: 640px;"></div>

A basic player configuration:

var config = {
  log: {
    level: 'DEBUG'
  },
  targetId: 'player-div',
  provider: {
    partnerId: 'YOUR_PARTNER_ID'
  },
  plugins: {
    myPlugin: {
      myValue: 10
    }
  }
};

And setup code:

var mediaInfo = {entryId: 'YOUR_ENTRY_ID'};
var player = KalturaPlayer.setup(config);
player.loadMedia(mediaInfo).then(function() {
  player.play();
});

Plug everything together and you’ll get:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>MyPlugin</title>
    <script src="PATH/TO/PLAYER/LIB/FILENAME.js"></script>
    <script src="PATH/TO/FILE/my-plugin.js"></script>
</head>
<body>
<script>
KalturaPlayer.core.registerPlugin("myPlugin", MyPlugin);

var config = {
    log:{
      level: 'DEBUG'
    },
    targetId: "player-div",
    provider: {
        partnerId: "YOUR_PARTNER_ID"
    },
    plugins: {
        myPlugin: {
            myValue: 10
        }
    }
};

var mediaInfo = {entryId: "YOUR_ENTRY_ID"};
var player = KalturaPlayer.setup(config);
player.loadMedia(mediaInfo).then(function() {
  player.play();
});
</script>
</body>
</html>

That’s it! the player starts to play and your plugin is activated.

Writing an Advanced Plugin

An advanced plugin is one that is built as a self project and handles a version, tests, documentation, dev scripts and so on.
All of the options described above can be achieved by using the PlayKit JS Plugin Generator tool.

Read here to learn more.