forked from snowplow/snowplow-java-tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTiming.java
More file actions
121 lines (103 loc) · 3.82 KB
/
Timing.java
File metadata and controls
121 lines (103 loc) · 3.82 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
/*
* Copyright (c) 2015 Snowplow Analytics Ltd. All rights reserved.
*
* This program is licensed to you under the Apache License Version 2.0,
* and you may not use this file except in compliance with the Apache License Version 2.0.
* You may obtain a copy of the Apache License Version 2.0 at http://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the Apache License Version 2.0 is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the Apache License Version 2.0 for the specific language governing permissions and limitations there under.
*/
package com.snowplowanalytics.snowplow.tracker.events;
// Java
import java.util.LinkedHashMap;
// Google
import com.google.common.base.Preconditions;
// This library
import com.snowplowanalytics.snowplow.tracker.constants.Parameter;
import com.snowplowanalytics.snowplow.tracker.constants.Constants;
import com.snowplowanalytics.snowplow.tracker.payload.SelfDescribingJson;
public class Timing extends AbstractEvent {
private final String category;
private final String variable;
private final Integer timing;
private final String label;
public static abstract class Builder<T extends Builder<T>> extends AbstractEvent.Builder<T> {
private String category;
private String variable;
private Integer timing;
private String label;
/**
* @param category The category of the timed event
* @return itself
*/
public T category(String category) {
this.category = category;
return self();
}
/**
* @param variable Identify the timing being recorded
* @return itself
*/
public T variable(String variable) {
this.variable = variable;
return self();
}
/**
* @param timing The number of milliseconds in elapsed time to report
* @return itself
*/
public T timing(Integer timing) {
this.timing = timing;
return self();
}
/**
* @param label Optional description of this timing
* @return itself
*/
public T label(String label) {
this.label = label;
return self();
}
public Timing build() {
return new Timing(this);
}
}
private static class Builder2 extends Builder<Builder2> {
@Override
protected Builder2 self() {
return this;
}
}
public static Builder<?> builder() {
return new Builder2();
}
protected Timing(Builder<?> builder) {
super(builder);
// Precondition checks
Preconditions.checkNotNull(builder.category);
Preconditions.checkNotNull(builder.timing);
Preconditions.checkNotNull(builder.variable);
Preconditions.checkArgument(!builder.category.isEmpty(), "category cannot be empty");
Preconditions.checkArgument(!builder.variable.isEmpty(), "variable cannot be empty");
this.category = builder.category;
this.variable = builder.variable;
this.label = builder.label;
this.timing = builder.timing;
}
/**
* Return the payload wrapped into a SelfDescribingJson.
*
* @return the payload as a SelfDescribingJson.
*/
public SelfDescribingJson getPayload() {
LinkedHashMap<String,Object> payload = new LinkedHashMap<>();
payload.put(Parameter.UT_CATEGORY, this.category);
payload.put(Parameter.UT_LABEL, this.label);
payload.put(Parameter.UT_TIMING, this.timing);
payload.put(Parameter.UT_VARIABLE, this.variable);
return new SelfDescribingJson(Constants.SCHEMA_USER_TIMINGS, payload);
}
}