/* * Copyright 2014 PRImA Research Lab, University of Salford, United Kingdom * * 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 org.primaresearch.web.gwt.server; import java.util.logging.Level; import java.util.logging.Logger; import org.primaresearch.web.gwt.client.log.LoggingService; import org.primaresearch.web.gwt.shared.RemoteException; import com.google.gwt.user.server.rpc.RemoteServiceServlet; /** * Service for sending log messages from the client (browser) to the server. * * @author Christian Clausner * */ public class LoggingServiceImpl extends RemoteServiceServlet implements LoggingService { private static final long serialVersionUID = 1L; Logger logger = null; public LoggingServiceImpl() { try { logger = Logger.getGlobal(); } catch (Exception exc) { exc.printStackTrace(); } } @Override public Boolean log(int level, int messageId, String message) throws RemoteException { doLog(level, messageId, message); return true; } /** * Calls the Java logger */ private void doLog(int level, int messageId, String message) { try { String text = "" + messageId + " - " + message; if (logger != null) { if (level == LoggingService.LEVEL_INFO) logger.info(text); else if (level == LoggingService.LEVEL_WARNING) logger.warning(text); else //if (level == LoggingService.LEVEL_ERROR) logger.log(Level.SEVERE, text); } else { System.out.println(text); } } catch (Exception exc) { } } }