2015-07-21 15:17:20 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Icinga\Module\Director\Web\Hook;
|
|
|
|
|
|
|
|
use Icinga\Module\Director\Web\Form\QuickForm;
|
|
|
|
use Icinga\Module\Director\Db;
|
2015-12-02 04:00:31 +01:00
|
|
|
use Icinga\Exception\ConfigurationError;
|
2015-07-21 15:17:20 +02:00
|
|
|
|
|
|
|
abstract class ImportSourceHook
|
|
|
|
{
|
|
|
|
protected $settings = array();
|
|
|
|
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
$parts = explode('\\', get_class($this));
|
|
|
|
$class = preg_replace('/ImportSource/', '', array_pop($parts));
|
|
|
|
|
|
|
|
if (array_shift($parts) === 'Icinga' && array_shift($parts) === 'Module') {
|
|
|
|
$module = array_shift($parts);
|
|
|
|
if ($module !== 'Director') {
|
2015-11-14 00:22:50 +01:00
|
|
|
if ($class === '') {
|
|
|
|
return sprintf('%s module', $module);
|
|
|
|
}
|
2015-07-21 15:17:20 +02:00
|
|
|
return sprintf('%s (%s)', $class, $module);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $class;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function loadByName($name, $db)
|
|
|
|
{
|
|
|
|
$db = $db->getDbAdapter();
|
|
|
|
$source = $db->fetchRow(
|
|
|
|
$db->select()->from(
|
|
|
|
'import_source',
|
|
|
|
array('id', 'provider_class')
|
|
|
|
)->where('source_name = ?', $name)
|
|
|
|
);
|
|
|
|
|
|
|
|
$settings = $db->fetchPairs(
|
|
|
|
$db->select()->from(
|
|
|
|
'import_source_setting',
|
|
|
|
array('setting_name', 'setting_value')
|
|
|
|
)->where('source_id = ?', $source->id)
|
|
|
|
);
|
|
|
|
|
2015-12-02 04:00:31 +01:00
|
|
|
if (! class_exists($source->provider_class)) {
|
|
|
|
throw new ConfigurationError(
|
|
|
|
'Cannot load import provider class %s',
|
|
|
|
$source->provider_class
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-07-21 15:17:20 +02:00
|
|
|
$obj = new $source->provider_class;
|
|
|
|
$obj->setSettings($settings);
|
|
|
|
|
|
|
|
return $obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setSettings($settings)
|
|
|
|
{
|
|
|
|
$this->settings = $settings;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-12-03 00:39:46 +01:00
|
|
|
public function getSetting($name, $default = null) {
|
|
|
|
if (array_key_exists($name, $this->settings)) {
|
|
|
|
return $this->settings[$name];
|
|
|
|
} else {
|
|
|
|
return $default;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-07-21 15:17:20 +02:00
|
|
|
/**
|
|
|
|
* 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();
|
|
|
|
|
2015-11-30 13:06:34 +01:00
|
|
|
/**
|
|
|
|
* Override this method in case you want to suggest a default
|
|
|
|
* key column
|
|
|
|
*
|
|
|
|
* @return string|null Default key column
|
|
|
|
*/
|
|
|
|
public static function getDefaultKeyColumnName()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2015-07-21 15:17:20 +02:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
}
|
|
|
|
}
|