-
-
Notifications
You must be signed in to change notification settings - Fork 441
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
11 changed files
with
513 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
146 changes: 146 additions & 0 deletions
146
sentry/src/main/java/io/sentry/SentryStartupProfilingOptions.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,146 @@ | ||
package io.sentry; | ||
|
||
import io.sentry.vendor.gson.stream.JsonToken; | ||
import java.io.IOException; | ||
import java.util.Map; | ||
import java.util.concurrent.ConcurrentHashMap; | ||
import org.jetbrains.annotations.NotNull; | ||
import org.jetbrains.annotations.Nullable; | ||
|
||
final class SentryStartupProfilingOptions implements JsonUnknown, JsonSerializable { | ||
|
||
boolean profileSampled; | ||
@Nullable Double profileSampleRate; | ||
boolean traceSampled; | ||
@Nullable Double traceSampleRate; | ||
@Nullable String profilingTracesDirPath; | ||
boolean isProfilingEnabled; | ||
|
||
private @Nullable Map<String, Object> unknown; | ||
|
||
SentryStartupProfilingOptions() { | ||
traceSampled = false; | ||
traceSampleRate = null; | ||
profileSampled = false; | ||
profileSampleRate = null; | ||
profilingTracesDirPath = null; | ||
isProfilingEnabled = false; | ||
} | ||
|
||
SentryStartupProfilingOptions( | ||
final @NotNull SentryOptions options, | ||
final @NotNull TracesSamplingDecision samplingDecision) { | ||
traceSampled = samplingDecision.getSampled(); | ||
traceSampleRate = samplingDecision.getSampleRate(); | ||
profileSampled = samplingDecision.getProfileSampled(); | ||
profileSampleRate = samplingDecision.getProfileSampleRate(); | ||
profilingTracesDirPath = options.getProfilingTracesDirPath(); | ||
isProfilingEnabled = options.isProfilingEnabled(); | ||
} | ||
|
||
// JsonSerializable | ||
|
||
public static final class JsonKeys { | ||
public static final String PROFILE_SAMPLED = "profile_sampled"; | ||
public static final String PROFILE_SAMPLE_RATE = "profile_sample_rate"; | ||
public static final String TRACE_SAMPLED = "trace_sampled"; | ||
public static final String TRACE_SAMPLE_RATE = "trace_sample_rate"; | ||
public static final String PROFILING_TRACES_DIR_PATH = "profiling_traces_dir_path"; | ||
public static final String IS_PROFILING_ENABLED = "is_profiling_enabled"; | ||
} | ||
|
||
@Override | ||
public void serialize(final @NotNull ObjectWriter writer, final @NotNull ILogger logger) | ||
throws IOException { | ||
writer.beginObject(); | ||
writer.name(JsonKeys.PROFILE_SAMPLED).value(logger, profileSampled); | ||
writer.name(JsonKeys.PROFILE_SAMPLE_RATE).value(logger, profileSampleRate); | ||
writer.name(JsonKeys.TRACE_SAMPLED).value(logger, traceSampled); | ||
writer.name(JsonKeys.TRACE_SAMPLE_RATE).value(logger, traceSampleRate); | ||
writer.name(JsonKeys.PROFILING_TRACES_DIR_PATH).value(logger, profilingTracesDirPath); | ||
writer.name(JsonKeys.IS_PROFILING_ENABLED).value(logger, isProfilingEnabled); | ||
|
||
if (unknown != null) { | ||
for (String key : unknown.keySet()) { | ||
Object value = unknown.get(key); | ||
writer.name(key); | ||
writer.value(logger, value); | ||
} | ||
} | ||
writer.endObject(); | ||
} | ||
|
||
@Nullable | ||
@Override | ||
public Map<String, Object> getUnknown() { | ||
return unknown; | ||
} | ||
|
||
@Override | ||
public void setUnknown(@Nullable Map<String, Object> unknown) { | ||
this.unknown = unknown; | ||
} | ||
|
||
public static final class Deserializer | ||
implements JsonDeserializer<SentryStartupProfilingOptions> { | ||
|
||
@Override | ||
public @NotNull SentryStartupProfilingOptions deserialize( | ||
@NotNull JsonObjectReader reader, @NotNull ILogger logger) throws Exception { | ||
reader.beginObject(); | ||
SentryStartupProfilingOptions options = new SentryStartupProfilingOptions(); | ||
Map<String, Object> unknown = null; | ||
|
||
while (reader.peek() == JsonToken.NAME) { | ||
final String nextName = reader.nextName(); | ||
switch (nextName) { | ||
case JsonKeys.PROFILE_SAMPLED: | ||
Boolean profileSampled = reader.nextBooleanOrNull(); | ||
if (profileSampled != null) { | ||
options.profileSampled = profileSampled; | ||
} | ||
break; | ||
case JsonKeys.PROFILE_SAMPLE_RATE: | ||
Double profileSampleRate = reader.nextDoubleOrNull(); | ||
if (profileSampleRate != null) { | ||
options.profileSampleRate = profileSampleRate; | ||
} | ||
break; | ||
case JsonKeys.TRACE_SAMPLED: | ||
Boolean traceSampled = reader.nextBooleanOrNull(); | ||
if (traceSampled != null) { | ||
options.traceSampled = traceSampled; | ||
} | ||
break; | ||
case JsonKeys.TRACE_SAMPLE_RATE: | ||
Double traceSampleRate = reader.nextDoubleOrNull(); | ||
if (traceSampleRate != null) { | ||
options.traceSampleRate = traceSampleRate; | ||
} | ||
break; | ||
case JsonKeys.PROFILING_TRACES_DIR_PATH: | ||
String profilingTracesDirPath = reader.nextStringOrNull(); | ||
if (profilingTracesDirPath != null) { | ||
options.profilingTracesDirPath = profilingTracesDirPath; | ||
} | ||
break; | ||
case JsonKeys.IS_PROFILING_ENABLED: | ||
Boolean isProfilingEnabled = reader.nextBooleanOrNull(); | ||
if (isProfilingEnabled != null) { | ||
options.isProfilingEnabled = isProfilingEnabled; | ||
} | ||
break; | ||
default: | ||
if (unknown == null) { | ||
unknown = new ConcurrentHashMap<>(); | ||
} | ||
reader.nextUnknown(logger, unknown, nextName); | ||
break; | ||
} | ||
} | ||
options.setUnknown(unknown); | ||
reader.endObject(); | ||
return options; | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.