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

org.bonitasoft.engine.services.impl.QueriableLogUpdater Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2019 Bonitasoft S.A.
 * Bonitasoft, 32 rue Gustave Eiffel - 38000 Grenoble
 * This library is free software; you can redistribute it and/or modify it under the terms
 * of the GNU Lesser General Public License as published by the Free Software Foundation
 * version 2.1 of the License.
 * This library 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 Lesser General Public License for more details.
 * You should have received a copy of the GNU Lesser General Public License along with this
 * program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
 * Floor, Boston, MA 02110-1301, USA.
 **/
package org.bonitasoft.engine.services.impl;

import lombok.extern.slf4j.Slf4j;
import org.bonitasoft.engine.platform.PlatformService;
import org.bonitasoft.engine.queriablelogger.model.SQueriableLog;
import org.bonitasoft.engine.services.QueriableLogSessionProvider;

/**
 * @author Elias Ricken de Medeiros
 */
@Slf4j
public class QueriableLogUpdater {

    private static final int MAX_MESSAGE_LENGTH = 255;
    private final QueriableLogSessionProvider sessionProvider;
    private final PlatformService platformService;

    public QueriableLogUpdater(final QueriableLogSessionProvider sessionProvider,
            final PlatformService platformService) {
        this.sessionProvider = sessionProvider;
        this.platformService = platformService;
    }

    public SQueriableLog buildFinalLog(final String callerClassName, final String callerMethodName,
            final SQueriableLog sQueriableLog) {
        final SQueriableLog.SQueriableLogBuilder builder = sQueriableLog.toBuilder();

        final String rawMessage = sQueriableLog.getRawMessage();
        if (rawMessage.length() > MAX_MESSAGE_LENGTH) {
            final String truncatedMessage = rawMessage.substring(0, MAX_MESSAGE_LENGTH);
            builder.rawMessage(truncatedMessage);
            if (log.isInfoEnabled()) {
                final StringBuilder stb = new StringBuilder();
                stb.append("The queriable log message is too long and will be truncated to ");
                stb.append(MAX_MESSAGE_LENGTH);
                stb.append(" characters. The original message is '");
                stb.append(rawMessage);
                stb.append("'. It will be truncated to '");
                stb.append(truncatedMessage);
                stb.append("'");
                log.info(stb.toString());
            }
        }
        return builder.callerClassName(callerClassName).callerMethodName(callerMethodName)
                .userId(sessionProvider.getUserId()).clusterNode(sessionProvider.getClusterNode())
                .productVersion(platformService.getSPlatformProperties().getPlatformVersion())
                .build();

    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy