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

devutility.internal.io.LogHelper Maven / Gradle / Ivy

package devutility.internal.io;

import java.io.IOException;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.time.LocalDateTime;

import devutility.internal.lang.ExceptionHelper;
import devutility.internal.lang.StringHelper;

public class LogHelper {
	// region variables

	private static final String FILENAMEFORMAT_EXCEPTION = "exception_%s";

	// endregion

	// region get Log Root Directory

	public static String getLogRootDirectory() throws IOException {
		String projectDirectory = DirectoryHelper.getProjectDirectory();

		if (projectDirectory == null) {
			throw new IOException("Cannot get project directory!");
		}

		return Paths.get(projectDirectory, "data", "logs").toString();
	}

	// endregion

	// region get file name

	public static String getLogFileName(String fileNameFormat, LocalDateTime dateTime) {
		String hourLogFileName = FileUtils.getHourLogFileName(dateTime.getHour());

		if (StringHelper.isNullOrEmpty(fileNameFormat)) {
			return hourLogFileName;
		}

		return String.format(fileNameFormat, hourLogFileName);
	}

	// endregion

	// region save

	public static void save(String rootDirectory, LocalDateTime dateTime, String fileNameFormat, String content) throws IOException {
		String logDirectory = DirectoryHelper.getDateDirectory(rootDirectory, dateTime);

		if (!DirectoryHelper.createIfNon(logDirectory)) {
			throw new IOException(String.format("Cannot create directory %s", logDirectory));
		}

		String fileName = getLogFileName(fileNameFormat, dateTime);
		Path path = Paths.get(logDirectory, fileName);
		TextFileHelper.asyncAppend(path, content);
	}

	public static void save(LocalDateTime dateTime, String fileNameFormat, String content) throws IOException {
		String rootDirectory = getLogRootDirectory();
		save(rootDirectory, dateTime, fileNameFormat, content);
	}

	public static void save(String rootDirectory, String fileNameFormat, String content) throws IOException {
		save(rootDirectory, LocalDateTime.now(), fileNameFormat, content);
	}

	public static void save(String fileNameFormat, String content) throws IOException {
		save(LocalDateTime.now(), fileNameFormat, content);
	}

	public static void save(String content) throws IOException {
		save(null, content);
	}

	public static void save(String rootDirectory, LocalDateTime dateTime, Exception exception) throws Exception {
		save(rootDirectory, dateTime, FILENAMEFORMAT_EXCEPTION, ExceptionHelper.toString(exception));
	}

	// endregion
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy