// 
// Decompiled by Procyon v0.6.0
// 

package io.sentry;

import org.jetbrains.annotations.TestOnly;
import io.sentry.util.Objects;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.ApiStatus;

@ApiStatus.Internal
public final class DiagnosticLogger implements ILogger
{
    @NotNull
    private final SentryOptions options;
    @Nullable
    private final ILogger logger;
    
    public DiagnosticLogger(@NotNull final SentryOptions options, @Nullable final ILogger logger) {
        this.options = Objects.requireNonNull(options, "SentryOptions is required.");
        this.logger = logger;
    }
    
    @Override
    public boolean isEnabled(@Nullable final SentryLevel level) {
        final SentryLevel diagLevel = this.options.getDiagnosticLevel();
        return level != null && this.options.isDebug() && level.ordinal() >= diagLevel.ordinal();
    }
    
    @Override
    public void log(@NotNull final SentryLevel level, @NotNull final String message, @Nullable final Object... args) {
        if (this.logger != null && this.isEnabled(level)) {
            this.logger.log(level, message, args);
        }
    }
    
    @Override
    public void log(@NotNull final SentryLevel level, @NotNull final String message, @Nullable final Throwable throwable) {
        if (this.logger != null && this.isEnabled(level)) {
            this.logger.log(level, message, throwable);
        }
    }
    
    @Override
    public void log(@NotNull final SentryLevel level, @Nullable final Throwable throwable, @NotNull final String message, @Nullable final Object... args) {
        if (this.logger != null && this.isEnabled(level)) {
            this.logger.log(level, throwable, message, args);
        }
    }
    
    @TestOnly
    @Nullable
    public ILogger getLogger() {
        return this.logger;
    }
}
