Rabbit-R1/original r1/smali/smali_classes3/io/sentry/SentryClient.smali
2024-05-21 17:08:36 -04:00

3474 lines
92 KiB
Smali

.class public final Lio/sentry/SentryClient;
.super Ljava/lang/Object;
.source "SentryClient.java"
# interfaces
.implements Lio/sentry/ISentryClient;
.implements Lio/sentry/metrics/IMetricsClient;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/sentry/SentryClient$SortBreadcrumbsByDate;
}
.end annotation
# static fields
.field static final SENTRY_PROTOCOL_VERSION:Ljava/lang/String; = "7"
# instance fields
.field private enabled:Z
.field private final metricsAggregator:Lio/sentry/IMetricsAggregator;
.field private final options:Lio/sentry/SentryOptions;
.field private final random:Ljava/security/SecureRandom;
.field private final sortBreadcrumbsByDate:Lio/sentry/SentryClient$SortBreadcrumbsByDate;
.field private final transport:Lio/sentry/transport/ITransport;
# direct methods
.method constructor <init>(Lio/sentry/SentryOptions;)V
.locals 3
.line 52
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 44
new-instance v0, Lio/sentry/SentryClient$SortBreadcrumbsByDate;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lio/sentry/SentryClient$SortBreadcrumbsByDate;-><init>(Lio/sentry/SentryClient$1;)V
iput-object v0, p0, Lio/sentry/SentryClient;->sortBreadcrumbsByDate:Lio/sentry/SentryClient$SortBreadcrumbsByDate;
const-string v0, "SentryOptions is required."
.line 53
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lio/sentry/SentryOptions;
iput-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
const/4 v0, 0x1
iput-boolean v0, p0, Lio/sentry/SentryClient;->enabled:Z
.line 56
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getTransportFactory()Lio/sentry/ITransportFactory;
move-result-object v0
.line 57
instance-of v2, v0, Lio/sentry/NoOpTransportFactory;
if-eqz v2, :cond_0
.line 58
new-instance v0, Lio/sentry/AsyncHttpTransportFactory;
invoke-direct {v0}, Lio/sentry/AsyncHttpTransportFactory;-><init>()V
.line 59
invoke-virtual {p1, v0}, Lio/sentry/SentryOptions;->setTransportFactory(Lio/sentry/ITransportFactory;)V
.line 62
:cond_0
new-instance v2, Lio/sentry/RequestDetailsResolver;
invoke-direct {v2, p1}, Lio/sentry/RequestDetailsResolver;-><init>(Lio/sentry/SentryOptions;)V
.line 63
invoke-virtual {v2}, Lio/sentry/RequestDetailsResolver;->resolve()Lio/sentry/RequestDetails;
move-result-object v2
invoke-interface {v0, p1, v2}, Lio/sentry/ITransportFactory;->create(Lio/sentry/SentryOptions;Lio/sentry/RequestDetails;)Lio/sentry/transport/ITransport;
move-result-object v0
iput-object v0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 66
invoke-virtual {p1}, Lio/sentry/SentryOptions;->isEnableMetrics()Z
move-result v0
if-eqz v0, :cond_1
.line 67
new-instance v0, Lio/sentry/MetricsAggregator;
invoke-direct {v0, p1, p0}, Lio/sentry/MetricsAggregator;-><init>(Lio/sentry/SentryOptions;Lio/sentry/metrics/IMetricsClient;)V
goto :goto_0
.line 68
:cond_1
invoke-static {}, Lio/sentry/metrics/NoopMetricsAggregator;->getInstance()Lio/sentry/metrics/NoopMetricsAggregator;
move-result-object v0
:goto_0
iput-object v0, p0, Lio/sentry/SentryClient;->metricsAggregator:Lio/sentry/IMetricsAggregator;
.line 70
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getSampleRate()Ljava/lang/Double;
move-result-object p1
if-nez p1, :cond_2
goto :goto_1
:cond_2
new-instance v1, Ljava/security/SecureRandom;
invoke-direct {v1}, Ljava/security/SecureRandom;-><init>()V
:goto_1
iput-object v1, p0, Lio/sentry/SentryClient;->random:Ljava/security/SecureRandom;
return-void
.end method
.method private addScopeAttachmentsToHint(Lio/sentry/IScope;Lio/sentry/Hint;)V
.locals 0
if-eqz p1, :cond_0
.line 259
invoke-interface {p1}, Lio/sentry/IScope;->getAttachments()Ljava/util/List;
move-result-object p0
invoke-virtual {p2, p0}, Lio/sentry/Hint;->addAttachments(Ljava/util/List;)V
:cond_0
return-void
.end method
.method private applyScope(Lio/sentry/CheckIn;Lio/sentry/IScope;)Lio/sentry/CheckIn;
.locals 1
if-eqz p2, :cond_1
.line 817
invoke-interface {p2}, Lio/sentry/IScope;->getSpan()Lio/sentry/ISpan;
move-result-object p0
.line 818
invoke-virtual {p1}, Lio/sentry/CheckIn;->getContexts()Lio/sentry/MonitorContexts;
move-result-object v0
invoke-virtual {v0}, Lio/sentry/MonitorContexts;->getTrace()Lio/sentry/SpanContext;
move-result-object v0
if-nez v0, :cond_1
if-nez p0, :cond_0
.line 821
invoke-virtual {p1}, Lio/sentry/CheckIn;->getContexts()Lio/sentry/MonitorContexts;
move-result-object p0
.line 822
invoke-interface {p2}, Lio/sentry/IScope;->getPropagationContext()Lio/sentry/PropagationContext;
move-result-object p2
invoke-static {p2}, Lio/sentry/TransactionContext;->fromPropagationContext(Lio/sentry/PropagationContext;)Lio/sentry/TransactionContext;
move-result-object p2
invoke-virtual {p0, p2}, Lio/sentry/MonitorContexts;->setTrace(Lio/sentry/SpanContext;)V
goto :goto_0
.line 824
:cond_0
invoke-virtual {p1}, Lio/sentry/CheckIn;->getContexts()Lio/sentry/MonitorContexts;
move-result-object p2
invoke-interface {p0}, Lio/sentry/ISpan;->getSpanContext()Lio/sentry/SpanContext;
move-result-object p0
invoke-virtual {p2, p0}, Lio/sentry/MonitorContexts;->setTrace(Lio/sentry/SpanContext;)V
:cond_1
:goto_0
return-object p1
.end method
.method private applyScope(Lio/sentry/SentryBaseEvent;Lio/sentry/IScope;)Lio/sentry/SentryBaseEvent;
.locals 4
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Lio/sentry/SentryBaseEvent;",
">(TT;",
"Lio/sentry/IScope;",
")TT;"
}
.end annotation
if-eqz p2, :cond_a
.line 834
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getRequest()Lio/sentry/protocol/Request;
move-result-object v0
if-nez v0, :cond_0
.line 835
invoke-interface {p2}, Lio/sentry/IScope;->getRequest()Lio/sentry/protocol/Request;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/SentryBaseEvent;->setRequest(Lio/sentry/protocol/Request;)V
.line 837
:cond_0
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getUser()Lio/sentry/protocol/User;
move-result-object v0
if-nez v0, :cond_1
.line 838
invoke-interface {p2}, Lio/sentry/IScope;->getUser()Lio/sentry/protocol/User;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/SentryBaseEvent;->setUser(Lio/sentry/protocol/User;)V
.line 840
:cond_1
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getTags()Ljava/util/Map;
move-result-object v0
if-nez v0, :cond_2
.line 841
new-instance v0, Ljava/util/HashMap;
invoke-interface {p2}, Lio/sentry/IScope;->getTags()Ljava/util/Map;
move-result-object v1
invoke-direct {v0, v1}, Ljava/util/HashMap;-><init>(Ljava/util/Map;)V
invoke-virtual {p1, v0}, Lio/sentry/SentryBaseEvent;->setTags(Ljava/util/Map;)V
goto :goto_1
.line 843
:cond_2
invoke-interface {p2}, Lio/sentry/IScope;->getTags()Ljava/util/Map;
move-result-object v0
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_3
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_4
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 844
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getTags()Ljava/util/Map;
move-result-object v2
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
invoke-interface {v2, v3}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_3
.line 845
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getTags()Ljava/util/Map;
move-result-object v2
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-interface {v2, v3, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_0
.line 849
:cond_4
:goto_1
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getBreadcrumbs()Ljava/util/List;
move-result-object v0
if-nez v0, :cond_5
.line 850
new-instance p0, Ljava/util/ArrayList;
invoke-interface {p2}, Lio/sentry/IScope;->getBreadcrumbs()Ljava/util/Queue;
move-result-object v0
invoke-direct {p0, v0}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
invoke-virtual {p1, p0}, Lio/sentry/SentryBaseEvent;->setBreadcrumbs(Ljava/util/List;)V
goto :goto_2
.line 852
:cond_5
invoke-interface {p2}, Lio/sentry/IScope;->getBreadcrumbs()Ljava/util/Queue;
move-result-object v0
invoke-direct {p0, p1, v0}, Lio/sentry/SentryClient;->sortBreadcrumbsByDate(Lio/sentry/SentryBaseEvent;Ljava/util/Collection;)V
.line 854
:goto_2
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getExtras()Ljava/util/Map;
move-result-object p0
if-nez p0, :cond_6
.line 855
new-instance p0, Ljava/util/HashMap;
invoke-interface {p2}, Lio/sentry/IScope;->getExtras()Ljava/util/Map;
move-result-object v0
invoke-direct {p0, v0}, Ljava/util/HashMap;-><init>(Ljava/util/Map;)V
invoke-virtual {p1, p0}, Lio/sentry/SentryBaseEvent;->setExtras(Ljava/util/Map;)V
goto :goto_4
.line 857
:cond_6
invoke-interface {p2}, Lio/sentry/IScope;->getExtras()Ljava/util/Map;
move-result-object p0
invoke-interface {p0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object p0
invoke-interface {p0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object p0
:cond_7
:goto_3
invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_8
invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Map$Entry;
.line 858
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getExtras()Ljava/util/Map;
move-result-object v1
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v2
invoke-interface {v1, v2}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_7
.line 859
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getExtras()Ljava/util/Map;
move-result-object v1
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
invoke-interface {v0}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v0
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_3
.line 863
:cond_8
:goto_4
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getContexts()Lio/sentry/protocol/Contexts;
move-result-object p0
.line 864
new-instance v0, Lio/sentry/protocol/Contexts;
invoke-interface {p2}, Lio/sentry/IScope;->getContexts()Lio/sentry/protocol/Contexts;
move-result-object p2
invoke-direct {v0, p2}, Lio/sentry/protocol/Contexts;-><init>(Lio/sentry/protocol/Contexts;)V
invoke-virtual {v0}, Lio/sentry/protocol/Contexts;->entrySet()Ljava/util/Set;
move-result-object p2
invoke-interface {p2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object p2
:cond_9
:goto_5
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_a
invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Map$Entry;
.line 865
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
invoke-virtual {p0, v1}, Lio/sentry/protocol/Contexts;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_9
.line 866
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-interface {v0}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v0
invoke-virtual {p0, v1, v0}, Lio/sentry/protocol/Contexts;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_5
:cond_a
return-object p1
.end method
.method private applyScope(Lio/sentry/SentryEvent;Lio/sentry/IScope;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
.locals 2
if-eqz p2, :cond_5
.line 785
invoke-direct {p0, p1, p2}, Lio/sentry/SentryClient;->applyScope(Lio/sentry/SentryBaseEvent;Lio/sentry/IScope;)Lio/sentry/SentryBaseEvent;
.line 787
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getTransaction()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_0
.line 788
invoke-interface {p2}, Lio/sentry/IScope;->getTransactionName()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/SentryEvent;->setTransaction(Ljava/lang/String;)V
.line 790
:cond_0
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getFingerprints()Ljava/util/List;
move-result-object v0
if-nez v0, :cond_1
.line 791
invoke-interface {p2}, Lio/sentry/IScope;->getFingerprint()Ljava/util/List;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/SentryEvent;->setFingerprints(Ljava/util/List;)V
.line 794
:cond_1
invoke-interface {p2}, Lio/sentry/IScope;->getLevel()Lio/sentry/SentryLevel;
move-result-object v0
if-eqz v0, :cond_2
.line 795
invoke-interface {p2}, Lio/sentry/IScope;->getLevel()Lio/sentry/SentryLevel;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/SentryEvent;->setLevel(Lio/sentry/SentryLevel;)V
.line 798
:cond_2
invoke-interface {p2}, Lio/sentry/IScope;->getSpan()Lio/sentry/ISpan;
move-result-object v0
.line 799
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getContexts()Lio/sentry/protocol/Contexts;
move-result-object v1
invoke-virtual {v1}, Lio/sentry/protocol/Contexts;->getTrace()Lio/sentry/SpanContext;
move-result-object v1
if-nez v1, :cond_4
if-nez v0, :cond_3
.line 802
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getContexts()Lio/sentry/protocol/Contexts;
move-result-object v0
.line 803
invoke-interface {p2}, Lio/sentry/IScope;->getPropagationContext()Lio/sentry/PropagationContext;
move-result-object v1
invoke-static {v1}, Lio/sentry/TransactionContext;->fromPropagationContext(Lio/sentry/PropagationContext;)Lio/sentry/TransactionContext;
move-result-object v1
invoke-virtual {v0, v1}, Lio/sentry/protocol/Contexts;->setTrace(Lio/sentry/SpanContext;)V
goto :goto_0
.line 805
:cond_3
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getContexts()Lio/sentry/protocol/Contexts;
move-result-object v1
invoke-interface {v0}, Lio/sentry/ISpan;->getSpanContext()Lio/sentry/SpanContext;
move-result-object v0
invoke-virtual {v1, v0}, Lio/sentry/protocol/Contexts;->setTrace(Lio/sentry/SpanContext;)V
.line 809
:cond_4
:goto_0
invoke-interface {p2}, Lio/sentry/IScope;->getEventProcessors()Ljava/util/List;
move-result-object p2
invoke-direct {p0, p1, p3, p2}, Lio/sentry/SentryClient;->processEvent(Lio/sentry/SentryEvent;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/SentryEvent;
move-result-object p1
:cond_5
return-object p1
.end method
.method private buildEnvelope(Lio/sentry/CheckIn;Lio/sentry/TraceContext;)Lio/sentry/SentryEnvelope;
.locals 2
.line 484
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 487
invoke-virtual {v1}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object v1
invoke-static {v1, p1}, Lio/sentry/SentryEnvelopeItem;->fromCheckIn(Lio/sentry/ISerializer;Lio/sentry/CheckIn;)Lio/sentry/SentryEnvelopeItem;
move-result-object v1
.line 488
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 490
new-instance v1, Lio/sentry/SentryEnvelopeHeader;
.line 491
invoke-virtual {p1}, Lio/sentry/CheckIn;->getCheckInId()Lio/sentry/protocol/SentryId;
move-result-object p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSdkVersion()Lio/sentry/protocol/SdkVersion;
move-result-object p0
invoke-direct {v1, p1, p0, p2}, Lio/sentry/SentryEnvelopeHeader;-><init>(Lio/sentry/protocol/SentryId;Lio/sentry/protocol/SdkVersion;Lio/sentry/TraceContext;)V
.line 493
new-instance p0, Lio/sentry/SentryEnvelope;
invoke-direct {p0, v1, v0}, Lio/sentry/SentryEnvelope;-><init>(Lio/sentry/SentryEnvelopeHeader;Ljava/lang/Iterable;)V
return-object p0
.end method
.method private buildEnvelope(Lio/sentry/SentryBaseEvent;Ljava/util/List;Lio/sentry/Session;Lio/sentry/TraceContext;Lio/sentry/ProfilingTraceData;)Lio/sentry/SentryEnvelope;
.locals 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/sentry/SentryBaseEvent;",
"Ljava/util/List<",
"Lio/sentry/Attachment;",
">;",
"Lio/sentry/Session;",
"Lio/sentry/TraceContext;",
"Lio/sentry/ProfilingTraceData;",
")",
"Lio/sentry/SentryEnvelope;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;,
Lio/sentry/exception/SentryEnvelopeException;
}
.end annotation
.line 319
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
const/4 v1, 0x0
if-eqz p1, :cond_0
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 323
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object v2
invoke-static {v2, p1}, Lio/sentry/SentryEnvelopeItem;->fromEvent(Lio/sentry/ISerializer;Lio/sentry/SentryBaseEvent;)Lio/sentry/SentryEnvelopeItem;
move-result-object v2
.line 324
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 325
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
goto :goto_0
:cond_0
move-object p1, v1
:goto_0
if-eqz p3, :cond_1
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 330
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object v2
invoke-static {v2, p3}, Lio/sentry/SentryEnvelopeItem;->fromSession(Lio/sentry/ISerializer;Lio/sentry/Session;)Lio/sentry/SentryEnvelopeItem;
move-result-object p3
.line 331
invoke-interface {v0, p3}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:cond_1
if-eqz p5, :cond_2
iget-object p3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 337
invoke-virtual {p3}, Lio/sentry/SentryOptions;->getMaxTraceFileSize()J
move-result-wide v2
iget-object p3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
invoke-virtual {p3}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object p3
.line 336
invoke-static {p5, v2, v3, p3}, Lio/sentry/SentryEnvelopeItem;->fromProfilingTrace(Lio/sentry/ProfilingTraceData;JLio/sentry/ISerializer;)Lio/sentry/SentryEnvelopeItem;
move-result-object p3
.line 338
invoke-interface {v0, p3}, Ljava/util/List;->add(Ljava/lang/Object;)Z
if-nez p1, :cond_2
.line 341
new-instance p1, Lio/sentry/protocol/SentryId;
invoke-virtual {p5}, Lio/sentry/ProfilingTraceData;->getProfileId()Ljava/lang/String;
move-result-object p3
invoke-direct {p1, p3}, Lio/sentry/protocol/SentryId;-><init>(Ljava/lang/String;)V
:cond_2
if-eqz p2, :cond_3
.line 346
invoke-interface {p2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p2
:goto_1
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result p3
if-eqz p3, :cond_3
invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object p3
check-cast p3, Lio/sentry/Attachment;
iget-object p5, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 349
invoke-virtual {p5}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object p5
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 350
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v2
iget-object v3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 352
invoke-virtual {v3}, Lio/sentry/SentryOptions;->getMaxAttachmentSize()J
move-result-wide v3
.line 348
invoke-static {p5, v2, p3, v3, v4}, Lio/sentry/SentryEnvelopeItem;->fromAttachment(Lio/sentry/ISerializer;Lio/sentry/ILogger;Lio/sentry/Attachment;J)Lio/sentry/SentryEnvelopeItem;
move-result-object p3
.line 353
invoke-interface {v0, p3}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_1
.line 357
:cond_3
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result p2
if-nez p2, :cond_4
.line 358
new-instance p2, Lio/sentry/SentryEnvelopeHeader;
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 359
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSdkVersion()Lio/sentry/protocol/SdkVersion;
move-result-object p0
invoke-direct {p2, p1, p0, p4}, Lio/sentry/SentryEnvelopeHeader;-><init>(Lio/sentry/protocol/SentryId;Lio/sentry/protocol/SdkVersion;Lio/sentry/TraceContext;)V
.line 361
new-instance p0, Lio/sentry/SentryEnvelope;
invoke-direct {p0, p2, v0}, Lio/sentry/SentryEnvelope;-><init>(Lio/sentry/SentryEnvelopeHeader;Ljava/lang/Iterable;)V
return-object p0
:cond_4
return-object v1
.end method
.method private buildEnvelope(Lio/sentry/UserFeedback;)Lio/sentry/SentryEnvelope;
.locals 2
.line 470
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 473
invoke-virtual {v1}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object v1
invoke-static {v1, p1}, Lio/sentry/SentryEnvelopeItem;->fromUserFeedback(Lio/sentry/ISerializer;Lio/sentry/UserFeedback;)Lio/sentry/SentryEnvelopeItem;
move-result-object v1
.line 474
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 476
new-instance v1, Lio/sentry/SentryEnvelopeHeader;
.line 477
invoke-virtual {p1}, Lio/sentry/UserFeedback;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSdkVersion()Lio/sentry/protocol/SdkVersion;
move-result-object p0
invoke-direct {v1, p1, p0}, Lio/sentry/SentryEnvelopeHeader;-><init>(Lio/sentry/protocol/SentryId;Lio/sentry/protocol/SdkVersion;)V
.line 479
new-instance p0, Lio/sentry/SentryEnvelope;
invoke-direct {p0, v1, v0}, Lio/sentry/SentryEnvelope;-><init>(Lio/sentry/SentryEnvelopeHeader;Ljava/lang/Iterable;)V
return-object p0
.end method
.method private executeBeforeSend(Lio/sentry/SentryEvent;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
.locals 1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 885
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getBeforeSend()Lio/sentry/SentryOptions$BeforeSendCallback;
move-result-object v0
if-eqz v0, :cond_0
.line 888
:try_start_0
invoke-interface {v0, p1, p2}, Lio/sentry/SentryOptions$BeforeSendCallback;->execute(Lio/sentry/SentryEvent;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
move-result-object p1
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 891
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v0, "The BeforeSend callback threw an exception. It will be added as breadcrumb and continue."
.line 892
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 p1, 0x0
:cond_0
:goto_0
return-object p1
.end method
.method private executeBeforeSendTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;)Lio/sentry/protocol/SentryTransaction;
.locals 1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 907
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getBeforeSendTransaction()Lio/sentry/SentryOptions$BeforeSendTransactionCallback;
move-result-object v0
if-eqz v0, :cond_0
.line 910
:try_start_0
invoke-interface {v0, p1, p2}, Lio/sentry/SentryOptions$BeforeSendTransactionCallback;->execute(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;)Lio/sentry/protocol/SentryTransaction;
move-result-object p1
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 913
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v0, "The BeforeSendTransaction callback threw an exception. It will be added as breadcrumb and continue."
.line 914
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 p1, 0x0
:cond_0
:goto_0
return-object p1
.end method
.method private filterForTransaction(Ljava/util/List;)Ljava/util/List;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lio/sentry/Attachment;",
">;)",
"Ljava/util/List<",
"Lio/sentry/Attachment;",
">;"
}
.end annotation
if-nez p1, :cond_0
const/4 p0, 0x0
return-object p0
.line 772
:cond_0
new-instance p0, Ljava/util/ArrayList;
invoke-direct {p0}, Ljava/util/ArrayList;-><init>()V
.line 773
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:cond_1
:goto_0
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lio/sentry/Attachment;
.line 774
invoke-virtual {v0}, Lio/sentry/Attachment;->isAddToTransactions()Z
move-result v1
if-eqz v1, :cond_1
.line 775
invoke-interface {p0, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_0
:cond_2
return-object p0
.end method
.method private getAttachments(Lio/sentry/Hint;)Ljava/util/List;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/sentry/Hint;",
")",
"Ljava/util/List<",
"Lio/sentry/Attachment;",
">;"
}
.end annotation
.line 290
invoke-virtual {p1}, Lio/sentry/Hint;->getAttachments()Ljava/util/List;
move-result-object p0
.line 292
invoke-virtual {p1}, Lio/sentry/Hint;->getScreenshot()Lio/sentry/Attachment;
move-result-object v0
if-eqz v0, :cond_0
.line 294
invoke-interface {p0, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 297
:cond_0
invoke-virtual {p1}, Lio/sentry/Hint;->getViewHierarchy()Lio/sentry/Attachment;
move-result-object v0
if-eqz v0, :cond_1
.line 299
invoke-interface {p0, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 302
:cond_1
invoke-virtual {p1}, Lio/sentry/Hint;->getThreadDump()Lio/sentry/Attachment;
move-result-object p1
if-eqz p1, :cond_2
.line 304
invoke-interface {p0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:cond_2
return-object p0
.end method
.method static synthetic lambda$captureEvent$0(Lio/sentry/Session;)V
.locals 0
return-void
.end method
.method private processEvent(Lio/sentry/SentryEvent;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/SentryEvent;
.locals 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/sentry/SentryEvent;",
"Lio/sentry/Hint;",
"Ljava/util/List<",
"Lio/sentry/EventProcessor;",
">;)",
"Lio/sentry/SentryEvent;"
}
.end annotation
.line 372
invoke-interface {p3}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p3
:cond_0
invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_3
invoke-interface {p3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lio/sentry/EventProcessor;
.line 376
:try_start_0
instance-of v1, v0, Lio/sentry/BackfillingEventProcessor;
.line 377
const-class v2, Lio/sentry/hints/Backfillable;
invoke-static {p2, v2}, Lio/sentry/util/HintUtils;->hasType(Lio/sentry/Hint;Ljava/lang/Class;)Z
move-result v2
if-eqz v2, :cond_1
if-eqz v1, :cond_1
.line 379
invoke-interface {v0, p1, p2}, Lio/sentry/EventProcessor;->process(Lio/sentry/SentryEvent;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
move-result-object p1
goto :goto_0
:cond_1
if-nez v2, :cond_2
if-nez v1, :cond_2
.line 381
invoke-interface {v0, p1, p2}, Lio/sentry/EventProcessor;->process(Lio/sentry/SentryEvent;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
move-result-object p1
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception v1
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 385
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v2
sget-object v3, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
.line 390
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v4
filled-new-array {v4}, [Ljava/lang/Object;
move-result-object v4
const-string v5, "An exception occurred while processing event by processor: %s"
.line 386
invoke-interface {v2, v3, v1, v5, v4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_2
:goto_0
if-nez p1, :cond_0
iget-object p2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 395
invoke-virtual {p2}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p2
sget-object p3, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 399
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
filled-new-array {v0}, [Ljava/lang/Object;
move-result-object v0
const-string v1, "Event was dropped by a processor: %s"
.line 396
invoke-interface {p2, p3, v1, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 401
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object p0
sget-object p2, Lio/sentry/clientreport/DiscardReason;->EVENT_PROCESSOR:Lio/sentry/clientreport/DiscardReason;
sget-object p3, Lio/sentry/DataCategory;->Error:Lio/sentry/DataCategory;
.line 402
invoke-interface {p0, p2, p3}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
:cond_3
return-object p1
.end method
.method private processTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/protocol/SentryTransaction;
.locals 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/sentry/protocol/SentryTransaction;",
"Lio/sentry/Hint;",
"Ljava/util/List<",
"Lio/sentry/EventProcessor;",
">;)",
"Lio/sentry/protocol/SentryTransaction;"
}
.end annotation
.line 414
invoke-interface {p3}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p3
:cond_0
invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_1
invoke-interface {p3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lio/sentry/EventProcessor;
.line 416
:try_start_0
invoke-interface {v0, p1, p2}, Lio/sentry/EventProcessor;->process(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;)Lio/sentry/protocol/SentryTransaction;
move-result-object p1
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception v1
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 419
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v2
sget-object v3, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
.line 424
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v4
filled-new-array {v4}, [Ljava/lang/Object;
move-result-object v4
const-string v5, "An exception occurred while processing transaction by processor: %s"
.line 420
invoke-interface {v2, v3, v1, v5, v4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
if-nez p1, :cond_0
iget-object p2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 429
invoke-virtual {p2}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p2
sget-object p3, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 433
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
filled-new-array {v0}, [Ljava/lang/Object;
move-result-object v0
const-string v1, "Transaction was dropped by a processor: %s"
.line 430
invoke-interface {p2, p3, v1, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 435
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object p0
sget-object p2, Lio/sentry/clientreport/DiscardReason;->EVENT_PROCESSOR:Lio/sentry/clientreport/DiscardReason;
sget-object p3, Lio/sentry/DataCategory;->Transaction:Lio/sentry/DataCategory;
.line 436
invoke-interface {p0, p2, p3}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
:cond_1
return-object p1
.end method
.method private sample()Z
.locals 6
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 982
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getSampleRate()Ljava/lang/Double;
move-result-object v0
const/4 v1, 0x1
if-eqz v0, :cond_1
iget-object v0, p0, Lio/sentry/SentryClient;->random:Ljava/security/SecureRandom;
if-eqz v0, :cond_1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 983
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getSampleRate()Ljava/lang/Double;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Double;->doubleValue()D
move-result-wide v2
iget-object p0, p0, Lio/sentry/SentryClient;->random:Ljava/security/SecureRandom;
.line 984
invoke-virtual {p0}, Ljava/security/SecureRandom;->nextDouble()D
move-result-wide v4
cmpg-double p0, v2, v4
if-ltz p0, :cond_0
goto :goto_0
:cond_0
const/4 v1, 0x0
:cond_1
:goto_0
return v1
.end method
.method private sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
.locals 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 603
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getBeforeEnvelopeCallback()Lio/sentry/SentryOptions$BeforeEnvelopeCallback;
move-result-object v0
if-eqz v0, :cond_0
.line 606
:try_start_0
invoke-interface {v0, p1, p2}, Lio/sentry/SentryOptions$BeforeEnvelopeCallback;->execute(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)V
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception v0
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 609
invoke-virtual {v1}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v1
sget-object v2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v3, "The BeforeEnvelope callback threw an exception."
.line 610
invoke-interface {v1, v2, v3, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_0
:goto_0
if-nez p2, :cond_1
iget-object p0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 614
invoke-interface {p0, p1}, Lio/sentry/transport/ITransport;->send(Lio/sentry/SentryEnvelope;)V
goto :goto_1
:cond_1
iget-object p0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 616
invoke-interface {p0, p1, p2}, Lio/sentry/transport/ITransport;->send(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)V
.line 618
:goto_1
invoke-virtual {p1}, Lio/sentry/SentryEnvelope;->getHeader()Lio/sentry/SentryEnvelopeHeader;
move-result-object p0
invoke-virtual {p0}, Lio/sentry/SentryEnvelopeHeader;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p0
if-eqz p0, :cond_2
goto :goto_2
.line 619
:cond_2
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
:goto_2
return-object p0
.end method
.method private shouldApplyScopeData(Lio/sentry/CheckIn;Lio/sentry/Hint;)Z
.locals 1
.line 86
invoke-static {p2}, Lio/sentry/util/HintUtils;->shouldApplyScopeData(Lio/sentry/Hint;)Z
move-result p2
if-eqz p2, :cond_0
const/4 p0, 0x1
return p0
:cond_0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 90
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 94
invoke-virtual {p1}, Lio/sentry/CheckIn;->getCheckInId()Lio/sentry/protocol/SentryId;
move-result-object p1
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
const-string v0, "Check-in was cached so not applying scope: %s"
.line 91
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 p0, 0x0
return p0
.end method
.method private shouldApplyScopeData(Lio/sentry/SentryBaseEvent;Lio/sentry/Hint;)Z
.locals 1
.line 75
invoke-static {p2}, Lio/sentry/util/HintUtils;->shouldApplyScopeData(Lio/sentry/Hint;)Z
move-result p2
if-eqz p2, :cond_0
const/4 p0, 0x1
return p0
:cond_0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 79
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 80
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
const-string v0, "Event was cached so not applying scope: %s"
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 p0, 0x0
return p0
.end method
.method private shouldSendSessionUpdateForDroppedEvent(Lio/sentry/Session;Lio/sentry/Session;)Z
.locals 3
const/4 p0, 0x0
if-nez p2, :cond_0
return p0
:cond_0
const/4 v0, 0x1
if-nez p1, :cond_1
return v0
.line 274
:cond_1
invoke-virtual {p2}, Lio/sentry/Session;->getStatus()Lio/sentry/Session$State;
move-result-object v1
sget-object v2, Lio/sentry/Session$State;->Crashed:Lio/sentry/Session$State;
if-ne v1, v2, :cond_2
.line 275
invoke-virtual {p1}, Lio/sentry/Session;->getStatus()Lio/sentry/Session$State;
move-result-object v1
sget-object v2, Lio/sentry/Session$State;->Crashed:Lio/sentry/Session$State;
if-eq v1, v2, :cond_2
return v0
.line 281
:cond_2
invoke-virtual {p2}, Lio/sentry/Session;->errorCount()I
move-result p2
if-lez p2, :cond_3
invoke-virtual {p1}, Lio/sentry/Session;->errorCount()I
move-result p1
if-gtz p1, :cond_3
return v0
:cond_3
return p0
.end method
.method private sortBreadcrumbsByDate(Lio/sentry/SentryBaseEvent;Ljava/util/Collection;)V
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/sentry/SentryBaseEvent;",
"Ljava/util/Collection<",
"Lio/sentry/Breadcrumb;",
">;)V"
}
.end annotation
.line 875
invoke-virtual {p1}, Lio/sentry/SentryBaseEvent;->getBreadcrumbs()Ljava/util/List;
move-result-object p1
if-eqz p1, :cond_0
.line 877
invoke-interface {p2}, Ljava/util/Collection;->isEmpty()Z
move-result v0
if-nez v0, :cond_0
.line 878
invoke-interface {p1, p2}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
iget-object p0, p0, Lio/sentry/SentryClient;->sortBreadcrumbsByDate:Lio/sentry/SentryClient$SortBreadcrumbsByDate;
.line 879
invoke-static {p1, p0}, Ljava/util/Collections;->sort(Ljava/util/List;Ljava/util/Comparator;)V
:cond_0
return-void
.end method
# virtual methods
.method public captureCheckIn(Lio/sentry/CheckIn;Lio/sentry/IScope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
.locals 4
if-nez p3, :cond_0
.line 708
new-instance p3, Lio/sentry/Hint;
invoke-direct {p3}, Lio/sentry/Hint;-><init>()V
.line 711
:cond_0
invoke-virtual {p1}, Lio/sentry/CheckIn;->getEnvironment()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 712
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getEnvironment()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/CheckIn;->setEnvironment(Ljava/lang/String;)V
.line 715
:cond_1
invoke-virtual {p1}, Lio/sentry/CheckIn;->getRelease()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_2
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 716
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getRelease()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Lio/sentry/CheckIn;->setRelease(Ljava/lang/String;)V
.line 719
:cond_2
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->shouldApplyScopeData(Lio/sentry/CheckIn;Lio/sentry/Hint;)Z
move-result v0
if-eqz v0, :cond_3
.line 720
invoke-direct {p0, p1, p2}, Lio/sentry/SentryClient;->applyScope(Lio/sentry/CheckIn;Lio/sentry/IScope;)Lio/sentry/CheckIn;
move-result-object p1
:cond_3
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 723
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getIgnoredCheckIns()Ljava/util/List;
move-result-object v0
invoke-virtual {p1}, Lio/sentry/CheckIn;->getMonitorSlug()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lio/sentry/util/CheckInUtils;->isIgnored(Ljava/util/List;Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_4
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 725
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 729
invoke-virtual {p1}, Lio/sentry/CheckIn;->getMonitorSlug()Ljava/lang/String;
move-result-object p1
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
const-string p3, "Check-in was dropped as slug %s is ignored"
.line 726
invoke-interface {p0, p2, p3, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 734
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
:cond_4
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 737
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
invoke-virtual {p1}, Lio/sentry/CheckIn;->getCheckInId()Lio/sentry/protocol/SentryId;
move-result-object v2
filled-new-array {v2}, [Ljava/lang/Object;
move-result-object v2
const-string v3, "Capturing check-in: %s"
invoke-interface {v0, v1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 739
invoke-virtual {p1}, Lio/sentry/CheckIn;->getCheckInId()Lio/sentry/protocol/SentryId;
move-result-object v0
if-eqz p2, :cond_6
.line 744
:try_start_0
invoke-interface {p2}, Lio/sentry/IScope;->getTransaction()Lio/sentry/ITransaction;
move-result-object v1
if-eqz v1, :cond_5
.line 746
invoke-interface {v1}, Lio/sentry/ITransaction;->traceContext()Lio/sentry/TraceContext;
move-result-object p2
goto :goto_0
:cond_5
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 749
invoke-static {p2, v1}, Lio/sentry/util/TracingUtils;->maybeUpdateBaggage(Lio/sentry/IScope;Lio/sentry/SentryOptions;)Lio/sentry/PropagationContext;
move-result-object p2
.line 750
invoke-virtual {p2}, Lio/sentry/PropagationContext;->traceContext()Lio/sentry/TraceContext;
move-result-object p2
goto :goto_0
:cond_6
const/4 p2, 0x0
.line 754
:goto_0
invoke-direct {p0, p1, p2}, Lio/sentry/SentryClient;->buildEnvelope(Lio/sentry/CheckIn;Lio/sentry/TraceContext;)Lio/sentry/SentryEnvelope;
move-result-object p1
.line 756
invoke-virtual {p3}, Lio/sentry/Hint;->clear()V
.line 757
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
move-result-object p0
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_1
:catch_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 759
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string p3, "Capturing check-in %s failed."
filled-new-array {v0}, [Ljava/lang/Object;
move-result-object v0
invoke-interface {p0, p2, p1, p3, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
.line 761
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
:goto_1
return-object p0
.end method
.method public captureEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
.locals 1
const-string v0, "SentryEnvelope is required."
.line 585
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
if-nez p2, :cond_0
.line 588
new-instance p2, Lio/sentry/Hint;
invoke-direct {p2}, Lio/sentry/Hint;-><init>()V
.line 592
:cond_0
:try_start_0
invoke-virtual {p2}, Lio/sentry/Hint;->clear()V
.line 593
invoke-direct {p0, p1, p2}, Lio/sentry/SentryClient;->sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
move-result-object p0
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
return-object p0
:catch_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 595
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v0, "Failed to capture envelope."
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 597
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
.end method
.method public captureEvent(Lio/sentry/SentryEvent;Lio/sentry/IScope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
.locals 12
const-string v0, "SentryEvent is required."
.line 102
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
if-nez p3, :cond_0
.line 105
new-instance p3, Lio/sentry/Hint;
invoke-direct {p3}, Lio/sentry/Hint;-><init>()V
.line 108
:cond_0
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->shouldApplyScopeData(Lio/sentry/SentryBaseEvent;Lio/sentry/Hint;)Z
move-result v0
if-eqz v0, :cond_1
.line 109
invoke-direct {p0, p2, p3}, Lio/sentry/SentryClient;->addScopeAttachmentsToHint(Lio/sentry/IScope;Lio/sentry/Hint;)V
:cond_1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 112
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v2
filled-new-array {v2}, [Ljava/lang/Object;
move-result-object v2
const-string v3, "Capturing event: %s"
invoke-interface {v0, v1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
if-eqz p1, :cond_2
.line 115
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getThrowable()Ljava/lang/Throwable;
move-result-object v0
if-eqz v0, :cond_2
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 116
invoke-virtual {v1, v0}, Lio/sentry/SentryOptions;->containsIgnoredExceptionForType(Ljava/lang/Throwable;)Z
move-result v1
if-eqz v1, :cond_2
iget-object p1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 118
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p1
sget-object p2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 122
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object p3
filled-new-array {p3}, [Ljava/lang/Object;
move-result-object p3
const-string v0, "Event was dropped as the exception %s is ignored"
.line 119
invoke-interface {p1, p2, v0, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 124
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object p0
sget-object p1, Lio/sentry/clientreport/DiscardReason;->EVENT_PROCESSOR:Lio/sentry/clientreport/DiscardReason;
sget-object p2, Lio/sentry/DataCategory;->Error:Lio/sentry/DataCategory;
.line 125
invoke-interface {p0, p1, p2}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
.line 126
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
.line 130
:cond_2
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->shouldApplyScopeData(Lio/sentry/SentryBaseEvent;Lio/sentry/Hint;)Z
move-result v0
const/4 v1, 0x0
if-eqz v0, :cond_3
.line 134
invoke-direct {p0, p1, p2, p3}, Lio/sentry/SentryClient;->applyScope(Lio/sentry/SentryEvent;Lio/sentry/IScope;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
move-result-object p1
if-nez p1, :cond_3
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 137
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string p2, "Event was dropped by applyScope"
new-array p3, v1, [Ljava/lang/Object;
invoke-interface {p0, p1, p2, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 138
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
:cond_3
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 142
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getEventProcessors()Ljava/util/List;
move-result-object v0
invoke-direct {p0, p1, p3, v0}, Lio/sentry/SentryClient;->processEvent(Lio/sentry/SentryEvent;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/SentryEvent;
move-result-object p1
if-eqz p1, :cond_4
.line 145
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->executeBeforeSend(Lio/sentry/SentryEvent;Lio/sentry/Hint;)Lio/sentry/SentryEvent;
move-result-object p1
if-nez p1, :cond_4
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 148
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string v3, "Event was dropped by beforeSend"
new-array v4, v1, [Ljava/lang/Object;
invoke-interface {v0, v2, v3, v4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 150
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object v0
sget-object v2, Lio/sentry/clientreport/DiscardReason;->BEFORE_SEND:Lio/sentry/clientreport/DiscardReason;
sget-object v3, Lio/sentry/DataCategory;->Error:Lio/sentry/DataCategory;
.line 151
invoke-interface {v0, v2, v3}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
:cond_4
if-nez p1, :cond_5
.line 156
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
:cond_5
const/4 v0, 0x0
if-eqz p2, :cond_6
.line 161
new-instance v2, Lio/sentry/SentryClient$$ExternalSyntheticLambda0;
invoke-direct {v2}, Lio/sentry/SentryClient$$ExternalSyntheticLambda0;-><init>()V
invoke-interface {p2, v2}, Lio/sentry/IScope;->withSession(Lio/sentry/Scope$IWithSession;)Lio/sentry/Session;
move-result-object v2
goto :goto_0
:cond_6
move-object v2, v0
:goto_0
if-eqz p1, :cond_a
if-eqz v2, :cond_8
.line 166
invoke-virtual {v2}, Lio/sentry/Session;->isTerminated()Z
move-result v3
if-nez v3, :cond_7
goto :goto_1
:cond_7
move-object v3, v0
goto :goto_2
.line 167
:cond_8
:goto_1
invoke-virtual {p0, p1, p3, p2}, Lio/sentry/SentryClient;->updateSessionData(Lio/sentry/SentryEvent;Lio/sentry/Hint;Lio/sentry/IScope;)Lio/sentry/Session;
move-result-object v3
.line 170
:goto_2
invoke-direct {p0}, Lio/sentry/SentryClient;->sample()Z
move-result v4
if-nez v4, :cond_9
iget-object v4, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 172
invoke-virtual {v4}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v4
sget-object v5, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 176
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
const-string v6, "Event %s was dropped due to sampling decision."
.line 173
invoke-interface {v4, v5, v6, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object p1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 178
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object p1
sget-object v4, Lio/sentry/clientreport/DiscardReason;->SAMPLE_RATE:Lio/sentry/clientreport/DiscardReason;
sget-object v5, Lio/sentry/DataCategory;->Error:Lio/sentry/DataCategory;
.line 179
invoke-interface {p1, v4, v5}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
move-object v7, v0
goto :goto_3
:cond_9
move-object v7, p1
:goto_3
move-object v9, v3
goto :goto_4
:cond_a
move-object v7, p1
move-object v9, v0
.line 186
:goto_4
invoke-direct {p0, v2, v9}, Lio/sentry/SentryClient;->shouldSendSessionUpdateForDroppedEvent(Lio/sentry/Session;Lio/sentry/Session;)Z
move-result p1
if-nez v7, :cond_b
if-nez p1, :cond_b
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 190
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string p2, "Not sending session update for dropped event as it did not cause the session health to change."
new-array p3, v1, [Ljava/lang/Object;
.line 191
invoke-interface {p0, p1, p2, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 194
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
.line 197
:cond_b
sget-object p1, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
if-eqz v7, :cond_c
.line 198
invoke-virtual {v7}, Lio/sentry/SentryEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v2
if-eqz v2, :cond_c
.line 199
invoke-virtual {v7}, Lio/sentry/SentryEvent;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
.line 204
:cond_c
:try_start_0
const-class v2, Lio/sentry/hints/Backfillable;
invoke-static {p3, v2}, Lio/sentry/util/HintUtils;->hasType(Lio/sentry/Hint;Ljava/lang/Class;)Z
move-result v2
if-eqz v2, :cond_d
if-eqz v7, :cond_f
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 207
invoke-static {v7, v2}, Lio/sentry/Baggage;->fromEvent(Lio/sentry/SentryEvent;Lio/sentry/SentryOptions;)Lio/sentry/Baggage;
move-result-object v2
.line 208
invoke-virtual {v2}, Lio/sentry/Baggage;->toTraceContext()Lio/sentry/TraceContext;
move-result-object v2
goto :goto_5
:cond_d
if-eqz p2, :cond_f
.line 211
invoke-interface {p2}, Lio/sentry/IScope;->getTransaction()Lio/sentry/ITransaction;
move-result-object v2
if-eqz v2, :cond_e
.line 213
invoke-interface {v2}, Lio/sentry/ITransaction;->traceContext()Lio/sentry/TraceContext;
move-result-object v2
:goto_5
move-object v10, v2
goto :goto_6
:cond_e
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 216
invoke-static {p2, v2}, Lio/sentry/util/TracingUtils;->maybeUpdateBaggage(Lio/sentry/IScope;Lio/sentry/SentryOptions;)Lio/sentry/PropagationContext;
move-result-object v2
.line 217
invoke-virtual {v2}, Lio/sentry/PropagationContext;->traceContext()Lio/sentry/TraceContext;
move-result-object v2
goto :goto_5
:cond_f
move-object v10, v0
:goto_6
if-eqz v7, :cond_10
.line 222
invoke-direct {p0, p3}, Lio/sentry/SentryClient;->getAttachments(Lio/sentry/Hint;)Ljava/util/List;
move-result-object v2
move-object v8, v2
goto :goto_7
:cond_10
move-object v8, v0
:goto_7
const/4 v11, 0x0
move-object v6, p0
.line 224
invoke-direct/range {v6 .. v11}, Lio/sentry/SentryClient;->buildEnvelope(Lio/sentry/SentryBaseEvent;Ljava/util/List;Lio/sentry/Session;Lio/sentry/TraceContext;Lio/sentry/ProfilingTraceData;)Lio/sentry/SentryEnvelope;
move-result-object v2
.line 226
invoke-virtual {p3}, Lio/sentry/Hint;->clear()V
if-eqz v2, :cond_11
.line 228
invoke-direct {p0, v2, p3}, Lio/sentry/SentryClient;->sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
move-result-object p1
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
.catch Lio/sentry/exception/SentryEnvelopeException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_8
:catch_0
move-exception v2
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 231
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object v3, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string v4, "Capturing event %s failed."
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
invoke-interface {p0, v3, v2, v4, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
.line 234
sget-object p1, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
:cond_11
:goto_8
if-eqz p2, :cond_13
.line 240
invoke-interface {p2}, Lio/sentry/IScope;->getTransaction()Lio/sentry/ITransaction;
move-result-object p0
if-eqz p0, :cond_13
.line 242
const-class p2, Lio/sentry/hints/TransactionEnd;
invoke-static {p3, p2}, Lio/sentry/util/HintUtils;->hasType(Lio/sentry/Hint;Ljava/lang/Class;)Z
move-result p2
if-eqz p2, :cond_13
.line 243
invoke-static {p3}, Lio/sentry/util/HintUtils;->getSentrySdkHint(Lio/sentry/Hint;)Ljava/lang/Object;
move-result-object p2
.line 244
instance-of v2, p2, Lio/sentry/hints/DiskFlushNotification;
if-eqz v2, :cond_12
.line 245
check-cast p2, Lio/sentry/hints/DiskFlushNotification;
invoke-interface {p0}, Lio/sentry/ITransaction;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v0
invoke-interface {p2, v0}, Lio/sentry/hints/DiskFlushNotification;->setFlushable(Lio/sentry/protocol/SentryId;)V
.line 246
sget-object p2, Lio/sentry/SpanStatus;->ABORTED:Lio/sentry/SpanStatus;
invoke-interface {p0, p2, v1, p3}, Lio/sentry/ITransaction;->forceFinish(Lio/sentry/SpanStatus;ZLio/sentry/Hint;)V
goto :goto_9
.line 248
:cond_12
sget-object p2, Lio/sentry/SpanStatus;->ABORTED:Lio/sentry/SpanStatus;
invoke-interface {p0, p2, v1, v0}, Lio/sentry/ITransaction;->forceFinish(Lio/sentry/SpanStatus;ZLio/sentry/Hint;)V
:cond_13
:goto_9
return-object p1
.end method
.method public captureMetrics(Lio/sentry/metrics/EncodedMetrics;)Lio/sentry/protocol/SentryId;
.locals 4
.line 997
invoke-static {p1}, Lio/sentry/SentryEnvelopeItem;->fromMetrics(Lio/sentry/metrics/EncodedMetrics;)Lio/sentry/SentryEnvelopeItem;
move-result-object p1
.line 998
new-instance v0, Lio/sentry/SentryEnvelopeHeader;
new-instance v1, Lio/sentry/protocol/SentryId;
invoke-direct {v1}, Lio/sentry/protocol/SentryId;-><init>()V
iget-object v2, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 999
invoke-virtual {v2}, Lio/sentry/SentryOptions;->getSdkVersion()Lio/sentry/protocol/SdkVersion;
move-result-object v2
const/4 v3, 0x0
invoke-direct {v0, v1, v2, v3}, Lio/sentry/SentryEnvelopeHeader;-><init>(Lio/sentry/protocol/SentryId;Lio/sentry/protocol/SdkVersion;Lio/sentry/TraceContext;)V
.line 1001
new-instance v1, Lio/sentry/SentryEnvelope;
.line 1002
invoke-static {p1}, Ljava/util/Collections;->singleton(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p1
invoke-direct {v1, v0, p1}, Lio/sentry/SentryEnvelope;-><init>(Lio/sentry/SentryEnvelopeHeader;Ljava/lang/Iterable;)V
.line 1003
invoke-virtual {p0, v1}, Lio/sentry/SentryClient;->captureEnvelope(Lio/sentry/SentryEnvelope;)Lio/sentry/protocol/SentryId;
move-result-object p0
if-eqz p0, :cond_0
goto :goto_0
.line 1004
:cond_0
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
:goto_0
return-object p0
.end method
.method public captureSession(Lio/sentry/Session;Lio/sentry/Hint;)V
.locals 2
const-string v0, "Session is required."
.line 561
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
.line 563
invoke-virtual {p1}, Lio/sentry/Session;->getRelease()Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_1
invoke-virtual {p1}, Lio/sentry/Session;->getRelease()Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
goto :goto_0
:cond_0
:try_start_0
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 572
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer;
move-result-object v0
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
invoke-virtual {v1}, Lio/sentry/SentryOptions;->getSdkVersion()Lio/sentry/protocol/SdkVersion;
move-result-object v1
invoke-static {v0, p1, v1}, Lio/sentry/SentryEnvelope;->from(Lio/sentry/ISerializer;Lio/sentry/Session;Lio/sentry/protocol/SdkVersion;)Lio/sentry/SentryEnvelope;
move-result-object p1
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
.line 578
invoke-virtual {p0, p1, p2}, Lio/sentry/SentryClient;->captureEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
return-void
:catch_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 574
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v0, "Failed to capture session."
invoke-interface {p0, p2, v0, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
:cond_1
:goto_0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 565
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
const-string v0, "Sessions can\'t be captured without setting a release."
.line 566
invoke-interface {p0, p1, v0, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method public captureTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/TraceContext;Lio/sentry/IScope;Lio/sentry/Hint;Lio/sentry/ProfilingTraceData;)Lio/sentry/protocol/SentryId;
.locals 7
const-string v0, "Transaction is required."
.line 629
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
if-nez p4, :cond_0
.line 632
new-instance p4, Lio/sentry/Hint;
invoke-direct {p4}, Lio/sentry/Hint;-><init>()V
.line 635
:cond_0
invoke-direct {p0, p1, p4}, Lio/sentry/SentryClient;->shouldApplyScopeData(Lio/sentry/SentryBaseEvent;Lio/sentry/Hint;)Z
move-result v0
if-eqz v0, :cond_1
.line 636
invoke-direct {p0, p3, p4}, Lio/sentry/SentryClient;->addScopeAttachmentsToHint(Lio/sentry/IScope;Lio/sentry/Hint;)V
:cond_1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 640
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 641
invoke-virtual {p1}, Lio/sentry/protocol/SentryTransaction;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v2
filled-new-array {v2}, [Ljava/lang/Object;
move-result-object v2
const-string v3, "Capturing transaction: %s"
invoke-interface {v0, v1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 643
sget-object v0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
.line 644
invoke-virtual {p1}, Lio/sentry/protocol/SentryTransaction;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v1
if-eqz v1, :cond_2
.line 645
invoke-virtual {p1}, Lio/sentry/protocol/SentryTransaction;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v0
.line 648
:cond_2
invoke-direct {p0, p1, p4}, Lio/sentry/SentryClient;->shouldApplyScopeData(Lio/sentry/SentryBaseEvent;Lio/sentry/Hint;)Z
move-result v1
const/4 v2, 0x0
if-eqz v1, :cond_4
.line 649
invoke-direct {p0, p1, p3}, Lio/sentry/SentryClient;->applyScope(Lio/sentry/SentryBaseEvent;Lio/sentry/IScope;)Lio/sentry/SentryBaseEvent;
move-result-object p1
check-cast p1, Lio/sentry/protocol/SentryTransaction;
if-eqz p1, :cond_3
if-eqz p3, :cond_3
.line 652
invoke-interface {p3}, Lio/sentry/IScope;->getEventProcessors()Ljava/util/List;
move-result-object p3
invoke-direct {p0, p1, p4, p3}, Lio/sentry/SentryClient;->processTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/protocol/SentryTransaction;
move-result-object p1
:cond_3
if-nez p1, :cond_4
iget-object p3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 656
invoke-virtual {p3}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p3
sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string v3, "Transaction was dropped by applyScope"
new-array v4, v2, [Ljava/lang/Object;
invoke-interface {p3, v1, v3, v4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_4
if-eqz p1, :cond_5
iget-object p3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 661
invoke-virtual {p3}, Lio/sentry/SentryOptions;->getEventProcessors()Ljava/util/List;
move-result-object p3
invoke-direct {p0, p1, p4, p3}, Lio/sentry/SentryClient;->processTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;Ljava/util/List;)Lio/sentry/protocol/SentryTransaction;
move-result-object p1
:cond_5
if-nez p1, :cond_6
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 665
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string p2, "Transaction was dropped by Event processors."
new-array p3, v2, [Ljava/lang/Object;
invoke-interface {p0, p1, p2, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 666
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
.line 669
:cond_6
invoke-direct {p0, p1, p4}, Lio/sentry/SentryClient;->executeBeforeSendTransaction(Lio/sentry/protocol/SentryTransaction;Lio/sentry/Hint;)Lio/sentry/protocol/SentryTransaction;
move-result-object p1
if-nez p1, :cond_7
iget-object p1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 673
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p1
sget-object p2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string p3, "Transaction was dropped by beforeSendTransaction."
new-array p4, v2, [Ljava/lang/Object;
.line 674
invoke-interface {p1, p2, p3, p4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 676
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getClientReportRecorder()Lio/sentry/clientreport/IClientReportRecorder;
move-result-object p0
sget-object p1, Lio/sentry/clientreport/DiscardReason;->BEFORE_SEND:Lio/sentry/clientreport/DiscardReason;
sget-object p2, Lio/sentry/DataCategory;->Transaction:Lio/sentry/DataCategory;
.line 677
invoke-interface {p0, p1, p2}, Lio/sentry/clientreport/IClientReportRecorder;->recordLostEvent(Lio/sentry/clientreport/DiscardReason;Lio/sentry/DataCategory;)V
.line 678
sget-object p0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
return-object p0
.line 685
:cond_7
:try_start_0
invoke-direct {p0, p4}, Lio/sentry/SentryClient;->getAttachments(Lio/sentry/Hint;)Ljava/util/List;
move-result-object p3
invoke-direct {p0, p3}, Lio/sentry/SentryClient;->filterForTransaction(Ljava/util/List;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
move-object v1, p0
move-object v2, p1
move-object v5, p2
move-object v6, p5
.line 683
invoke-direct/range {v1 .. v6}, Lio/sentry/SentryClient;->buildEnvelope(Lio/sentry/SentryBaseEvent;Ljava/util/List;Lio/sentry/Session;Lio/sentry/TraceContext;Lio/sentry/ProfilingTraceData;)Lio/sentry/SentryEnvelope;
move-result-object p1
.line 690
invoke-virtual {p4}, Lio/sentry/Hint;->clear()V
if-eqz p1, :cond_8
.line 692
invoke-direct {p0, p1, p4}, Lio/sentry/SentryClient;->sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
move-result-object v0
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
.catch Lio/sentry/exception/SentryEnvelopeException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception p1
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 695
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p2, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string p3, "Capturing transaction %s failed."
filled-new-array {v0}, [Ljava/lang/Object;
move-result-object p4
invoke-interface {p0, p2, p1, p3, p4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
.line 697
sget-object v0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
:cond_8
:goto_0
return-object v0
.end method
.method public captureUserFeedback(Lio/sentry/UserFeedback;)V
.locals 4
const-string v0, "SentryEvent is required."
.line 445
invoke-static {p1, v0}, Lio/sentry/util/Objects;->requireNonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
.line 447
sget-object v0, Lio/sentry/protocol/SentryId;->EMPTY_ID:Lio/sentry/protocol/SentryId;
invoke-virtual {p1}, Lio/sentry/UserFeedback;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v1
invoke-virtual {v0, v1}, Lio/sentry/protocol/SentryId;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 448
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const/4 v0, 0x0
new-array v0, v0, [Ljava/lang/Object;
const-string v1, "Capturing userFeedback without a Sentry Id."
invoke-interface {p0, p1, v1, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
:cond_0
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 452
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
.line 453
invoke-virtual {p1}, Lio/sentry/UserFeedback;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object v2
filled-new-array {v2}, [Ljava/lang/Object;
move-result-object v2
const-string v3, "Capturing userFeedback: %s"
invoke-interface {v0, v1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
.line 456
:try_start_0
invoke-direct {p0, p1}, Lio/sentry/SentryClient;->buildEnvelope(Lio/sentry/UserFeedback;)Lio/sentry/SentryEnvelope;
move-result-object v0
const/4 v1, 0x0
.line 457
invoke-direct {p0, v0, v1}, Lio/sentry/SentryClient;->sendEnvelope(Lio/sentry/SentryEnvelope;Lio/sentry/Hint;)Lio/sentry/protocol/SentryId;
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception v0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 460
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object v1, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
.line 465
invoke-virtual {p1}, Lio/sentry/UserFeedback;->getEventId()Lio/sentry/protocol/SentryId;
move-result-object p1
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
const-string v2, "Capturing user feedback %s failed."
.line 461
invoke-interface {p0, v1, v0, v2, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
return-void
.end method
.method public close()V
.locals 1
const/4 v0, 0x0
.line 928
invoke-virtual {p0, v0}, Lio/sentry/SentryClient;->close(Z)V
return-void
.end method
.method public close(Z)V
.locals 6
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 933
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel;
const/4 v2, 0x0
new-array v3, v2, [Ljava/lang/Object;
const-string v4, "Closing SentryClient."
invoke-interface {v0, v1, v4, v3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
:try_start_0
iget-object v0, p0, Lio/sentry/SentryClient;->metricsAggregator:Lio/sentry/IMetricsAggregator;
.line 935
invoke-interface {v0}, Lio/sentry/IMetricsAggregator;->close()V
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception v0
iget-object v1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 937
invoke-virtual {v1}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v1
sget-object v3, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string v4, "Failed to close the metrics aggregator."
invoke-interface {v1, v3, v4, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_0
if-eqz p1, :cond_0
const-wide/16 v0, 0x0
goto :goto_1
:cond_0
:try_start_1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 940
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getShutdownTimeoutMillis()J
move-result-wide v0
:goto_1
invoke-virtual {p0, v0, v1}, Lio/sentry/SentryClient;->flush(J)V
iget-object v0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 941
invoke-interface {v0, p1}, Lio/sentry/transport/ITransport;->close(Z)V
:try_end_1
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_1
goto :goto_2
:catch_1
move-exception p1
iget-object v0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 944
invoke-virtual {v0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v0
sget-object v1, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string v3, "Failed to close the connection to the Sentry Server."
.line 945
invoke-interface {v0, v1, v3, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_2
iget-object p1, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 947
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getEventProcessors()Ljava/util/List;
move-result-object p1
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:cond_1
:goto_3
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lio/sentry/EventProcessor;
.line 948
instance-of v1, v0, Ljava/io/Closeable;
if-eqz v1, :cond_1
.line 950
:try_start_2
move-object v1, v0
check-cast v1, Ljava/io/Closeable;
invoke-interface {v1}, Ljava/io/Closeable;->close()V
:try_end_2
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_2
goto :goto_3
:catch_2
move-exception v1
iget-object v3, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 953
invoke-virtual {v3}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object v3
sget-object v4, Lio/sentry/SentryLevel;->WARNING:Lio/sentry/SentryLevel;
const-string v5, "Failed to close the event processor {}."
filled-new-array {v0, v1}, [Ljava/lang/Object;
move-result-object v0
.line 954
invoke-interface {v3, v4, v5, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_3
:cond_2
iput-boolean v2, p0, Lio/sentry/SentryClient;->enabled:Z
return-void
.end method
.method public flush(J)V
.locals 0
iget-object p0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 967
invoke-interface {p0, p1, p2}, Lio/sentry/transport/ITransport;->flush(J)V
return-void
.end method
.method public getMetricsAggregator()Lio/sentry/IMetricsAggregator;
.locals 0
iget-object p0, p0, Lio/sentry/SentryClient;->metricsAggregator:Lio/sentry/IMetricsAggregator;
return-object p0
.end method
.method public getRateLimiter()Lio/sentry/transport/RateLimiter;
.locals 0
iget-object p0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 972
invoke-interface {p0}, Lio/sentry/transport/ITransport;->getRateLimiter()Lio/sentry/transport/RateLimiter;
move-result-object p0
return-object p0
.end method
.method public isEnabled()Z
.locals 0
iget-boolean p0, p0, Lio/sentry/SentryClient;->enabled:Z
return p0
.end method
.method public isHealthy()Z
.locals 0
iget-object p0, p0, Lio/sentry/SentryClient;->transport:Lio/sentry/transport/ITransport;
.line 977
invoke-interface {p0}, Lio/sentry/transport/ITransport;->isHealthy()Z
move-result p0
return p0
.end method
.method synthetic lambda$updateSessionData$1$io-sentry-SentryClient(Lio/sentry/SentryEvent;Lio/sentry/Hint;Lio/sentry/Session;)V
.locals 4
.line 0
const/4 v0, 0x0
if-eqz p3, :cond_5
.line 516
invoke-virtual {p1}, Lio/sentry/SentryEvent;->isCrashed()Z
move-result p0
const/4 v1, 0x0
if-eqz p0, :cond_0
.line 517
sget-object p0, Lio/sentry/Session$State;->Crashed:Lio/sentry/Session$State;
goto :goto_0
:cond_0
move-object p0, v1
.line 521
:goto_0
sget-object v2, Lio/sentry/Session$State;->Crashed:Lio/sentry/Session$State;
if-eq v2, p0, :cond_1
invoke-virtual {p1}, Lio/sentry/SentryEvent;->isErrored()Z
move-result v2
if-eqz v2, :cond_2
:cond_1
const/4 v0, 0x1
.line 526
:cond_2
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getRequest()Lio/sentry/protocol/Request;
move-result-object v2
if-eqz v2, :cond_3
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getRequest()Lio/sentry/protocol/Request;
move-result-object v2
invoke-virtual {v2}, Lio/sentry/protocol/Request;->getHeaders()Ljava/util/Map;
move-result-object v2
if-eqz v2, :cond_3
.line 527
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getRequest()Lio/sentry/protocol/Request;
move-result-object v2
invoke-virtual {v2}, Lio/sentry/protocol/Request;->getHeaders()Ljava/util/Map;
move-result-object v2
const-string v3, "user-agent"
invoke-interface {v2, v3}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_3
.line 528
invoke-virtual {p1}, Lio/sentry/SentryEvent;->getRequest()Lio/sentry/protocol/Request;
move-result-object p1
invoke-virtual {p1}, Lio/sentry/protocol/Request;->getHeaders()Ljava/util/Map;
move-result-object p1
invoke-interface {p1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
goto :goto_1
:cond_3
move-object p1, v1
.line 532
:goto_1
invoke-static {p2}, Lio/sentry/util/HintUtils;->getSentrySdkHint(Lio/sentry/Hint;)Ljava/lang/Object;
move-result-object p2
.line 534
instance-of v2, p2, Lio/sentry/hints/AbnormalExit;
if-eqz v2, :cond_4
.line 535
check-cast p2, Lio/sentry/hints/AbnormalExit;
invoke-interface {p2}, Lio/sentry/hints/AbnormalExit;->mechanism()Ljava/lang/String;
move-result-object v1
.line 536
sget-object p0, Lio/sentry/Session$State;->Abnormal:Lio/sentry/Session$State;
.line 539
:cond_4
invoke-virtual {p3, p0, p1, v0, v1}, Lio/sentry/Session;->update(Lio/sentry/Session$State;Ljava/lang/String;ZLjava/lang/String;)Z
move-result p0
if-eqz p0, :cond_6
.line 541
invoke-virtual {p3}, Lio/sentry/Session;->isTerminated()Z
move-result p0
if-eqz p0, :cond_6
.line 542
invoke-virtual {p3}, Lio/sentry/Session;->end()V
goto :goto_2
:cond_5
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 547
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel;
const-string p2, "Session is null on scope.withSession"
new-array p3, v0, [Ljava/lang/Object;
.line 548
invoke-interface {p0, p1, p2, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_6
:goto_2
return-void
.end method
.method updateSessionData(Lio/sentry/SentryEvent;Lio/sentry/Hint;Lio/sentry/IScope;)Lio/sentry/Session;
.locals 1
.line 509
invoke-static {p2}, Lio/sentry/util/HintUtils;->shouldApplyScopeData(Lio/sentry/Hint;)Z
move-result v0
if-eqz v0, :cond_1
if-eqz p3, :cond_0
.line 511
new-instance v0, Lio/sentry/SentryClient$$ExternalSyntheticLambda1;
invoke-direct {v0, p0, p1, p2}, Lio/sentry/SentryClient$$ExternalSyntheticLambda1;-><init>(Lio/sentry/SentryClient;Lio/sentry/SentryEvent;Lio/sentry/Hint;)V
.line 512
invoke-interface {p3, v0}, Lio/sentry/IScope;->withSession(Lio/sentry/Scope$IWithSession;)Lio/sentry/Session;
move-result-object p0
goto :goto_0
:cond_0
iget-object p0, p0, Lio/sentry/SentryClient;->options:Lio/sentry/SentryOptions;
.line 552
invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
move-result-object p0
sget-object p1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel;
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
const-string p3, "Scope is null on client.captureEvent"
invoke-interface {p0, p1, p3, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_1
const/4 p0, 0x0
:goto_0
return-object p0
.end method