-
Notifications
You must be signed in to change notification settings - Fork 46
/
RavenPersistenceConfiguration.cs
152 lines (124 loc) · 6.83 KB
/
RavenPersistenceConfiguration.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
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
namespace ServiceControl.Audit.Persistence.RavenDB
{
using System;
using System.Collections.Generic;
using System.IO;
using System.Reflection;
using CustomChecks;
using NServiceBus.Logging;
public class RavenPersistenceConfiguration : IPersistenceConfiguration
{
public const string DatabaseNameKey = "RavenDB/DatabaseName";
public const string DatabasePathKey = "DbPath";
public const string ConnectionStringKey = "RavenDB/ConnectionString";
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 DataSpaceRemainingThresholdKey = "DataSpaceRemainingThreshold";
public IEnumerable<string> ConfigurationKeys => new[]{
DatabaseNameKey,
DatabasePathKey,
ConnectionStringKey,
DatabaseMaintenancePortKey,
ExpirationProcessTimerInSecondsKey,
LogPathKey,
RavenDbLogLevelKey,
DataSpaceRemainingThresholdKey,
MinimumStorageLeftRequiredForIngestionKey
};
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);
}
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);
}
serverConfiguration = new ServerConfiguration(dbPath, serverUrl, logPath, logsMode);
}
var dataSpaceRemainingThreshold = CheckFreeDiskSpace.Parse(settings.PersisterSpecificSettings);
var minimumStorageLeftRequiredForIngestion = CheckMinimumStorageRequiredForIngestion.Parse(settings.PersisterSpecificSettings);
var expirationProcessTimerInSeconds = GetExpirationProcessTimerInSeconds(settings);
return new DatabaseConfiguration(
databaseName,
expirationProcessTimerInSeconds,
settings.EnableFullTextSearchOnBodies,
settings.AuditRetentionPeriod,
settings.MaxBodySizeToStore,
dataSpaceRemainingThreshold,
minimumStorageLeftRequiredForIngestion,
serverConfiguration);
}
static int GetExpirationProcessTimerInSeconds(PersistenceSettings settings)
{
var expirationProcessTimerInSeconds = ExpirationProcessTimerInSecondsDefault;
if (settings.PersisterSpecificSettings.TryGetValue(ExpirationProcessTimerInSecondsKey, out var expirationProcessTimerInSecondsString))
{
expirationProcessTimerInSeconds = int.Parse(expirationProcessTimerInSecondsString);
}
if (expirationProcessTimerInSeconds < 0)
{
Logger.Error($"ExpirationProcessTimerInSeconds cannot be negative. Defaulting to {ExpirationProcessTimerInSecondsDefault}");
return ExpirationProcessTimerInSecondsDefault;
}
if (expirationProcessTimerInSeconds > TimeSpan.FromHours(3).TotalSeconds)
{
Logger.Error($"ExpirationProcessTimerInSeconds cannot be larger than {TimeSpan.FromHours(3).TotalSeconds}. Defaulting to {ExpirationProcessTimerInSecondsDefault}");
return ExpirationProcessTimerInSecondsDefault;
}
return expirationProcessTimerInSeconds;
}
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;
}
static readonly ILog Logger = LogManager.GetLogger(typeof(RavenPersistenceConfiguration));
const int ExpirationProcessTimerInSecondsDefault = 600;
}
}