mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2024-12-25 16:42:30 -06:00
128 lines
6 KiB
Java
128 lines
6 KiB
Java
package io.sentry;
|
|
|
|
import com.google.common.net.HttpHeaders;
|
|
import io.sentry.SentryOptions;
|
|
import io.sentry.util.Platform;
|
|
import java.io.Closeable;
|
|
import java.io.IOException;
|
|
import java.io.OutputStream;
|
|
import java.net.HttpURLConnection;
|
|
import java.net.URI;
|
|
import java.util.concurrent.RejectedExecutionException;
|
|
import java.util.zip.GZIPOutputStream;
|
|
|
|
/* loaded from: classes3.dex */
|
|
public final class SpotlightIntegration implements Integration, SentryOptions.BeforeEnvelopeCallback, Closeable {
|
|
private SentryOptions options;
|
|
private ILogger logger = NoOpLogger.getInstance();
|
|
private ISentryExecutorService executorService = NoOpSentryExecutorService.getInstance();
|
|
|
|
@Override // io.sentry.Integration
|
|
public void register(IHub iHub, SentryOptions sentryOptions) {
|
|
this.options = sentryOptions;
|
|
this.logger = sentryOptions.getLogger();
|
|
if (sentryOptions.getBeforeEnvelopeCallback() == null && sentryOptions.isEnableSpotlight()) {
|
|
this.executorService = new SentryExecutorService();
|
|
sentryOptions.setBeforeEnvelopeCallback(this);
|
|
this.logger.log(SentryLevel.DEBUG, "SpotlightIntegration enabled.", new Object[0]);
|
|
return;
|
|
}
|
|
this.logger.log(SentryLevel.DEBUG, "SpotlightIntegration is not enabled. BeforeEnvelopeCallback is already set or spotlight is not enabled.", new Object[0]);
|
|
}
|
|
|
|
@Override // io.sentry.SentryOptions.BeforeEnvelopeCallback
|
|
public void execute(final SentryEnvelope sentryEnvelope, Hint hint) {
|
|
try {
|
|
this.executorService.submit(new Runnable() { // from class: io.sentry.SpotlightIntegration$$ExternalSyntheticLambda0
|
|
@Override // java.lang.Runnable
|
|
public final void run() {
|
|
SpotlightIntegration.this.m5633lambda$execute$0$iosentrySpotlightIntegration(sentryEnvelope);
|
|
}
|
|
});
|
|
} catch (RejectedExecutionException e) {
|
|
this.logger.log(SentryLevel.WARNING, "Spotlight envelope submission rejected.", e);
|
|
}
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
/* renamed from: sendEnvelope, reason: merged with bridge method [inline-methods] */
|
|
public void m5633lambda$execute$0$iosentrySpotlightIntegration(SentryEnvelope sentryEnvelope) {
|
|
try {
|
|
if (this.options == null) {
|
|
throw new IllegalArgumentException("SentryOptions are required to send envelopes.");
|
|
}
|
|
HttpURLConnection createConnection = createConnection(getSpotlightConnectionUrl());
|
|
try {
|
|
OutputStream outputStream = createConnection.getOutputStream();
|
|
try {
|
|
GZIPOutputStream gZIPOutputStream = new GZIPOutputStream(outputStream);
|
|
try {
|
|
this.options.getSerializer().serialize(sentryEnvelope, gZIPOutputStream);
|
|
gZIPOutputStream.close();
|
|
if (outputStream != null) {
|
|
outputStream.close();
|
|
}
|
|
this.logger.log(SentryLevel.DEBUG, "Envelope sent to spotlight: %d", Integer.valueOf(createConnection.getResponseCode()));
|
|
} finally {
|
|
}
|
|
} finally {
|
|
}
|
|
} catch (Throwable th) {
|
|
try {
|
|
this.logger.log(SentryLevel.ERROR, "An exception occurred while submitting the envelope to the Sentry server.", th);
|
|
this.logger.log(SentryLevel.DEBUG, "Envelope sent to spotlight: %d", Integer.valueOf(createConnection.getResponseCode()));
|
|
} catch (Throwable th2) {
|
|
this.logger.log(SentryLevel.DEBUG, "Envelope sent to spotlight: %d", Integer.valueOf(createConnection.getResponseCode()));
|
|
closeAndDisconnect(createConnection);
|
|
throw th2;
|
|
}
|
|
}
|
|
closeAndDisconnect(createConnection);
|
|
} catch (Exception e) {
|
|
this.logger.log(SentryLevel.ERROR, "An exception occurred while creating the connection to spotlight.", e);
|
|
}
|
|
}
|
|
|
|
public String getSpotlightConnectionUrl() {
|
|
SentryOptions sentryOptions = this.options;
|
|
if (sentryOptions == null || sentryOptions.getSpotlightConnectionUrl() == null) {
|
|
return Platform.isAndroid() ? "http://10.0.2.2:8969/stream" : "http://localhost:8969/stream";
|
|
}
|
|
return this.options.getSpotlightConnectionUrl();
|
|
}
|
|
|
|
private HttpURLConnection createConnection(String str) throws Exception {
|
|
HttpURLConnection httpURLConnection = (HttpURLConnection) URI.create(str).toURL().openConnection();
|
|
httpURLConnection.setReadTimeout(1000);
|
|
httpURLConnection.setConnectTimeout(1000);
|
|
httpURLConnection.setRequestMethod("POST");
|
|
httpURLConnection.setDoOutput(true);
|
|
httpURLConnection.setRequestProperty(HttpHeaders.CONTENT_ENCODING, "gzip");
|
|
httpURLConnection.setRequestProperty(HttpHeaders.CONTENT_TYPE, "application/x-sentry-envelope");
|
|
httpURLConnection.setRequestProperty(HttpHeaders.ACCEPT, "application/json");
|
|
httpURLConnection.setRequestProperty(HttpHeaders.CONNECTION, "close");
|
|
httpURLConnection.connect();
|
|
return httpURLConnection;
|
|
}
|
|
|
|
private void closeAndDisconnect(HttpURLConnection httpURLConnection) {
|
|
try {
|
|
httpURLConnection.getInputStream().close();
|
|
} catch (IOException unused) {
|
|
} catch (Throwable th) {
|
|
httpURLConnection.disconnect();
|
|
throw th;
|
|
}
|
|
httpURLConnection.disconnect();
|
|
}
|
|
|
|
@Override // java.io.Closeable, java.lang.AutoCloseable
|
|
public void close() throws IOException {
|
|
this.executorService.close(0L);
|
|
SentryOptions sentryOptions = this.options;
|
|
if (sentryOptions == null || sentryOptions.getBeforeEnvelopeCallback() != this) {
|
|
return;
|
|
}
|
|
this.options.setBeforeEnvelopeCallback(null);
|
|
}
|
|
}
|