icingaweb2/modules/monitoring/library/Monitoring/Timeline/TimeEntry.php

234 lines
4.4 KiB
PHP
Raw Normal View History

2013-10-22 17:02:30 +02:00
<?php
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
2013-10-22 17:02:30 +02:00
namespace Icinga\Module\Monitoring\Timeline;
2013-10-22 17:02:30 +02:00
use DateTime;
use Icinga\Web\Url;
use Icinga\Exception\ProgrammingError;
2013-10-22 17:02:30 +02:00
/**
* An event group that is part of a timeline
*/
class TimeEntry
{
/**
* The name of this group
*
* @var string
*/
protected $name;
2013-10-22 17:02:30 +02:00
/**
* The amount of events that are part of this group
*
* @var int
*/
protected $value;
2013-10-22 17:02:30 +02:00
/**
* The date and time of this group
*
* @var DateTime
*/
protected $dateTime;
2013-10-22 17:02:30 +02:00
/**
* The url to this group's detail view
*
* @var Url
2013-10-22 17:02:30 +02:00
*/
protected $detailUrl;
2013-10-22 17:02:30 +02:00
/**
* The weight of this group
*
* @var float
*/
protected $weight = 1.0;
/**
* The label of this group
*
* @var string
*/
protected $label;
2013-10-22 17:02:30 +02:00
/**
* The CSS class of the entry
2013-10-22 17:02:30 +02:00
*
* @var string
2013-10-22 17:02:30 +02:00
*/
protected $class;
/**
* Return a new TimeEntry object with the given attributes being set
*
* @param array $attributes The attributes to set
* @return TimeEntry The resulting TimeEntry object
* @throws ProgrammingError If one of the given attributes cannot be set
*/
public static function fromArray(array $attributes)
{
$entry = new TimeEntry();
foreach ($attributes as $name => $value) {
$methodName = 'set' . ucfirst($name);
if (method_exists($entry, $methodName)) {
$entry->{$methodName}($value);
} else {
throw new ProgrammingError(
'Method "%s" does not exist on object of type "%s"',
$methodName,
__CLASS__
);
}
}
return $entry;
}
/**
* Set this group's name
*
* @param string $name The name to set
*/
public function setName($name)
2013-10-22 17:02:30 +02:00
{
$this->name = $name;
}
/**
* Return the name of this group
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Set this group's amount of events
*
* @param int $value The value to set
*/
public function setValue($value)
{
$this->value = intval($value);
}
2013-10-22 17:02:30 +02:00
/**
* Return the amount of events in this group
*
* @return int
*/
public function getValue()
2013-10-22 17:02:30 +02:00
{
return $this->value;
2013-10-22 17:02:30 +02:00
}
/**
* Set this group's date and time
*
* @param DateTime $dateTime The date and time to set
*/
public function setDateTime(DateTime $dateTime)
{
$this->dateTime = $dateTime;
}
2013-10-22 17:02:30 +02:00
/**
* Return the date and time of this group
*
* @return DateTime
*/
public function getDateTime()
{
return $this->dateTime;
}
/**
* Set the url to this group's detail view
*
* @param Url $detailUrl The url to set
*/
public function setDetailUrl(Url $detailUrl)
{
$this->detailUrl = $detailUrl;
}
2013-10-22 17:02:30 +02:00
/**
* Return the url to this group's detail view
*
* @return Url
2013-10-22 17:02:30 +02:00
*/
public function getDetailUrl()
{
return $this->detailUrl;
}
/**
* Set this group's weight
*
* @param float $weight The weight for this group
*/
public function setWeight($weight)
{
$this->weight = floatval($weight);
}
2013-10-22 17:02:30 +02:00
/**
* Return the weight of this group
*
* @return float
*/
public function getWeight()
{
return $this->weight;
}
/**
* Set this group's label
*
* @param string $label The label to set
*/
public function setLabel($label)
{
$this->label = $label;
}
/**
* Return the label of this group
*
* @return string
*/
public function getLabel()
{
return $this->label;
}
2013-10-22 17:02:30 +02:00
/**
* Get the CSS class
2013-10-22 17:02:30 +02:00
*
* @return string
2013-10-22 17:02:30 +02:00
*/
public function getClass()
2013-10-22 17:02:30 +02:00
{
return $this->class;
}
/**
* Set the CSS class
*
* @param string $class
*
* @return $this
*/
public function setClass($class)
{
$this->class = $class;
return $this;
2013-10-22 17:02:30 +02:00
}
}