/
MonitoringLoggerConfig.java
106 lines (86 loc) · 3.1 KB
/
MonitoringLoggerConfig.java
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
/*
* Copyright (c) 2019 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0
*
* SPDX-License-Identifier: EPL-2.0
*/
package org.eclipse.ditto.services.connectivity.messaging.config;
import java.time.Duration;
import javax.annotation.concurrent.Immutable;
import org.eclipse.ditto.services.utils.config.KnownConfigValue;
/**
* Configuration for monitoring loggers.
*/
@Immutable
public interface MonitoringLoggerConfig {
/**
* Returns the number of success logs stored for each {@link org.eclipse.ditto.model.connectivity.LogCategory} and
* {@link org.eclipse.ditto.model.connectivity.LogType}.
*
* @return the success capacity.
*/
int successCapacity();
/**
* Returns the number of failure logs stored for each {@link org.eclipse.ditto.model.connectivity.LogCategory} and
* {@link org.eclipse.ditto.model.connectivity.LogType}.
*
* @return the failure capacity.
*/
int failureCapacity();
/**
* Returns how long logs will stay enabled after enabling them.
*
* @return the logging duration.
*/
Duration logDuration();
/**
* Returns interval in which we check if logging timeframe was exceeded and logs need to be disabled.
*
* @return the interval.
*/
Duration loggingActiveCheckInterval();
/**
* An enumeration of the known config path expressions and their associated default values for {@code
* ExponentialBackOffConfig}.
*/
enum MonitoringLoggerConfigValue implements KnownConfigValue {
/**
* The number of success logs stored for each {@link org.eclipse.ditto.model.connectivity.LogCategory} and
* {@link org.eclipse.ditto.model.connectivity.LogType}.
*/
SUCCESS_CAPACITY("successCapacity", 10),
/**
* The number of failure logs stored for each {@link org.eclipse.ditto.model.connectivity.LogCategory} and
* {@link org.eclipse.ditto.model.connectivity.LogType}.
*/
FAILURE_CAPACITY("failureCapacity", 10),
/**
* How long logs will stay enabled after enabling them.
*/
LOG_DURATION("logDuration", Duration.ofHours(1)),
/**
* Interval in which we check if logging timeframe was exceeded and logs need to be disabled.
*/
LOGGING_ACTIVE_CHECK_INTERVAL("loggingActiveCheckInterval", Duration.ofMinutes(5));
private final String path;
private final Object defaultValue;
MonitoringLoggerConfigValue(final String thePath, final Object theDefaultValue) {
path = thePath;
defaultValue = theDefaultValue;
}
@Override
public Object getDefaultValue() {
return defaultValue;
}
@Override
public String getConfigPath() {
return path;
}
}
}