Schedule Criteria

Schedule Criteria

Schedule Criteria are a set of metrics set on the media player which influence the active schedule loop. Scheduled events in the CMS can have criteria configured against them, so that the event only becomes active when the criteria on the media player matches.

For example a metric of “PRODUCT_LIFTED” could be set on the media player via API which activated a new scheduled layout in the loop to show information regarding the lifted product.

There are several ways to inform a media player which criteria are currently active:

  • Local Player API (Push criteria into the player)
  • Data Connector (Pull criteria into the player)
  • XMR (Push criteria into the player via the CMS)

Whenever new schedule criteria are set, the Xibo player app will reassess its schedule loop and all events criteria evaluated to build a new schedule loop.

The schedule events created in the CMS describe all possibilities, which are then assessed by the criteria set on each individual player when creating a schedule loop.

Local Player API call

This is suitable if the system setting the criteria is local to the player (i.e. on device) or on the same LAN with a network route to the player.

A POST request can be made to the player web server: POST http://localhost:9696/criteria containing a JSON array of criteria to add/update on the player.

[
  {
    "metric": "metric",
    "value": "value",
    "ttl": 60
  }
]

The metric and value are assessed against any criteria on schedule events for that display.

If you are making a WAN connection (i.e. by IP address or hostname) ensure you have WAN access enabled in Display Settings as by default it is disabled.

Frequency

Players may implement throttling on this function to maintain stability, please do not call it rapidly.

Data Connector

Data Connectors can also set schedule criteria. This is useful when you wish to pull criteria updates from another system.

xiboDC.setCriteria(metric, value, ttl) is used to set criteria, with the following method signature.

/**
 * Set Schedule Criteria
 * @param {string} metric the name of the metric to be set, this will be matched against  the metrics defined on the scheduled events criteria tab
 * @param {string} value the value to set, this can be a string, integer, boolean, etc
 * @param {int} ttl a time to live in seconds, 0 for permanent
 */
xiboDC.setCriteria(metric, value, ttl);

Example:

// Indicate there is a goal and timeout after 30 seconds.
xiboDC.setCriteria('GOAL', true, 30);

XMR

The CMS API has a request to push criteria updates since 4.2. The request is documented in the CMS API documentation.

This is useful if the system responsible for setting criteria has no direct network route to the player, but still wants to push data to the player.

Adding criteria types to the User Interface

The CMS comes with two criteria types; Weather and Custom. When interfacing with another system it may be desirable to give users a pre-defined list of criteria metrics and values to choose from whilst scheduling. This can be achieved using a Connector.

Providing Schedule Criteria via Connector

This guide explains how to provide schedule criteria via a connector. By implementing the ScheduleCriteriaProviderInterface, connectors can supply types, metrics, and values for scheduling conditions. This ensures that the criteria are displayed correctly in the Schedule Criteria Form, allowing users to configure scheduling conditions based on the specified criteria.

Interface for Managing Schedule Criteria Types, Metrics, and Values

Allows the addition of types, metrics, and values in a chained manner:

  • Start with addType() to add a new type. Call addType() multiple times to add multiple types.
  • Follow with addMetric() to add metrics under the specified type. Call addMetric() multiple times to add multiple metrics to the current type.
  • Conclude with addValues() immediately after addMetric() to specify a set of values for the metric. Each metric can have one set of values.
  • You can chain another addMetric() right after addValues() to add another metric.

The added criteria are then parsed and displayed in the Schedule Criteria Form, enabling users to configure scheduling conditions based on the specified types, metrics, and values. The PHP methods below detail the implementation for adding new types, metrics, and values.

/**
 * Add a new type to the criteria.
 *
 * @param string $id Unique identifier for the type.
 * @param string $type Name of the type.
 * @return self
 */
public function addType(string $id, string $type): self;

/**
 * Add a new metric to the current type.
 *
 * @param string $id Unique identifier for the metric.
 * @param string $name Name of the metric.
 * @return self
 * @throws ConfigurationException If the current type is not set.
 */
public function addMetric(string $id, string $name): self;

/**
 * Add values to the current metric. The input type must be either "dropdown", "string", "date", or "number".
 *
 * The values array should be formatted such that the index is the id and the value is the title/name of the value.
 * For "dropdown" input type, provide an array of values. For other input types ("string", "date", "number"),
 * the values array should be empty "[]".
 *
 * Example values for "dropdown":
 * [
 *     'id1' => 'Value 1',
 *     'id2' => 'Value 2'
 * ]
 *
 * @param string $inputType Type of input for the values ("dropdown", "string", "date", "number").
 * @param array $values Array of values to be associated with the metric, where the index is the id and the value is
 * the title.
 * @return self
 * @throws ConfigurationException If the current type or metric is not set.
 */
public function addValues(string $inputType, array $values): self;

Below is a step-by-step implementation guide for providing schedule criteria via a custom connector:

Step 1 - Create Custom Connector

Follow the documentation for creating a custom connector. You can find the detailed guide here.

Be sure to enable it afterward:

  1. Go to Application
  2. Find your custom connector
  3. Click Configure
  4. Check the “Enabled?” checkbox
  5. Click Save

Step 2 - Register Event Listener

Connectors that want to provide schedule criteria must register a listener for the ScheduleCriteriaRequestEvent.

use Xibo\Event\ScheduleCriteriaRequestEvent;

public function registerWithDispatcher(EventDispatcherInterface $dispatcher): ConnectorInterface
{
    $dispatcher->addListener(ScheduleCriteriaRequestEvent::$NAME, [$this, 'onScheduleCriteriaRequest']);
    return $this;
}

Step 3 - Implement Event Handler

Implement the method that will handle the ScheduleCriteriaRequestEvent. This method will add types, metrics, and values

use Xibo\Event\ScheduleCriteriaRequestInterface;

/**
 * @param ScheduleCriteriaRequestInterface $event
 * @return void
 * @throws ConfigurationException
 */
public function onScheduleCriteriaRequest(ScheduleCriteriaRequestInterface $event): void
{
    $event->addType('earthquake', 'Earthquake Alerts')
          ->addMetric('magnitude', 'Magnitude')
            ->addValues('dropdown', ['3.0-3.9' => 'Minor', '4.0-4.9' => 'Light', '5.0-5.9' => 'Moderate', '6.0-6.9' => 'Strong', '7.0+' => 'Major'])
          ->addMetric('location', 'Location')
            ->addValues('text', [])
          ->addMetric('region', 'Region')
            ->addValues('dropdown', ['Pacific Rim' => 'Pacific Rim', 'Ring of Fire' => 'Ring of Fire', 'East Coast' => 'East Coast', 'Midwest' => 'Midwest'])
          ->addMetric('alert_level', 'Alert Level')
            ->addValues('dropdown', ['Advisory' => 'Advisory', 'Watch' => 'Watch', 'Warning' => 'Warning']);
}

Then, it would be added to the form as shown below: