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

com.microsoft.applicationinsights.internal.logger.DefaultLogFileProxy Maven / Gradle / Ivy

/*
 * ApplicationInsights-Java
 * Copyright (c) Microsoft Corporation
 * All rights reserved.
 *
 * MIT License
 * Permission is hereby granted, free of charge, to any person obtaining a copy of this
 * software and associated documentation files (the ""Software""), to deal in the Software
 * without restriction, including without limitation the rights to use, copy, modify, merge,
 * publish, distribute, sublicense, and/or sell copies of the Software, and to permit
 * persons to whom the Software is furnished to do so, subject to the following conditions:
 * The above copyright notice and this permission notice shall be included in all copies or
 * substantial portions of the Software.
 * THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
 * PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
 * FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 * DEALINGS IN THE SOFTWARE.
 */

package com.microsoft.applicationinsights.internal.logger;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;

/**
 * The class is responsible for doing the work with the log files.
 */
public final class DefaultLogFileProxy implements LogFileProxy {
    private static String NEW_LINE = System.getProperty("line.separator");
    private final static String LOG_FILE_PREFIX = "-JavaSDKLog";
    private final static String LOG_FILE_SUFFIX = ".jsl";
    private final static int SIZE_OF_MB = 1048576;

    private FileWriter out;
    private File file;
    private int maxSizePerFileInMB;

    public static DefaultLogFileProxy createNew(File baseFolder, String uniquePrefix, int maxSizePerFileInMB) throws IOException {
        return new DefaultLogFileProxy(baseFolder, uniquePrefix, maxSizePerFileInMB);
    }

    public static DefaultLogFileProxy attachToExistingFile(File file, int maxSizePerFileInMB) throws IOException {
        return new DefaultLogFileProxy(file, maxSizePerFileInMB);
    }

    public void close() throws IOException {
        flush();
        out.close();
    }

    public void delete() {
        file.delete();
    }

    public void writeLine(String line) throws IOException {
        out.write(line + NEW_LINE);

        //flush every time for real time streaming of logs on file.
        //Please use logger with caution. Using File logger with TRACE level logging
        //can significantly increase the load
        flush();
    }

    public boolean isFull() {
        long fileSizeInMB = file.length() / SIZE_OF_MB;
        return maxSizePerFileInMB < fileSizeInMB;
    }

    public void flush() {
        try {
            out.flush();
        } catch (IOException e) {
        }
    }

    private DefaultLogFileProxy(File baseFolder, String uniquePrefix, int maxSizePerFileInMB) throws IOException {
        initialize(File.createTempFile(uniquePrefix + LOG_FILE_PREFIX, LOG_FILE_SUFFIX, baseFolder), maxSizePerFileInMB);
    }

    private DefaultLogFileProxy(File file, int maxSizePerFileInMB) throws IOException {
        initialize(file, maxSizePerFileInMB);
    }

    private void initialize(File file, int maxSizePerFileInMB) throws IOException {
        this.maxSizePerFileInMB = maxSizePerFileInMB;
        this.file = file;
        out = new FileWriter(file);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy