/****************************************************************************** * Copyright © 2013-2016 The Nxt Core Developers. * * * * See the AUTHORS.txt, DEVELOPER-AGREEMENT.txt and LICENSE.txt files at * * the top-level directory of this distribution for the individual copyright * * holder information and the developer policies on copyright and licensing. * * * * Unless otherwise agreed in a custom licensing agreement, no part of the * * Nxt software, including this file, may be copied, modified, propagated, * * or distributed except according to the terms contained in the LICENSE.txt * * file. * * * * Removal or modification of this copyright notice is prohibited. * * * ******************************************************************************/ package nxt.http; import nxt.peer.Peers; import nxt.util.JSON; import nxt.util.Logger; import org.json.simple.JSONObject; import org.json.simple.JSONStreamAware; import javax.servlet.http.HttpServletRequest; /** * <p>The SetLogging API will set the NRS log level for all log messages. * It will also set the communication events that are logged.</p> * * <p>Request parameters:</p> * <ul> * <li>logLevel - Specifies the log message level and defaults to INFO if not specified.</li> * <li>communicationEvent - Specifies a communication event to be logged and defaults to * no communication logging if not specified. * This parameter can be specified multiple times to log multiple communication events.</li> * </ul> * * <p>Response parameters:</p> * <ul> * <li>loggingUpdated - Set to 'true' if the logging was updated.</li> * </ul> * * <p>The following log levels can be specified:</p> * <ul> * <li>DEBUG - Debug, informational, warning and error messages will be logged.</li> * <li>INFO - Informational, warning and error messages will be logged.</li> * <li>WARN - Warning and error messages will be logged.</li> * <li>ERROR - Error messages will be logged.</li> * </ul> * * <p>The following communication events can be specified. This is a bit mask * so multiple events can be enabled at the same time. The log level must be * DEBUG or INFO for communication events to be logged.</p> * <ul> * <li>EXCEPTION - Log HTTP exceptions.</li> * <li>HTTP-ERROR - Log non-200 HTTP responses.</li> * <li>HTTP-OK - Log HTTP 200 responses.</li> * </ul> */ public class SetLogging extends APIServlet.APIRequestHandler { /** SetLogging instance */ static final SetLogging instance = new SetLogging(); /** Logging updated */ private static final JSONStreamAware LOGGING_UPDATED; static { JSONObject response = new JSONObject(); response.put("loggingUpdated", true); LOGGING_UPDATED = JSON.prepare(response); } /** Incorrect log level */ private static final JSONStreamAware INCORRECT_LEVEL = JSONResponses.incorrect("logLevel", "Log level must be DEBUG, INFO, WARN or ERROR"); /** Incorrect communication event */ private static final JSONStreamAware INCORRECT_EVENT = JSONResponses.incorrect("communicationEvent", "Communication event must be EXCEPTION, HTTP-ERROR or HTTP-OK"); /** * Create the SetLogging instance */ private SetLogging() { super(new APITag[] {APITag.DEBUG}, "logLevel", "communicationEvent", "communicationEvent", "communicationEvent"); } /** * Process the SetLogging API request * * @param req API request * @return API response */ @Override JSONStreamAware processRequest(HttpServletRequest req) { JSONStreamAware response = null; // // Get the log level // String value = req.getParameter("logLevel"); if (value != null) { switch (value) { case "DEBUG": Logger.setLevel(Logger.Level.DEBUG); break; case "INFO": Logger.setLevel(Logger.Level.INFO); break; case "WARN": Logger.setLevel(Logger.Level.WARN); break; case "ERROR": Logger.setLevel(Logger.Level.ERROR); break; default: response = INCORRECT_LEVEL; } } else { Logger.setLevel(Logger.Level.INFO); } // // Get the communication events // if (response == null) { String[] events = req.getParameterValues("communicationEvent"); if (!Peers.setCommunicationLoggingMask(events)) response = INCORRECT_EVENT; } // // Return the response // if (response == null) response = LOGGING_UPDATED; return response; } /** * Require the administrator password * * @return TRUE if the admin password is required */ @Override boolean requirePassword() { return true; } @Override final boolean requirePost() { return true; } @Override boolean allowRequiredBlockParameters() { return false; } @Override boolean requireBlockchain() { return false; } }