aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private/Log/LogFactory.php
blob: a5a7290bd9ce610249fc22ae2d5347c8f1840019 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?php
/**
 * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */
namespace OC\Log;

use OC\Log;
use OC\SystemConfig;
use OCP\ILogger;
use OCP\IServerContainer;
use OCP\Log\ILogFactory;
use OCP\Log\IWriter;
use Psr\Log\LoggerInterface;

class LogFactory implements ILogFactory {
	public function __construct(
		private IServerContainer $c,
		private SystemConfig $systemConfig,
	) {
	}

	/**
	 * @throws \OCP\AppFramework\QueryException
	 */
	public function get(string $type):IWriter {
		return match (strtolower($type)) {
			'errorlog' => new Errorlog($this->systemConfig),
			'syslog' => $this->c->resolve(Syslog::class),
			'systemd' => $this->c->resolve(Systemdlog::class),
			'file' => $this->buildLogFile(),
			default => $this->buildLogFile(),
		};
	}

	public function getCustomLogger(string $path): ILogger {
		$log = $this->buildLogFile($path);
		return new Log($log, $this->systemConfig);
	}

	protected function createNewLogger(string $type, string $tag, string $path): IWriter {
		return match (strtolower($type)) {
			'errorlog' => new Errorlog($this->systemConfig, $tag),
			'syslog' => new Syslog($this->systemConfig, $tag),
			'systemd' => new Systemdlog($this->systemConfig, $tag),
			default => $this->buildLogFile($path),
		};
	}

	public function getCustomPsrLogger(string $path, string $type = 'file', string $tag = 'Nextcloud'): LoggerInterface {
		$log = $this->createNewLogger($type, $tag, $path);
		return new PsrLoggerAdapter(
			new Log($log, $this->systemConfig)
		);
	}

	protected function buildLogFile(string $logFile = ''): File {
		$defaultLogFile = $this->systemConfig->getValue('datadirectory', \OC::$SERVERROOT.'/data').'/nextcloud.log';
		if ($logFile === '') {
			$logFile = $this->systemConfig->getValue('logfile', $defaultLogFile);
		}
		$fallback = $defaultLogFile !== $logFile ? $defaultLogFile : '';

		return new File($logFile, $fallback, $this->systemConfig);
	}
}