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

package io.sentry.clientreport;

import io.sentry.SentryLevel;
import java.util.HashMap;
import java.util.Collection;
import io.sentry.vendor.gson.stream.JsonToken;
import java.util.ArrayList;
import io.sentry.ObjectReader;
import io.sentry.JsonDeserializer;
import java.io.IOException;
import java.util.Iterator;
import io.sentry.DateUtils;
import io.sentry.ILogger;
import io.sentry.ObjectWriter;
import org.jetbrains.annotations.Nullable;
import java.util.Map;
import java.util.List;
import org.jetbrains.annotations.NotNull;
import java.util.Date;
import org.jetbrains.annotations.ApiStatus;
import io.sentry.JsonSerializable;
import io.sentry.JsonUnknown;

@ApiStatus.Internal
public final class ClientReport implements JsonUnknown, JsonSerializable
{
    @NotNull
    private final Date timestamp;
    @NotNull
    private final List<DiscardedEvent> discardedEvents;
    @Nullable
    private Map<String, Object> unknown;
    
    public ClientReport(@NotNull final Date timestamp, @NotNull final List<DiscardedEvent> discardedEvents) {
        this.timestamp = timestamp;
        this.discardedEvents = discardedEvents;
    }
    
    @NotNull
    public Date getTimestamp() {
        return this.timestamp;
    }
    
    @NotNull
    public List<DiscardedEvent> getDiscardedEvents() {
        return this.discardedEvents;
    }
    
    @Nullable
    @Override
    public Map<String, Object> getUnknown() {
        return this.unknown;
    }
    
    @Override
    public void setUnknown(@Nullable final Map<String, Object> unknown) {
        this.unknown = unknown;
    }
    
    @Override
    public void serialize(@NotNull final ObjectWriter writer, @NotNull final ILogger logger) throws IOException {
        writer.beginObject();
        writer.name("timestamp").value(DateUtils.getTimestamp(this.timestamp));
        writer.name("discarded_events").value(logger, this.discardedEvents);
        if (this.unknown != null) {
            for (final String key : this.unknown.keySet()) {
                final Object value = this.unknown.get(key);
                writer.name(key).value(logger, value);
            }
        }
        writer.endObject();
    }
    
    public static final class JsonKeys
    {
        public static final String TIMESTAMP = "timestamp";
        public static final String DISCARDED_EVENTS = "discarded_events";
    }
    
    public static final class Deserializer implements JsonDeserializer<ClientReport>
    {
        @NotNull
        @Override
        public ClientReport deserialize(@NotNull final ObjectReader reader, @NotNull final ILogger logger) throws Exception {
            Date timestamp = null;
            final List<DiscardedEvent> discardedEvents = new ArrayList<DiscardedEvent>();
            Map<String, Object> unknown = null;
            reader.beginObject();
            while (reader.peek() == JsonToken.NAME) {
                final String nextName2;
                final String nextName = nextName2 = reader.nextName();
                switch (nextName2) {
                    case "timestamp": {
                        timestamp = reader.nextDateOrNull(logger);
                        continue;
                    }
                    case "discarded_events": {
                        final List<DiscardedEvent> deserializedDiscardedEvents = reader.nextListOrNull(logger, (JsonDeserializer<DiscardedEvent>)new DiscardedEvent.Deserializer());
                        discardedEvents.addAll(deserializedDiscardedEvents);
                        continue;
                    }
                    default: {
                        if (unknown == null) {
                            unknown = new HashMap<String, Object>();
                        }
                        reader.nextUnknown(logger, unknown, nextName);
                        continue;
                    }
                }
            }
            reader.endObject();
            if (timestamp == null) {
                throw this.missingRequiredFieldException("timestamp", logger);
            }
            if (discardedEvents.isEmpty()) {
                throw this.missingRequiredFieldException("discarded_events", logger);
            }
            final ClientReport clientReport = new ClientReport(timestamp, discardedEvents);
            clientReport.setUnknown(unknown);
            return clientReport;
        }
        
        private Exception missingRequiredFieldException(final String field, final ILogger logger) {
            final String message = "Missing required field \"" + field + "\"";
            final Exception exception = new IllegalStateException(message);
            logger.log(SentryLevel.ERROR, message, exception);
            return exception;
        }
    }
}
