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

io.opentelemetry.sdk.logs.MultiLogRecordProcessor Maven / Gradle / Ivy

There is a newer version: 1.44.1
Show newest version
/*
 * Copyright The OpenTelemetry Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package io.opentelemetry.sdk.logs;

import io.opentelemetry.context.Context;
import io.opentelemetry.sdk.common.CompletableResultCode;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.concurrent.atomic.AtomicBoolean;

/**
 * Implementation of {@link LogRecordProcessor} that forwards all logs to a list of {@link
 * LogRecordProcessor}s.
 */
final class MultiLogRecordProcessor implements LogRecordProcessor {

  private final List logRecordProcessors;
  private final AtomicBoolean isShutdown = new AtomicBoolean(false);

  /**
   * Create a new {@link MultiLogRecordProcessor}.
   *
   * @param logRecordProcessorsList list of log processors to forward logs to
   * @return a multi log processor instance
   */
  static LogRecordProcessor create(List logRecordProcessorsList) {
    return new MultiLogRecordProcessor(
        new ArrayList<>(
            Objects.requireNonNull(logRecordProcessorsList, "logRecordProcessorsList")));
  }

  @Override
  public void onEmit(Context context, ReadWriteLogRecord logRecord) {
    for (LogRecordProcessor logRecordProcessor : logRecordProcessors) {
      logRecordProcessor.onEmit(context, logRecord);
    }
  }

  @Override
  public CompletableResultCode shutdown() {
    if (isShutdown.getAndSet(true)) {
      return CompletableResultCode.ofSuccess();
    }
    List results = new ArrayList<>(logRecordProcessors.size());
    for (LogRecordProcessor logRecordProcessor : logRecordProcessors) {
      results.add(logRecordProcessor.shutdown());
    }
    return CompletableResultCode.ofAll(results);
  }

  @Override
  public CompletableResultCode forceFlush() {
    List results = new ArrayList<>(logRecordProcessors.size());
    for (LogRecordProcessor logRecordProcessor : logRecordProcessors) {
      results.add(logRecordProcessor.forceFlush());
    }
    return CompletableResultCode.ofAll(results);
  }

  private MultiLogRecordProcessor(List logRecordProcessorsList) {
    this.logRecordProcessors = logRecordProcessorsList;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy