001/**
002 *
003 * Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
004 *
005 * This library is free software; you can redistribute it and/or
006 * modify it under the terms of the GNU Lesser General Public
007 * License as published by the Free Software Foundation; either 
008 * version 2.1 of the License, or (at your option) any later version.
009 * 
010 * This library is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
013 * Lesser General Public License for more details.
014 * 
015 * You should have received a copy of the GNU Lesser General Public 
016 * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
017 * 
018 **/
019package lucee.commons.io.log.log4j;
020
021import lucee.commons.io.log.Log;
022import lucee.commons.lang.StringUtil;
023
024import org.apache.log4j.Logger;
025
026public class LogAdapter implements Log {
027        
028        private Logger logger;
029
030        public LogAdapter(Logger logger){
031                this.logger=logger;
032        }
033
034        @Override
035        public void log(int level, String application, String message) {
036                logger.log(Log4jUtil.toLevel(level), application+"->"+message);
037                
038        }
039
040        public void log(int level, String application, String message, Throwable t) {
041                if(StringUtil.isEmpty(message))logger.log(Log4jUtil.toLevel(level), application,t);
042                else logger.log(Log4jUtil.toLevel(level), application+"->"+message,t);
043        }
044
045        @Override
046        public void info(String application, String message) {
047                log(Log.LEVEL_INFO,application,message);
048        }
049
050        @Override
051        public void debug(String application, String message) {
052                log(Log.LEVEL_DEBUG,application,message);
053        }
054
055        @Override
056        public void warn(String application, String message) {
057                log(Log.LEVEL_WARN,application,message);
058        }
059
060        @Override
061        public void error(String application, String message) {
062                log(Log.LEVEL_ERROR,application,message);
063        }
064
065        @Override
066        public void fatal(String application, String message) {
067                log(Log.LEVEL_FATAL,application,message);
068        }
069
070        @Override
071        public int getLogLevel() {
072                return Log4jUtil.toLevel(logger.getLevel());
073        }
074
075        @Override
076        public void setLogLevel(int level) {
077                logger.setLevel(Log4jUtil.toLevel(level));
078        }
079
080        public Logger getLogger() {
081                return logger;
082        }
083}