icingaweb2-module-director/library/Director/Web/Hook/PropertyModifierHook.php

89 lines
2.1 KiB
PHP

<?php
namespace Icinga\Module\Director\Web\Hook;
use Icinga\Module\Director\Web\Form\QuickForm;
use Icinga\Module\Director\Db;
abstract class PropertyModifierHook
{
protected $settings = array();
public function getName()
{
$parts = explode('\\', get_class($this));
$class = preg_replace('/ImportRowModifier/', '', array_pop($parts)); // right?
if (array_shift($parts) === 'Icinga' && array_shift($parts) === 'Module') {
$module = array_shift($parts);
if ($module !== 'Director') {
return sprintf('%s (%s)', $class, $module);
}
}
return $class;
}
public static function loadById($property_id, Db $db)
{
$db = $db->getDbAdapter();
$modifier = $db->fetchRow(
$db->select()->from(
'import_row_modifier',
array('id', 'provider_class')
)->where('property_id = ?', $property_id)
);
$settings = $db->fetchPairs(
$db->select()->from(
'import_row_modifier_settings',
array('setting_name', 'setting_value')
)->where('modifier_id = ?', $modifier->id)
);
$obj = new $modifier->provider_class;
$obj->setSettings($settings);
return $obj;
}
public function setSettings($settings)
{
$this->settings = $settings;
return $this;
}
/**
* Returns an array containing importable objects
*
* @return array
*/
abstract public function fetchData();
/**
* Returns a list of all available columns
*
* @return array
*/
abstract public function listColumns();
/**
* Methode to transform the given value
*
* @return value
*/
abstract public function transform($value);
/**
* Override this method if you want to extend the settings form
*
* @param QuickForm $form QuickForm that should be extended
* @return QuickForm
*/
public static function addSettingsFormFields(QuickForm $form)
{
return $form;
}
}