All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jpattern.service.log.SimpleLoggerServiceBuilder Maven / Gradle / Ivy

package com.jpattern.service.log;

import java.io.PrintWriter;
import java.util.Map.Entry;

import com.jpattern.service.log.file.ILogFileExecutorStrategy;
import com.jpattern.service.log.file.ILogFileWriter;
import com.jpattern.service.log.file.LogFileExecutor;
import com.jpattern.service.log.file.RollingLogFileExecutorStrategy;
import com.jpattern.service.mail.IMailService;

/**
 * 
 * @author Francesco Cina'
 *
 * 09/apr/2010
 */
public class SimpleLoggerServiceBuilder extends ALoggerServiceBuilder {

	private static final long serialVersionUID = 1L;
	private ILoggerConfig loggerConfig;
	private IMailService mailService;
	private final IExecutor executor;

	public SimpleLoggerServiceBuilder(ILoggerConfig loggerConfig, IMailService mailService) {
		this(loggerConfig, mailService, new NullExecutor());
	}
	
	public SimpleLoggerServiceBuilder(ILoggerConfig loggerConfig, IMailService mailService, IExecutor executor) {
		this.loggerConfig = loggerConfig;
		this.mailService = mailService;
		this.executor = executor;
	}

	public ILoggerService build() {
		
		//Configuro Logging su File
		ILogFileExecutorStrategy fileExecutorStrategy = new RollingLogFileExecutorStrategy(loggerConfig.getLogFile(), loggerConfig.getMaxFileSize(), ILogFileWriter.MEGABYTE, loggerConfig.getMaxFileBackupNumber());
		IExecutor fileExecutor = new LogFileExecutor(fileExecutorStrategy, executor);
		fileExecutor.setLoggerLevel(loggerConfig.getFileLoggerlevel());
		
		//Configuro Logging su console
		PrintWriter printWriter = new PrintWriter(System.out, true);
		IExecutor consoleExecutor = new PrintWriterExecutor( printWriter , fileExecutor);
		consoleExecutor.setLoggerLevel(loggerConfig.getConsoleLoggerlevel());
		
		//Configuro Logging su Mail
		IExecutor mailExecutor = new MailExecutor(mailService, loggerConfig.getMailToList(), loggerConfig.getMailFrom(), loggerConfig.getMailSubject(), consoleExecutor);
		mailExecutor.setLoggerLevel(loggerConfig.getMailLoggerlevel());
		
		
		ILoggerService loggerService = (ILoggerService) new LoggerServiceBuilder( mailExecutor ).build(); 
		for( Entry entry : loggerConfig.getClasspathLoggerLevelMap().entrySet() ) {
			loggerService.setLoggerLevel(entry.getKey(), entry.getValue());
		}
		
		return loggerService;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy