Skip to content

Latest commit

 

History

History
105 lines (75 loc) · 5.84 KB

README.md

File metadata and controls

105 lines (75 loc) · 5.84 KB

Extending AzuraCast with Plugins

This repository contains documentation for the AzuraCast plugin system, as well as a working example of some of the more common modifications that might be made to the AzuraCast system via plugins.

More information on plugins is available via the AzuraCast Documentation.

Including Plugins

Plugins are automatically discovered if they're located in the /plugins directory relative to the main AzuraCast installation. Plugins are ignored by the parent AzuraCast instance, so you can update your instance any time you like without worrying about your plugins being removed.

Docker Installations

You can clone the plugin directory anywhere you want on the host machine, though it's recommended to have it as a subdirectory of your AzuraCast install directory (like /var/azuracast). To mount the plugin as a volume so Docker recognizes it, you should create a new file named docker-compose.override.yml alongside the existing docker-compose.yml file. If you already have such a file, you can update it to include the extra lines.

services:
  web:
    environment:
      AZURACAST_PLUGIN_MODE: true
    volumes:
      - ./path_to_plugin:/var/azuracast/www/plugins/example-plugin

Make sure to restart the Docker containers afterward (using ./docker.sh restart).

Naming Convention

Autoloaded Files

The following files are automatically loaded along with the relevant section of code:

  • /services.php: Register or extend services with the application's Dependency Injection (DI) container.
  • /events.php: Register listeners for the Event Dispatcher.

Classes

AzuraCast autoloads PHP files inside /plugins/(plugin_name)/src as long as they are in the appropriate namespace.

The function used to convert from the plugin folder name into the PHP class name is:

<?php
return str_replace([' ', '_', '-'], '', ucwords($word, ' _-'));

For example, /plugins/example-plugin/src will autoload classes in the \Plugin\ExamplePlugin namespace.

The Event Dispatcher

Most of the extensibility of plugins comes from events that use the EventDispatcher in AzuraCast. Both classes from inside AzuraCast and plugins are registered as "listeners" to common events that are dispatched by the system, so you can override or modify the core application's responses simply by adding your own listeners in the right order.

See the events.php file included in this sample repository for an example of common events to listen to.

As you can see, each event listener that you register has to provide the event that it listens to as a callable to the addListener method's first parameter, and each event listener receives an instance of that event class complete with relevant metadata already attached. Listeners also have a priority (the last argument in the function call); this number can be positive or negative, with the default handler tending to be around zero. Higher numbers are dispatched before lower numbers.

Below is a listing of the events that can be overridden by plugins:

General Events

Media Events

NGINX Events

Radio Events