icingadb-web/library/Icingadb/Model/Service.php
2019-11-06 15:35:14 +01:00

115 lines
3.5 KiB
PHP

<?php
namespace Icinga\Module\Icingadb\Model;
use Icinga\Module\Icingadb\Model\Behavior\BoolCast;
use ipl\Orm\Behaviors;
use ipl\Orm\Model;
use ipl\Orm\Relations;
class Service extends Model
{
public function getTableName()
{
return 'service';
}
public function getKeyName()
{
return 'id';
}
public function getColumns()
{
return [
'environment_id',
'name_checksum',
'properties_checksum',
'customvars_checksum',
'groups_checksum',
'host_id',
'name',
'name_ci',
'display_name',
'checkcommand',
'checkcommand_id',
'max_check_attempts',
'check_timeperiod',
'check_timeperiod_id',
'check_timeout',
'check_interval',
'check_retry_interval',
'active_checks_enabled',
'passive_checks_enabled',
'event_handler_enabled',
'notifications_enabled',
'flapping_enabled',
'flapping_threshold_low',
'flapping_threshold_high',
'perfdata_enabled',
'eventcommand',
'eventcommand_id',
'is_volatile',
'action_url_id',
'notes_url_id',
'notes',
'icon_image_id',
'icon_image_alt',
'zone',
'zone_id',
'command_endpoint',
'command_endpoint_id'
];
}
public function getSearchColumns()
{
return ['name_ci'];
}
public function getSortRules()
{
return ['display_name'];
}
public function createBehaviors(Behaviors $behaviors)
{
$behaviors->add(new BoolCast([
'active_checks_enabled',
'passive_checks_enabled',
'event_handler_enabled',
'notifications_enabled',
'flapping_enabled'
]));
}
public function createRelations(Relations $relations)
{
$relations->belongsTo('environment', Environment::class);
$relations->belongsTo('host', Host::class)->setJoinType('LEFT');
$relations->belongsTo('checkcommand', Checkcommand::class);
$relations->belongsTo('timeperiod', Timeperiod::class)
->setCandidateKey('check_timeperiod_id');
$relations->belongsTo('eventcommand', Eventcommand::class);
$relations->belongsTo('action_url', ActionUrl::class);
$relations->belongsTo('notes_url', NotesUrl::class);
$relations->belongsTo('icon_image', IconImage::class);
$relations->belongsTo('zone', Zone::class);
$relations->belongsTo('endpoint', Endpoint::class)
->setCandidateKey('command_endpoint_id');
$relations->belongsToMany('customvar', Customvar::class)
->setThrough(ServiceCustomvar::class);
$relations->belongsToMany('vars', CustomvarFlat::class)
->setThrough(ServiceCustomvar::class);
$relations->belongsToMany('servicegroup', Servicegroup::class)
->setThrough(ServicegroupMember::class);
$relations->belongsToMany('hostgroup', Hostgroup::class)
->setThrough(HostgroupMember::class);
$relations->hasOne('state', ServiceState::class)->setJoinType('LEFT');
$relations->hasMany('comment', Comment::class);
$relations->hasMany('downtime', Downtime::class);
$relations->hasMany('notification', Notification::class);
}
}