/* * Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET) * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ using System; using System.Collections.Generic; using SafeExamBrowser.Logging.Contracts; namespace SafeExamBrowser.Logging { public class ModuleLogger : IModuleLogger { private ILogger logger; private string moduleInfo; public LogLevel LogLevel { get { return logger.LogLevel; } set { logger.LogLevel = value; } } public ModuleLogger(ILogger logger, string moduleInfo) { this.logger = logger; this.moduleInfo = moduleInfo; } public IModuleLogger CloneFor(string moduleInfo) { return new ModuleLogger(logger, moduleInfo); } public void Debug(string message) { logger.Debug(AppendModuleInfo(message)); } public void Error(string message) { logger.Error(AppendModuleInfo(message)); } public void Error(string message, Exception exception) { logger.Error(AppendModuleInfo(message), exception); } public IList GetLog() { return logger.GetLog(); } public void Info(string message) { logger.Info(AppendModuleInfo(message)); } public void Log(string message) { logger.Log(message); } public void Subscribe(ILogObserver observer) { logger.Subscribe(observer); } public void Unsubscribe(ILogObserver observer) { logger.Unsubscribe(observer); } public void Warn(string message) { logger.Warn(AppendModuleInfo(message)); } private string AppendModuleInfo(string message) { return $"[{moduleInfo}] {message}"; } } }