BootLogger.java

  1. /*
  2.  * #%L
  3.  * *********************************************************************************************************************
  4.  *
  5.  * NorthernWind - lightweight CMS
  6.  * http://northernwind.tidalwave.it - git clone https://bitbucket.org/tidalwave/northernwind-src.git
  7.  * %%
  8.  * Copyright (C) 2011 - 2021 Tidalwave s.a.s. (http://tidalwave.it)
  9.  * %%
  10.  * *********************************************************************************************************************
  11.  *
  12.  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  13.  * the License. You may obtain a copy of the License at
  14.  *
  15.  *     http://www.apache.org/licenses/LICENSE-2.0
  16.  *
  17.  * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  18.  * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the
  19.  * specific language governing permissions and limitations under the License.
  20.  *
  21.  * *********************************************************************************************************************
  22.  *
  23.  *
  24.  * *********************************************************************************************************************
  25.  * #L%
  26.  */
  27. package it.tidalwave.northernwind.frontend.util;

  28. import java.io.PrintWriter;
  29. import java.io.StringWriter;
  30. import javax.annotation.Nonnull;
  31. import lombok.RequiredArgsConstructor;

  32. /***********************************************************************************************************************
  33.  *
  34.  * We can't log to the real thing, since we first need to compute the path of the logging file. Logging to the real
  35.  * thing would instantiate the logging facility before we have a chance to configure it.
  36.  *
  37.  * @author  Fabrizio Giudici
  38.  *
  39.  **********************************************************************************************************************/
  40. @RequiredArgsConstructor
  41. public final class BootLogger
  42.   {
  43.     private static final StringBuilder BUILDER = new StringBuilder();

  44.     private final Class<?> owner;

  45.     public void log (@Nonnull final String string)
  46.       {
  47.         @SuppressWarnings("squid:S106")
  48.         final String s = String.format("%s: %s", owner.getSimpleName(), string);
  49.         System.err.println(s);
  50.         BUILDER.append(s).append("\n");
  51.       }

  52.     public void log (@Nonnull final Throwable t)
  53.       {
  54.         final StringWriter sw = new StringWriter();
  55.         final PrintWriter pw = new PrintWriter(sw);
  56.         t.printStackTrace(pw);
  57.         pw.flush();
  58.         log(t + "\n" + sw);
  59.       }

  60.     @Nonnull
  61.     public static String getLogContent()
  62.       {
  63.         return BUILDER.toString();
  64.       }
  65.   }