summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJoas Schilling <nickvergessen@owncloud.com>2015-06-23 17:07:28 +0200
committerJoas Schilling <nickvergessen@owncloud.com>2015-06-24 09:26:30 +0200
commitdba5d5e2057ae51ef73644bf1feeb16e60a99afa (patch)
tree08cbb6ddf0df7f3ae073c52e8c9bc273009c3647 /lib
parentd8b9f6ac2338e25d9560174ae4be98b6adf19819 (diff)
downloadnextcloud-server-dba5d5e2057ae51ef73644bf1feeb16e60a99afa.tar.gz
nextcloud-server-dba5d5e2057ae51ef73644bf1feeb16e60a99afa.zip
Use a OutputFormatter instead of hacking into writeln()
Diffstat (limited to 'lib')
-rw-r--r--lib/private/console/timestampformatter.php107
1 files changed, 107 insertions, 0 deletions
diff --git a/lib/private/console/timestampformatter.php b/lib/private/console/timestampformatter.php
new file mode 100644
index 00000000000..f0c0f4c4520
--- /dev/null
+++ b/lib/private/console/timestampformatter.php
@@ -0,0 +1,107 @@
+<?php
+/**
+ * @author Joas Schilling <nickvergessen@owncloud.com>
+ *
+ * @copyright Copyright (c) 2015, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+namespace OC\Console;
+
+
+use OCP\IConfig;
+use Symfony\Component\Console\Formatter\OutputFormatterInterface;
+use Symfony\Component\Console\Formatter\OutputFormatterStyleInterface;
+
+class TimestampFormatter implements OutputFormatterInterface {
+ /** @var IConfig */
+ protected $config;
+
+ /**
+ * @param IConfig $config
+ * @param OutputFormatterInterface $formatter
+ */
+ public function __construct(IConfig $config, OutputFormatterInterface $formatter) {
+ $this->config = $config;
+ $this->formatter = $formatter;
+ }
+
+ /**
+ * Sets the decorated flag.
+ *
+ * @param bool $decorated Whether to decorate the messages or not
+ */
+ public function setDecorated($decorated) {
+ $this->formatter->setDecorated($decorated);
+ }
+
+ /**
+ * Gets the decorated flag.
+ *
+ * @return bool true if the output will decorate messages, false otherwise
+ */
+ public function isDecorated() {
+ return $this->formatter->isDecorated();
+ }
+
+ /**
+ * Sets a new style.
+ *
+ * @param string $name The style name
+ * @param OutputFormatterStyleInterface $style The style instance
+ */
+ public function setStyle($name, OutputFormatterStyleInterface $style) {
+ $this->formatter->setStyle($name, $style);
+ }
+
+ /**
+ * Checks if output formatter has style with specified name.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasStyle($name) {
+ $this->formatter->hasStyle($name);
+ }
+
+ /**
+ * Gets style options from style with specified name.
+ *
+ * @param string $name
+ * @return OutputFormatterStyleInterface
+ */
+ public function getStyle($name) {
+ return $this->formatter->getStyle($name);
+ }
+
+ /**
+ * Formats a message according to the given styles.
+ *
+ * @param string $message The message to style
+ * @return string The styled message, prepended with a timestamp using the
+ * log timezone and dateformat, e.g. "2015-06-23T17:24:37+02:00"
+ */
+ public function format($message) {
+
+ $timeZone = $this->config->getSystemValue('logtimezone', null);
+ $timeZone = $timeZone !== null ? new \DateTimeZone($timeZone) : null;
+
+ $time = new \DateTime('now', $timeZone);
+ $timestampInfo = $time->format($this->config->getSystemValue('logdateformat', 'c'));
+
+ return $timestampInfo . ' ' . $this->formatter->format($message);
+ }
+}