com.sonicle.webtop.core.util.LoggerUtils.java Source code

Java tutorial

Introduction

Here is the source code for com.sonicle.webtop.core.util.LoggerUtils.java

Source

/*
 * WebTop Services is a Web Application framework developed by Sonicle S.r.l.
 * Copyright (C) 2014 Sonicle S.r.l.
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU Affero General Public License version 3 as published by
 * the Free Software Foundation with the addition of the following permission
 * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
 * WORK IN WHICH THE COPYRIGHT IS OWNED BY SONICLE, SONICLE DISCLAIMS THE
 * WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program; if not, see http://www.gnu.org/licenses or write to
 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 * MA 02110-1301 USA.
 *
 * You can contact Sonicle S.r.l. at email address sonicle@sonicle.com
 *
 * The interactive user interfaces in modified source and object code versions
 * of this program must display Appropriate Legal Notices, as required under
 * Section 5 of the GNU Affero General Public License version 3.
 *
 * In accordance with Section 7(b) of the GNU Affero General Public License
 * version 3, these Appropriate Legal Notices must retain the display of the
 * Sonicle logo and Sonicle copyright notice. If the display of the logo is not
 * reasonably feasible for technical reasons, the Appropriate Legal Notices must
 * display the words "Copyright (C) 2014 Sonicle S.r.l.".
 */
package com.sonicle.webtop.core.util;

import com.sonicle.webtop.core.app.WebTopApp;
import com.sonicle.webtop.core.sdk.UserProfileId;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.MDC;

/**
 *
 * @author malbinola
 */
public class LoggerUtils {
    //private static final String VAR_APPNAME = "appname";
    private static final String VAR_SERVICE = "service";
    private static final String VAR_USER = "user";
    private static final String VAR_USER_SERVICE = "user-service";
    private static final String VAR_AUTO = "auto";
    private static final String VAR_CUSTOM = "custom";
    private static final String DEFAULT_APPNAME = "noapp";
    private static final String DEFAULT_SERVICE = "core";
    private static final String DEFAULT_USER = "system";

    /*
    public synchronized static String getAppNameVariable() {
       return StringUtils.defaultString(MDC.get(VAR_APPNAME));
    }
    */

    public synchronized static String getServiceVariable() {
        return StringUtils.defaultIfBlank(MDC.get(VAR_SERVICE), DEFAULT_SERVICE);
    }

    public synchronized static String getUserVariable() {
        return StringUtils.defaultIfBlank(MDC.get(VAR_USER), DEFAULT_USER);
    }

    public synchronized static String getUserServiceVariable() {
        return StringUtils.defaultString(MDC.get(VAR_USER_SERVICE));
    }

    public synchronized static String getCustomVariable() {
        return StringUtils.defaultIfBlank(MDC.get(VAR_CUSTOM), null);
    }

    public synchronized static void initDC() {
        clearDC();
        //initDC(StringUtils.defaultIfBlank(WebTopApp.getWebappName(), DEFAULT_APPNAME));
    }

    /*
    public synchronized static void initDC(String appName) {
       MDC.put(VAR_APPNAME, appName);
       clearDC();
    }
    */

    public synchronized static void clearDC() {
        MDC.put(VAR_USER, DEFAULT_USER);
        MDC.put(VAR_SERVICE, DEFAULT_SERVICE);
        MDC.remove(VAR_CUSTOM);
        updateAutoDC();
    }

    public synchronized static void setContextDC(UserProfileId profile) {
        MDC.put(VAR_USER, profile.getUserId());
        updateAutoDC();
    }

    public synchronized static void setContextDC(String service) {
        MDC.put(VAR_SERVICE, service);
        updateAutoDC();
    }

    public synchronized static void setContextDC(UserProfileId profile, String service) {
        MDC.put(VAR_USER, profile.getUserId());
        MDC.put(VAR_SERVICE, service);
        updateAutoDC();
    }

    public synchronized static void clearContextServiceDC() {
        MDC.put(VAR_SERVICE, DEFAULT_SERVICE);
        MDC.remove(VAR_CUSTOM);
        updateAutoDC();
    }

    public synchronized static void setCustomDC(String custom) {
        MDC.put(VAR_CUSTOM, custom);
        updateAutoDC();
    }

    public synchronized static void clearCustomDC() {
        MDC.remove(VAR_CUSTOM);
        updateAutoDC();
    }

    /**
     * Recalculate values of automatic variables in diagnostic context.
     */
    public synchronized static void updateAutoDC() {
        final String userservice = getServiceVariable() + "-" + getUserVariable();
        MDC.put(VAR_USER_SERVICE, userservice);
        final String custom = getCustomVariable();
        if (custom == null) {
            MDC.put(VAR_AUTO, getUserServiceVariable());
        } else {
            MDC.put(VAR_AUTO, getUserServiceVariable() + "-" + custom);
        }
        //MDC.put("split", MDC.get("appname") + "_" + (StringUtils.isEmpty(custom) ? servuser : servuser + "-" + custom));
    }
}