-
Notifications
You must be signed in to change notification settings - Fork 49
Expand file tree
/
Copy pathRavenPersistenceConfiguration.cs
More file actions
205 lines (169 loc) · 9.93 KB
/
RavenPersistenceConfiguration.cs
File metadata and controls
205 lines (169 loc) · 9.93 KB
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
namespace ServiceControl.Audit.Persistence.RavenDB
{
using System;
using System.Collections.Generic;
using System.IO;
using System.Reflection;
using CustomChecks;
using Microsoft.Extensions.Logging;
using ServiceControl.Infrastructure;
public class RavenPersistenceConfiguration : IPersistenceConfiguration
{
public const string DatabaseNameKey = "RavenDB/DatabaseName";
public const string DatabasePathKey = "DbPath";
public const string ConnectionStringKey = "RavenDB/ConnectionString";
public const string ClientCertificatePathKey = "RavenDB/ClientCertificatePath";
public const string ClientCertificateBase64Key = "RavenDB/ClientCertificateBase64";
public const string ClientCertificatePasswordKey = "RavenDB/ClientCertificatePassword";
public const string DatabaseMaintenancePortKey = "DatabaseMaintenancePort";
public const string ExpirationProcessTimerInSecondsKey = "ExpirationProcessTimerInSeconds";
public const string LogPathKey = "LogPath";
public const string RavenDbLogLevelKey = "RavenDBLogLevel";
public const string MinimumStorageLeftRequiredForIngestionKey = "MinimumStorageLeftRequiredForIngestion";
public const string BulkInsertCommitTimeoutInSecondsKey = "BulkInsertCommitTimeoutInSeconds";
public const string DataSpaceRemainingThresholdKey = "DataSpaceRemainingThreshold";
public IEnumerable<string> ConfigurationKeys => new[]{
DatabaseNameKey,
DatabasePathKey,
ConnectionStringKey,
ClientCertificatePathKey,
ClientCertificateBase64Key,
ClientCertificatePasswordKey,
DatabaseMaintenancePortKey,
ExpirationProcessTimerInSecondsKey,
LogPathKey,
RavenDbLogLevelKey,
DataSpaceRemainingThresholdKey,
MinimumStorageLeftRequiredForIngestionKey,
BulkInsertCommitTimeoutInSecondsKey
};
public string Name => "RavenDB";
public IPersistence Create(PersistenceSettings settings)
{
var databaseConfiguration = GetDatabaseConfiguration(settings);
return new RavenPersistence(databaseConfiguration);
}
internal static DatabaseConfiguration GetDatabaseConfiguration(PersistenceSettings settings)
{
if (!settings.PersisterSpecificSettings.TryGetValue(DatabaseNameKey, out var databaseName))
{
databaseName = "audit";
}
ServerConfiguration serverConfiguration;
if (settings.PersisterSpecificSettings.TryGetValue(ConnectionStringKey, out var connectionString))
{
if (settings.PersisterSpecificSettings.ContainsKey(DatabasePathKey))
{
throw new InvalidOperationException($"{ConnectionStringKey} and {DatabasePathKey} cannot be specified at the same time.");
}
serverConfiguration = new ServerConfiguration(connectionString);
if (settings.PersisterSpecificSettings.TryGetValue(ClientCertificatePathKey, out var clientCertificatePath))
{
serverConfiguration.ClientCertificatePath = clientCertificatePath;
}
if (settings.PersisterSpecificSettings.TryGetValue(ClientCertificateBase64Key, out var clientCertificateBase64))
{
serverConfiguration.ClientCertificateBase64 = clientCertificateBase64;
}
if (settings.PersisterSpecificSettings.TryGetValue(ClientCertificatePasswordKey, out var clientCertificatePassword))
{
serverConfiguration.ClientCertificatePassword = clientCertificatePassword;
}
}
else
{
if (!settings.PersisterSpecificSettings.TryGetValue(DatabasePathKey, out var dbPath))
{
// SC installer always populates DBPath in app.config on installation/change/upgrade so this will only be used when
// debugging or if the entry is removed manually. In those circumstances default to the folder containing the exe
var assemblyLocation = Assembly.GetExecutingAssembly().Location;
dbPath = Path.Combine(Path.GetDirectoryName(assemblyLocation), ".db");
}
if (!settings.PersisterSpecificSettings.TryGetValue(DatabaseMaintenancePortKey, out var databaseMaintenancePortString))
{
throw new InvalidOperationException($"{DatabaseMaintenancePortKey} must be specified when using embedded server.");
}
if (!int.TryParse(databaseMaintenancePortString, out var databaseMaintenancePort))
{
throw new InvalidOperationException($"{DatabaseMaintenancePortKey} must be an integer.");
}
var serverUrl = $"http://localhost:{databaseMaintenancePort}";
var logPath = GetLogPath(settings);
var logsMode = "Operations";
if (settings.PersisterSpecificSettings.TryGetValue(RavenDbLogLevelKey, out var ravenDbLogLevel))
{
logsMode = RavenDbLogLevelToLogsModeMapper.Map(ravenDbLogLevel, Logger);
}
serverConfiguration = new ServerConfiguration(dbPath, serverUrl, logPath, logsMode);
}
var dataSpaceRemainingThreshold = CheckFreeDiskSpace.Parse(settings.PersisterSpecificSettings, Logger);
var minimumStorageLeftRequiredForIngestion = CheckMinimumStorageRequiredForIngestion.Parse(settings.PersisterSpecificSettings);
var expirationProcessTimerInSeconds = GetExpirationProcessTimerInSeconds(settings);
var bulkInsertTimeout = TimeSpan.FromSeconds(GetBulkInsertCommitTimeout(settings));
return new DatabaseConfiguration(
databaseName,
expirationProcessTimerInSeconds,
settings.EnableFullTextSearchOnBodies,
settings.AuditRetentionPeriod,
settings.MaxBodySizeToStore,
dataSpaceRemainingThreshold,
minimumStorageLeftRequiredForIngestion,
serverConfiguration,
bulkInsertTimeout);
}
static int GetExpirationProcessTimerInSeconds(PersistenceSettings settings)
{
var expirationProcessTimerInSeconds = ExpirationProcessTimerInSecondsDefault;
if (settings.PersisterSpecificSettings.TryGetValue(ExpirationProcessTimerInSecondsKey, out var expirationProcessTimerInSecondsString))
{
expirationProcessTimerInSeconds = int.Parse(expirationProcessTimerInSecondsString);
}
var maxExpirationProcessTimerInSeconds = TimeSpan.FromHours(3).TotalSeconds;
if (expirationProcessTimerInSeconds < 0)
{
Logger.LogError("ExpirationProcessTimerInSeconds cannot be negative. Defaulting to {ExpirationProcessTimerInSecondsDefault}", ExpirationProcessTimerInSecondsDefault);
return ExpirationProcessTimerInSecondsDefault;
}
if (expirationProcessTimerInSeconds > maxExpirationProcessTimerInSeconds)
{
Logger.LogError("ExpirationProcessTimerInSeconds cannot be larger than {MaxExpirationProcessTimerInSeconds}. Defaulting to {ExpirationProcessTimerInSecondsDefault}", maxExpirationProcessTimerInSeconds, ExpirationProcessTimerInSecondsDefault);
return ExpirationProcessTimerInSecondsDefault;
}
return expirationProcessTimerInSeconds;
}
static int GetBulkInsertCommitTimeout(PersistenceSettings settings)
{
var bulkInsertCommitTimeoutInSeconds = BulkInsertCommitTimeoutInSecondsDefault;
if (settings.PersisterSpecificSettings.TryGetValue(BulkInsertCommitTimeoutInSecondsKey, out var bulkInsertCommitTimeoutString))
{
bulkInsertCommitTimeoutInSeconds = int.Parse(bulkInsertCommitTimeoutString);
}
var maxBulkInsertCommitTimeoutInSeconds = TimeSpan.FromHours(1).TotalSeconds;
if (bulkInsertCommitTimeoutInSeconds < 0)
{
Logger.LogError("BulkInsertCommitTimeout cannot be negative. Defaulting to {BulkInsertCommitTimeoutInSecondsDefault}", BulkInsertCommitTimeoutInSecondsDefault);
return BulkInsertCommitTimeoutInSecondsDefault;
}
if (bulkInsertCommitTimeoutInSeconds > maxBulkInsertCommitTimeoutInSeconds)
{
Logger.LogError("BulkInsertCommitTimeout cannot be larger than {MaxBulkInsertCommitTimeoutInSeconds}. Defaulting to {BulkInsertCommitTimeoutInSecondsDefault}", maxBulkInsertCommitTimeoutInSeconds, BulkInsertCommitTimeoutInSecondsDefault);
return BulkInsertCommitTimeoutInSecondsDefault;
}
return bulkInsertCommitTimeoutInSeconds;
}
static string GetLogPath(PersistenceSettings settings)
{
if (!settings.PersisterSpecificSettings.TryGetValue(LogPathKey, out var logPath))
{
// SC installer always populates LogPath in app.config on installation/change/upgrade so this will only be used when
// debugging or if the entry is removed manually. In those circumstances default to the folder containing the exe
var assemblyLocation = Assembly.GetExecutingAssembly().Location;
logPath = Path.Combine(Path.GetDirectoryName(assemblyLocation), ".logs");
}
return logPath;
}
const int ExpirationProcessTimerInSecondsDefault = 600;
const int BulkInsertCommitTimeoutInSecondsDefault = 60;
static readonly ILogger<RavenPersistenceConfiguration> Logger = LoggerUtil.CreateStaticLogger<RavenPersistenceConfiguration>();
}
}