-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Pivot.java
101 lines (75 loc) · 2.72 KB
/
Pivot.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
package org.graylog.plugins.enterprise.search.searchtypes.pivot;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonTypeName;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.google.auto.value.AutoValue;
import org.graylog.plugins.enterprise.search.Filter;
import org.graylog.plugins.enterprise.search.SearchType;
import javax.annotation.Nullable;
import java.util.Collections;
import java.util.List;
import static com.google.common.collect.ImmutableList.of;
@AutoValue
@JsonTypeName(Pivot.NAME)
@JsonDeserialize(builder = Pivot.Builder.class)
public abstract class Pivot implements SearchType {
public static final String NAME = "pivot";
@Override
public abstract String type();
@Override
@Nullable
@JsonProperty
public abstract String id();
@JsonProperty("row_groups")
public abstract List<BucketSpec> rowGroups();
@JsonProperty("column_groups")
public abstract List<BucketSpec> columnGroups();
@JsonProperty
public abstract List<SeriesSpec> series();
@JsonProperty
public abstract List<SortSpec> sort();
@JsonProperty
public abstract boolean rollup();
@Nullable
@Override
public abstract Filter filter();
@Override
public SearchType applyExecutionContext(ObjectMapper objectMapper, JsonNode state) {
return this;
}
public static Builder builder() {
return new AutoValue_Pivot.Builder()
.type(NAME)
.rowGroups(of())
.columnGroups(of())
.sort(of());
}
@AutoValue.Builder
public static abstract class Builder {
@JsonCreator
public static Builder createDefault() {
return builder()
.sort(Collections.emptyList());
}
@JsonProperty
public abstract Builder type(String type);
@JsonProperty
public abstract Builder id(@Nullable String id);
@JsonProperty("row_groups")
public abstract Builder rowGroups(@Nullable List<BucketSpec> rowGroups);
@JsonProperty("column_groups")
public abstract Builder columnGroups(@Nullable List<BucketSpec> columnGroups);
@JsonProperty
public abstract Builder series(List<SeriesSpec> series);
@JsonProperty
public abstract Builder sort(List<SortSpec> sort);
@JsonProperty
public abstract Builder rollup(boolean rollup);
@JsonProperty
public abstract Builder filter(@Nullable Filter filter);
public abstract Pivot build();
}
}