/* * Copyright (c) 2009-present the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.planet57.gshell.commands.logging; import javax.annotation.Nonnull; import com.planet57.gshell.util.jline.Complete; import com.planet57.gshell.command.Command; import com.planet57.gshell.command.CommandContext; import com.planet57.gshell.logging.LevelComponent; import com.planet57.gshell.logging.LoggerComponent; import com.planet57.gshell.util.cli2.Argument; /** * Set the level of a logger. * * @author <a href="mailto:jason@planet57.com">Jason Dillon</a> * @since 2.5 */ @Command(name = "logging/logger", description = "Set the level of a logger") public class LoggerSetLevelAction extends LoggingCommandActionSupport { @Argument(index = 0, required = true, description = "Logger name", token = "LOGGER") @Complete("logger-name") private String loggerName; @Argument(index = 1, required = true, description = "Logger level", token = "LEVEL") @Complete("logger-level") private String levelName; @Override public Object execute(@Nonnull final CommandContext context) throws Exception { LoggerComponent logger = getLogging().getLogger(loggerName); LevelComponent level = getLogging().getLevel(levelName); logger.setLevel(level); log.debug("Set logger {} level to: {}", logger, level); return null; } }