-
-
Notifications
You must be signed in to change notification settings - Fork 205
/
SettingLocator.cs
90 lines (75 loc) · 3.13 KB
/
SettingLocator.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
using Sentry.Internal.Extensions;
namespace Sentry.Internal;
/// <summary>
/// Exposes settings that are read from multiple places, such as environment variables, options, attributes, or defaults.
/// </summary>
internal class SettingLocator
{
private readonly SentryOptions _options;
public SettingLocator(SentryOptions options)
{
_options = options;
}
public Assembly? AssemblyForAttributes { get; protected set; } = Assembly.GetEntryAssembly();
// IMPORTANT: This method has the only usage of Environment.GetEnvironmentVariable in the entire solution.
// All callers should go through this method. Overriding this method thus allows one place for mocking environment variables.
public virtual string? GetEnvironmentVariable(string variable) => Environment.GetEnvironmentVariable(variable);
/*
* In all cases, the order of precedence is:
* 1. A value already assigned to a SentryOptions property
* 2. A value set in an environment variable
* 3. A value from an assembly attribute, when applicable
* 4. A default value, when applicable
*
* Except when already assigned, any non-null value resolved should be assigned to the SentryOptions property.
*/
public string GetDsn()
{
// For DSN only
// An empty string set on the option should NOT be converted to null because it is used
// to indicate the the SDK is disabled.
_options.Dsn ??= GetEnvironmentVariable(Constants.DsnEnvironmentVariable)
?? AssemblyForAttributes?.GetCustomAttribute<DsnAttribute>()?.Dsn;
if (_options.Dsn is null)
{
throw new ArgumentNullException("You must supply a DSN to use Sentry." +
"To disable Sentry, pass an empty string: \"\"." +
"See https://docs.sentry.io/platforms/dotnet/configuration/options/#dsn");
}
return _options.Dsn;
}
public string GetEnvironment() => GetEnvironment(true)!;
public string? GetEnvironment(bool useDefaultIfNotFound)
{
var environment = _options.Environment;
if (!string.IsNullOrWhiteSpace(environment))
{
return environment;
}
environment = GetEnvironmentVariable(Constants.EnvironmentEnvironmentVariable).NullIfWhitespace();
if (useDefaultIfNotFound)
{
environment ??= Debugger.IsAttached
? Constants.DebugEnvironmentSetting
: Constants.ProductionEnvironmentSetting;
}
else if (environment == null)
{
return null;
}
_options.Environment = environment;
return environment;
}
public string? GetRelease()
{
var release = _options.Release;
if (!string.IsNullOrWhiteSpace(release))
{
return release;
}
release = GetEnvironmentVariable(Constants.ReleaseEnvironmentVariable).NullIfWhitespace()
?? ApplicationVersionLocator.GetCurrent(AssemblyForAttributes);
_options.Release = release;
return release;
}
}