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

com.rt.storage.api.client.util.LoggingInputStream Maven / Gradle / Ivy

package com.rt.storage.api.client.util;

import java.io.FilterInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * Thread-safe input stream wrapper that forwards all reads to a given input stream, while logging
 * all reads to a {@link LoggingByteArrayOutputStream}.
 *
 * @since 1.9
 * @author Yaniv Inbar
 */
public class LoggingInputStream extends FilterInputStream {

  /** Log stream. */
  private final LoggingByteArrayOutputStream logStream;

  /**
   * @param inputStream input stream to forward all reads to
   * @param logger logger
   * @param loggingLevel logging level
   * @param contentLoggingLimit maximum number of bytes to log (may be {@code 0} to avoid logging
   *     content)
   */
  public LoggingInputStream(
      InputStream inputStream, Logger logger, Level loggingLevel, int contentLoggingLimit) {
    super(inputStream);
    logStream = new LoggingByteArrayOutputStream(logger, loggingLevel, contentLoggingLimit);
  }

  @Override
  public int read() throws IOException {
    int read = super.read();
    logStream.write(read);
    return read;
  }

  @Override
  public int read(byte[] b, int off, int len) throws IOException {
    int read = super.read(b, off, len);
    if (read > 0) {
      logStream.write(b, off, read);
    }
    return read;
  }

  @Override
  public void close() throws IOException {
    logStream.close();
    super.close();
  }

  /** Returns the log stream. */
  public final LoggingByteArrayOutputStream getLogStream() {
    return logStream;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy