2014-10-02 23:16:57 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
2014-10-03 18:39:09 +00:00
|
|
|
namespace OC\Diagnostics;
|
2014-10-02 23:16:57 +00:00
|
|
|
|
2014-10-03 18:39:09 +00:00
|
|
|
use OCP\Diagnostics\IEventLogger;
|
2014-10-02 23:16:57 +00:00
|
|
|
|
|
|
|
class EventLogger implements IEventLogger {
|
|
|
|
/**
|
2014-10-03 18:39:09 +00:00
|
|
|
* @var \OC\Diagnostics\Event[]
|
2014-10-02 23:16:57 +00:00
|
|
|
*/
|
|
|
|
private $events = array();
|
|
|
|
|
|
|
|
public function start($id, $description) {
|
|
|
|
$this->events[$id] = new Event($id, $description, microtime(true));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function end($id) {
|
|
|
|
if (isset($this->events[$id])) {
|
|
|
|
$timing = $this->events[$id];
|
|
|
|
$timing->end(microtime(true));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-15 11:14:13 +00:00
|
|
|
public function log($id, $description, $start, $end) {
|
|
|
|
$this->events[$id] = new Event($id, $description, $start);
|
|
|
|
$this->events[$id]->end($end);
|
|
|
|
}
|
|
|
|
|
2014-10-02 23:16:57 +00:00
|
|
|
/**
|
2014-10-03 18:39:09 +00:00
|
|
|
* @return \OCP\Diagnostics\IEvent[]
|
2014-10-02 23:16:57 +00:00
|
|
|
*/
|
|
|
|
public function getEvents() {
|
|
|
|
return $this->events;
|
|
|
|
}
|
|
|
|
}
|