112 lines
3.2 KiB
Java
Raw Normal View History

2019-10-03 08:42:09 +02:00
package com.wasteinformationserver.basicutils;
2019-10-02 21:42:04 +02:00
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
public class Log {
private static final String ANSI_RESET = "\u001B[0m";
private static final String ANSI_BLACK = "\u001B[30m";
private static final String ANSI_RED = "\u001B[31m";
private static final String ANSI_GREEN = "\u001B[32m";
private static final String ANSI_YELLOW = "\u001B[33m";
private static final String ANSI_BLUE = "\u001B[34m";
private static final String ANSI_PURPLE = "\u001B[35m";
private static final String ANSI_CYAN = "\u001B[36m";
private static final String ANSI_WHITE = "\u001B[37m";
2019-10-11 09:03:14 +02:00
public static final int CRITICAL_ERROR = 6;
public static final int ERROR = 5;
public static final int WARNING = 4;
public static final int INFO = 3;
public static final int MESSAGE = 2;
public static final int DEBUG = 1;
2019-10-02 21:42:04 +02:00
2019-10-11 09:03:14 +02:00
private static ArrayList<String> colors = new ArrayList<String>(Arrays.asList("", "DEBUG", "MESSAGE", "INFO", "WARNING", "ERROR", "CRITICAL_ERROR"));
2019-10-02 21:42:04 +02:00
2019-10-11 09:03:14 +02:00
public static void criticalerror(String msg) {
log(msg, CRITICAL_ERROR);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void error(String msg) {
log(msg, ERROR);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void warning(String msg) {
log(msg, WARNING);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void info(String msg) {
log(msg, INFO);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void message(String msg) {
log(msg, MESSAGE);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void debug(String msg) {
log(msg, DEBUG);
2019-10-02 21:42:04 +02:00
}
2019-10-11 09:03:14 +02:00
public static void log(String msg, int level) {
2019-11-11 13:07:56 +01:00
boolean iswindows = System.getProperty("os.name").contains("Windows");
2019-10-02 21:42:04 +02:00
StringBuilder builder = new StringBuilder();
2019-11-11 13:07:56 +01:00
if (!iswindows){
2019-10-11 09:03:14 +02:00
switch (level) {
2019-10-02 21:42:04 +02:00
case INFO:
builder.append(ANSI_CYAN);
break;
case WARNING:
builder.append(ANSI_YELLOW);
break;
case ERROR:
builder.append(ANSI_RED);
break;
case CRITICAL_ERROR:
builder.append(ANSI_RED);
break;
case MESSAGE:
builder.append(ANSI_WHITE);
break;
case DEBUG:
builder.append(ANSI_BLUE);
break;
}
2019-11-11 13:07:56 +01:00
}
2019-10-02 21:42:04 +02:00
builder.append("[");
builder.append(calcDate(System.currentTimeMillis()));
builder.append("]");
builder.append(" [");
2019-10-03 08:42:09 +02:00
builder.append(new Exception().getStackTrace()[2].getClassName());
2019-10-02 21:42:04 +02:00
builder.append("]");
builder.append(" [");
builder.append(colors.get(level));
builder.append("]");
2019-11-11 13:07:56 +01:00
if (!iswindows){
builder.append(ANSI_WHITE);
}
2019-10-02 21:42:04 +02:00
builder.append(" - ");
builder.append(msg);
2019-11-11 13:07:56 +01:00
if (!iswindows){
builder.append(ANSI_RESET);
}
2019-10-02 21:42:04 +02:00
System.out.println(builder.toString());
}
private static String calcDate(long millisecs) {
SimpleDateFormat date_format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date resultdate = new Date(millisecs);
return date_format.format(resultdate);
}
}