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

psiprobe.controllers.logs.ChangeLogLevelController Maven / Gradle / Ivy

/**
 * Licensed under the GPL License. You may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
 *
 * THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
 * WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE.
 */
package psiprobe.controllers.logs;

import java.util.Arrays;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.ServletRequestUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import psiprobe.tools.logging.LogDestination;
import psiprobe.tools.logging.jdk.Jdk14HandlerAccessor;
import psiprobe.tools.logging.log4j.Log4JAppenderAccessor;
import psiprobe.tools.logging.log4j2.Log4J2AppenderAccessor;
import psiprobe.tools.logging.logback.LogbackAppenderAccessor;
import psiprobe.tools.logging.slf4jlogback.TomcatSlf4jLogbackAppenderAccessor;

/**
 * The Class ChangeLogLevelController.
 */
@Controller
public class ChangeLogLevelController extends AbstractLogHandlerController {

  @RequestMapping(path = "/adm/changeloglevel.ajax")
  @Override
  public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response)
      throws Exception {
    return super.handleRequest(request, response);
  }

  @Override
  protected ModelAndView handleLogFile(HttpServletRequest request, HttpServletResponse response,
      LogDestination logDest) throws Exception {

    String level = ServletRequestUtils.getRequiredStringParameter(request, "level");
    if (logDest.getValidLevels() != null
        && Arrays.asList(logDest.getValidLevels()).contains(level)) {

      if (logDest instanceof Log4JAppenderAccessor) {
        Log4JAppenderAccessor accessor = (Log4JAppenderAccessor) logDest;
        accessor.getLoggerAccessor().setLevel(level);
      } else if (logDest instanceof Log4J2AppenderAccessor) {
        Log4J2AppenderAccessor accessor = (Log4J2AppenderAccessor) logDest;
        accessor.getLoggerAccessor().setLevel(level);
      } else if (logDest instanceof Jdk14HandlerAccessor) {
        Jdk14HandlerAccessor accessor = (Jdk14HandlerAccessor) logDest;
        accessor.getLoggerAccessor().setLevel(level);
      } else if (logDest instanceof LogbackAppenderAccessor) {
        LogbackAppenderAccessor accessor = (LogbackAppenderAccessor) logDest;
        accessor.getLoggerAccessor().setLevel(level);
      } else if (logDest instanceof TomcatSlf4jLogbackAppenderAccessor) {
        TomcatSlf4jLogbackAppenderAccessor accessor = (TomcatSlf4jLogbackAppenderAccessor) logDest;
        accessor.getLoggerAccessor().setLevel(level);
      }
    }
    return null;
  }

  @Value("")
  @Override
  public void setViewName(String viewName) {
    super.setViewName(viewName);
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy