forked from prebid/prebid-server-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLogAnalyticsReporter.java
More file actions
59 lines (48 loc) · 1.76 KB
/
LogAnalyticsReporter.java
File metadata and controls
59 lines (48 loc) · 1.76 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
package org.prebid.server.analytics;
import com.fasterxml.jackson.annotation.JsonUnwrapped;
import io.vertx.core.logging.Logger;
import io.vertx.core.logging.LoggerFactory;
import lombok.AllArgsConstructor;
import lombok.Value;
import org.prebid.server.analytics.model.AmpEvent;
import org.prebid.server.analytics.model.AuctionEvent;
import org.prebid.server.analytics.model.CookieSyncEvent;
import org.prebid.server.analytics.model.SetuidEvent;
import org.prebid.server.analytics.model.VideoEvent;
import org.prebid.server.json.JacksonMapper;
import java.util.Objects;
/**
* {@link AnalyticsReporter} implementation that writes application events to a log, for illustration purpose only.
*/
public class LogAnalyticsReporter implements AnalyticsReporter {
public static final Logger logger = LoggerFactory.getLogger(LogAnalyticsReporter.class);
private final JacksonMapper mapper;
public LogAnalyticsReporter(JacksonMapper mapper) {
this.mapper = Objects.requireNonNull(mapper);
}
@Override
public <T> void processEvent(T event) {
final String type;
if (event instanceof AuctionEvent) {
type = "/openrtb2/auction";
} else if (event instanceof AmpEvent) {
type = "/openrtb2/amp";
} else if (event instanceof VideoEvent) {
type = "/openrtb2/video";
} else if (event instanceof SetuidEvent) {
type = "/setuid";
} else if (event instanceof CookieSyncEvent) {
type = "/cookie_sync";
} else {
type = "unknown";
}
logger.debug(mapper.encode(new LogEvent<>(type, event)));
}
@AllArgsConstructor
@Value
private static class LogEvent<T> {
String type;
@JsonUnwrapped
T event;
}
}