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

com.swirlds.cli.logging.LogProcessingUtils Maven / Gradle / Ivy

Go to download

Swirlds is a software platform designed to build fully-distributed applications that harness the power of the cloud without servers. Now you can develop applications with fairness in decision making, speed, trust and reliability, at a fraction of the cost of traditional server-based platforms.

There is a newer version: 0.56.6
Show newest version
/*
 * Copyright (C) 2023-2024 Hedera Hashgraph, LLC
 *
 * 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 com.swirlds.cli.logging;

import static com.swirlds.cli.logging.LogLine.ERROR_LOG_LEVEL_COLOR;
import static com.swirlds.cli.logging.LogLine.HARMLESS_LOG_LEVEL_COLOR;
import static com.swirlds.cli.logging.LogLine.WARN_LOG_LEVEL_COLOR;

import com.swirlds.common.formatting.TextEffect;
import edu.umd.cs.findbugs.annotations.NonNull;
import java.time.Instant;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.format.DateTimeFormatter;

/**
 * Utility methods for processing log files into a more readable format.
 */
public class LogProcessingUtils {
    /**
     * Hidden constructor.
     */
    private LogProcessingUtils() {}

    /**
     * Get the correct color for a given log level.
     *
     * @param logLevel the log level
     * @return the color
     */
    @NonNull
    public static TextEffect getLogLevelColor(@NonNull final String logLevel) {
        return switch (logLevel) {
            case "TRACE", "DEBUG", "INFO" -> HARMLESS_LOG_LEVEL_COLOR;
            case "WARN" -> WARN_LOG_LEVEL_COLOR;
                // all other log levels are critical
            default -> ERROR_LOG_LEVEL_COLOR;
        };
    }

    /**
     * Parse a log timestamp string into an Instant.
     *
     * @param timestampString the timestamp string to parse
     * @param zoneId          the zone ID of the timestamp
     * @return the parsed Instant
     */
    public static Instant parseTimestamp(@NonNull final String timestampString, @NonNull final ZoneId zoneId) {
        return LocalDateTime.parse(timestampString, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS"))
                .atZone(zoneId)
                .toInstant();
    }

    /**
     * Generate an ANSI colorized version of a log line if the line can be parsed.
     * 

* If the line cannot be parsed, it is returned without any colorization. * * @param inputString the input log line string * @param zoneId the timezone of the timestamp in the log line * @return the colorized log line if it can be parsed, otherwise the original log line */ @NonNull static String colorizeLogLineAnsi(@NonNull final String inputString, @NonNull final ZoneId zoneId) { try { final LogLine logLine = new LogLine(inputString, zoneId); return logLine.generateAnsiString(); } catch (final Exception e) { return inputString; } } /** * Escapes the input string to be HTML safe * * @param inputString the string to escape * @return the escaped string */ @NonNull public static String escapeString(@NonNull final String inputString) { return inputString .replace("&", "&") .replace("<", "<") .replace(">", ">") .replace("\"", """) .replace("’", "'"); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy