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

io.ebeaninternal.server.logger.DTxnLogger Maven / Gradle / Ivy

There is a newer version: 15.8.0
Show newest version
package io.ebeaninternal.server.logger;

import io.ebeaninternal.api.SpiLogger;
import io.ebeaninternal.api.SpiTxnLogger;
import io.ebeaninternal.server.util.Str;

final class DTxnLogger implements SpiTxnLogger {

  private final String id;
  private final String logPrefix;
  private final SpiLogger sql;
  private final SpiLogger sum;
  private final SpiLogger txn;

  DTxnLogger(String id, SpiLogger sql, SpiLogger sum, SpiLogger txn) {
    this.id = id;
    this.logPrefix = id == null ? "" : "txn[" + id + "] ";
    this.sql = sql;
    this.sum = sum;
    this.txn = txn;
  }

  @Override
  public String id() {
    return id;
  }

  @Override
  public boolean isLogSql() {
    return sql.isDebug();
  }

  @Override
  public boolean isLogSummary() {
    return sum.isDebug();
  }

  @Override
  public void sql(String msg, Object... args) {
    sql.debug(Str.add(logPrefix, msg), args);
  }

  @Override
  public void sum(String msg, Object... args) {
    sum.debug(Str.add(logPrefix, msg), args);
  }

  @Override
  public void txn(String msg, Object... args) {
    txn.debug(Str.add(logPrefix, msg), args);
  }

  @Override
  public void notifyCommit() {
    txn.debug(Str.add(logPrefix, "Commit"));
  }

  @Override
  public void notifyQueryOnly() {
    // do nothing
  }

  @Override
  public void notifyRollback(Throwable cause) {
    if (txn.isDebug()) {
      String msg = logPrefix + "Rollback";
      if (cause != null) {
        msg += " error: " + formatThrowable(cause);
      }
      txn.debug(msg);
    }
  }

  private String formatThrowable(Throwable e) {
    if (e == null) {
      return "";
    }
    StringBuilder sb = new StringBuilder();
    formatThrowable(e, sb);
    return sb.toString();
  }

  private void formatThrowable(Throwable e, StringBuilder sb) {
    sb.append(e.toString());
    StackTraceElement[] stackTrace = e.getStackTrace();
    if (stackTrace.length > 0) {
      sb.append(" stack0: ");
      sb.append(stackTrace[0]);
    }
    Throwable cause = e.getCause();
    if (cause != null) {
      sb.append(" cause: ");
      formatThrowable(cause, sb);
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy