001/**
002 * Copyright 2010-2013 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package org.kuali.common.util.stream;
017
018import org.codehaus.plexus.util.cli.StreamConsumer;
019import org.kuali.common.util.Assert;
020import org.kuali.common.util.log.LoggerLevel;
021import org.kuali.common.util.log.LoggerUtils;
022import org.slf4j.Logger;
023
024public final class LoggingStreamConsumer implements StreamConsumer {
025
026        private final Logger logger;
027        private final LoggerLevel level;
028
029        public LoggingStreamConsumer(Logger logger) {
030                this(logger, LoggerLevel.INFO);
031        }
032
033        public LoggingStreamConsumer(Logger logger, LoggerLevel level) {
034                Assert.noNulls(logger, level);
035                this.logger = logger;
036                this.level = level;
037        }
038
039        @Override
040        public void consumeLine(String line) {
041                LoggerUtils.logMsg(line, logger, level);
042        }
043
044        public Logger getLogger() {
045                return logger;
046        }
047
048        public LoggerLevel getLevel() {
049                return level;
050        }
051
052}