// SPDX-License-Identifier: GPL-3.0-or-later namespace Icinga\Module\Icingadb\Model; use DateTime; use Icinga\Module\Icingadb\Model\Behavior\ReRoute; use ipl\Orm\Behavior\Binary; use ipl\Orm\Behavior\MillisecondTimestamp; use ipl\Orm\Behaviors; use Icinga\Module\Icingadb\Common\Model; use ipl\Orm\Relations; /** * Model for table `notification_history` * * Please note that using this model will fetch history entries for decommissioned services. To avoid this, the * query needs a `notification_history.service_id IS NULL OR notification_history_service.id IS NOT NULL` where. * * @property string $id * @property string $environment_id * @property ?string $endpoint_id * @property string $object_type * @property string $host_id * @property ?string $service_id * @property string $notification_id * @property string $type * @property DateTime $send_time * @property int $state * @property int $previous_hard_state * @property string $author * @property string $text * @property int $users_notified */ class NotificationHistory extends Model { public function getTableName() { return 'notification_history'; } public function getKeyName() { return 'id'; } public function getColumns() { return [ 'environment_id', 'endpoint_id', 'object_type', 'host_id', 'service_id', 'notification_id', 'type', 'send_time', 'state', 'previous_hard_state', 'author', 'text', 'users_notified' ]; } public function getColumnDefinitions() { return [ 'id' => t('History Id'), 'environment_id' => t('Environment Id'), 'endpoint_id' => t('Endpoint Id'), 'object_type' => t('Object Type'), 'host_id' => t('Host Id'), 'service_id' => t('Service Id'), 'notification_id' => t('Notification Id'), 'type' => t('Notification Type'), 'send_time' => t('Notification Sent On'), 'state' => t('Hard State'), 'previous_hard_state' => t('Previous Hard State'), 'author' => t('Notification Author'), 'text' => t('Notification Text'), 'users_notified' => t('Contacts Notified') ]; } public function getSearchColumns() { return ['text']; } public function getDefaultSort() { return 'notification_history.send_time desc'; } public function createBehaviors(Behaviors $behaviors) { $behaviors->add(new MillisecondTimestamp([ 'send_time' ])); $behaviors->add(new Binary([ 'id', 'environment_id', 'endpoint_id', 'host_id', 'service_id', 'notification_id' ])); $behaviors->add(new ReRoute([ 'hostgroup' => 'host.hostgroup', 'servicegroup' => 'service.servicegroup' ])); } public function createRelations(Relations $relations) { $relations->belongsTo('environment', Environment::class); $relations->belongsTo('history', History::class) ->setCandidateKey('id') ->setForeignKey('notification_history_id'); $relations->belongsTo('host', Host::class); $relations->belongsTo('service', Service::class)->setJoinType('LEFT'); $relations->belongsTo('notification', Notification::class)->setJoinType('LEFT'); $relations->belongsToMany('user', User::class) ->through('user_notification_history'); } }