ImportRowModifier: simplify code

This commit is contained in:
Thomas Gelf 2016-02-17 22:02:28 +01:00
parent 625b9373de
commit f6a3c6cf34
2 changed files with 9 additions and 253 deletions

View File

@ -2,9 +2,9 @@
namespace Icinga\Module\Director\Objects;
use Icinga\Module\Director\Data\Db\DbObject;
use Icinga\Module\Director\Data\Db\DbObjectWithSettings;
class ImportRowModifier extends DbObject
class ImportRowModifier extends DbObjectWithSettings
{
protected $table = 'import_row_modifier';
@ -13,123 +13,14 @@ class ImportRowModifier extends DbObject
protected $autoincKeyName = 'id';
protected $defaultProperties = array(
'id' => null,
'property_id' => null,
'provider_class' => null
'id' => null,
'source_id' => null,
'property_name' => null,
'provider_class' => null,
'priority' => null,
);
/*
protected $properties = array();
protected $settingsTable = 'import_row_modifier_setting';
public function set($key, $value)
{
if ($this->hasProperty($key)) {
return parent::set($key, $value);
}
if (! array_key_exists($key, $this->propterties) || $value !== $this->propterties[$key]) {
$this->hasBeenModified = true;
}
$this->properties[$key] = $value;
return $this;
}
public function get($key)
{
if ($this->hasProperty($key)) {
return parent::get($key);
}
if (array_key_exists($key, $this->properties)) {
return $this->properties[$key];
}
return parent::get($key);
}
public function getProperties()
{
return $this->properties;
}
protected function onStore()
{
$old = $this->fetchSettingsFromDb();
$oldKeys = array_keys($old);
$newKeys = array_keys($this->properties);
$add = array();
$mod = array();
$del = array();
foreach ($this->properties as $key => $val) {
if (array_key_exists($key, $old)) {
if ($old[$key] !== $this->properties[$key]) {
$mod[$key] = $this->properties[$key];
}
} else {
$add[$key] = $this->properties[$key];
}
}
foreach (array_diff(array_keys($old), array_keys($this->settings)) as $key) {
$del[$key] = $key;
}
$modifier = $db->fetchRow(
$db->select()->from(
'sync_modifier',
array('id')
)->where('property_id = ?', $property_id)
)
$where = sprintf('modifier_id = %d AND param_key = ?', $modifier->id);
$db = $this->getDb();
foreach ($mod as $key => $val) {
$db->update(
'sync_modifier_param',
array('param_value' => $val),
$db->quoteInto($where, $key)
);
}
foreach ($add as $key => $val) {
$db->insert(
'sync_modifier',
array(
'property_id' => $this->id,
'
)
$db->insert(
'sync_modifier_param',
array(
'source_id' => $this->id,
'setting_name' => $key,
'setting_value' => $val
)
);
}
foreach ($del as $key) {
$db->update(
'import_source_setting',
$db->quoteInto($where, $key)
);
}
}
protected function fetchSettingsFromDb()
{
$db = $this->getDb();
return $db->fetchPairs(
$db->select()
->from('sync_modifier_param', array('param_name', 'param_value'))
->where('modifier_id = ?', $this->id)
);
}
protected function onLoadFromDb()
{
$this->settings = $this->fetchSettingsFromDb();
} */
protected $settingsRemoteId = 'row_modifier_id';
}

View File

@ -1,135 +0,0 @@
<?php
namespace Icinga\Module\Director\Objects;
use Icinga\Module\Director\Data\Db\DbObject;
class ImportRowModifierSettings extends DbObject
{
protected $table = 'import_row_modifier_setting';
protected $keyName = 'id';
protected $autoincKeyName = 'id';
protected $defaultProperties = array(
'modifier_id' => null,
'setting_name' => null,
'setting_value' => null,
);
/*
protected $properties = array();
public function set($key, $value)
{
if ($this->hasProperty($key)) {
return parent::set($key, $value);
}
if (! array_key_exists($key, $this->propterties) || $value !== $this->propterties[$key]) {
$this->hasBeenModified = true;
}
$this->properties[$key] = $value;
return $this;
}
public function get($key)
{
if ($this->hasProperty($key)) {
return parent::get($key);
}
if (array_key_exists($key, $this->properties)) {
return $this->properties[$key];
}
return parent::get($key);
}
public function getProperties()
{
return $this->properties;
}
protected function onStore()
{
$old = $this->fetchSettingsFromDb();
$oldKeys = array_keys($old);
$newKeys = array_keys($this->properties);
$add = array();
$mod = array();
$del = array();
foreach ($this->properties as $key => $val) {
if (array_key_exists($key, $old)) {
if ($old[$key] !== $this->properties[$key]) {
$mod[$key] = $this->properties[$key];
}
} else {
$add[$key] = $this->properties[$key];
}
}
foreach (array_diff(array_keys($old), array_keys($this->settings)) as $key) {
$del[$key] = $key;
}
$modifier = $db->fetchRow(
$db->select()->from(
'sync_modifier',
array('id')
)->where('property_id = ?', $property_id)
)
$where = sprintf('modifier_id = %d AND param_key = ?', $modifier->id);
$db = $this->getDb();
foreach ($mod as $key => $val) {
$db->update(
'sync_modifier_param',
array('param_value' => $val),
$db->quoteInto($where, $key)
);
}
foreach ($add as $key => $val) {
$db->insert(
'sync_modifier',
array(
'property_id' => $this->id,
'
)
$db->insert(
'sync_modifier_param',
array(
'source_id' => $this->id,
'setting_name' => $key,
'setting_value' => $val
)
);
}
foreach ($del as $key) {
$db->update(
'import_source_setting',
$db->quoteInto($where, $key)
);
}
}
protected function fetchSettingsFromDb()
{
$db = $this->getDb();
return $db->fetchPairs(
$db->select()
->from('sync_modifier_param', array('param_name', 'param_value'))
->where('modifier_id = ?', $this->id)
);
}
protected function onLoadFromDb()
{
$this->settings = $this->fetchSettingsFromDb();
} */
}