|
20 | 20 | import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder;
|
21 | 21 | import org.elasticsearch.search.aggregations.metrics.MetricsAggregationBuilder;
|
22 | 22 | import org.elasticsearch.search.aggregations.metrics.ValuesSourceMetricsAggregationBuilder;
|
| 23 | +import org.elasticsearch.search.aggregations.metrics.scripted.ScriptedMetricBuilder; |
23 | 24 | import org.elasticsearch.search.aggregations.metrics.tophits.TopHitsBuilder;
|
24 | 25 | import org.elasticsearch.search.sort.SortOrder;
|
25 | 26 | import org.nlpcn.es4sql.Util;
|
@@ -92,6 +93,8 @@ public AbstractAggregationBuilder makeFieldAgg(MethodField field, AbstractAggreg
|
92 | 93 | return builder;
|
93 | 94 | case "TOPHITS":
|
94 | 95 | return makeTopHitsAgg(field);
|
| 96 | + case "SCRIPTED_METRIC": |
| 97 | + return scriptedMetric(field); |
95 | 98 | case "COUNT":
|
96 | 99 | groupMap.put(field.getAlias(), new KVValue("COUNT", parent));
|
97 | 100 | return makeCountAgg(field);
|
@@ -136,6 +139,61 @@ private AggregationBuilder<?> makeRangeGroup(MethodField field) throws SqlParseE
|
136 | 139 |
|
137 | 140 | }
|
138 | 141 |
|
| 142 | + private AbstractAggregationBuilder scriptedMetric(MethodField field) throws SqlParseException { |
| 143 | + String aggName = gettAggNameFromParamsOrAlias(field); |
| 144 | + ScriptedMetricBuilder scriptedMetricBuilder = AggregationBuilders.scriptedMetric(aggName); |
| 145 | + Map<String, Object> scriptedMetricParams = field.getParamsAsMap(); |
| 146 | + if(!scriptedMetricParams.containsKey("map_script") && !scriptedMetricParams.containsKey("map_script_id") && !scriptedMetricParams.containsKey("map_script_file")){ |
| 147 | + throw new SqlParseException("scripted metric parameters must contain map_script/map_script_id/map_script_file parameter"); |
| 148 | + } |
| 149 | + for(Map.Entry<String,Object> param : scriptedMetricParams.entrySet()) { |
| 150 | + String paramValue = param.getValue().toString(); |
| 151 | + switch (param.getKey().toLowerCase()) { |
| 152 | + case "map_script": |
| 153 | + scriptedMetricBuilder.mapScript(paramValue); |
| 154 | + break; |
| 155 | + case "map_script_id": |
| 156 | + scriptedMetricBuilder.mapScriptId(paramValue); |
| 157 | + break; |
| 158 | + case "map_script_file": |
| 159 | + scriptedMetricBuilder.mapScriptFile(paramValue); |
| 160 | + break; |
| 161 | + case "init_script": |
| 162 | + scriptedMetricBuilder.initScript(paramValue); |
| 163 | + break; |
| 164 | + case "init_script_id": |
| 165 | + scriptedMetricBuilder.initScriptId(paramValue); |
| 166 | + break; |
| 167 | + case "init_script_file": |
| 168 | + scriptedMetricBuilder.initScriptFile(paramValue); |
| 169 | + break; |
| 170 | + case "combine_script": |
| 171 | + scriptedMetricBuilder.combineScript(paramValue); |
| 172 | + break; |
| 173 | + case "combine_script_id": |
| 174 | + scriptedMetricBuilder.combineScriptId(paramValue); |
| 175 | + break; |
| 176 | + case "combine_script_file": |
| 177 | + scriptedMetricBuilder.combineScriptFile(paramValue); |
| 178 | + break; |
| 179 | + case "reduce_script": |
| 180 | + scriptedMetricBuilder.reduceScript(paramValue); |
| 181 | + break; |
| 182 | + case "reduce_script_id": |
| 183 | + scriptedMetricBuilder.reduceScriptId(paramValue); |
| 184 | + break; |
| 185 | + case "reduce_script_file": |
| 186 | + scriptedMetricBuilder.reduceScriptFile(paramValue); |
| 187 | + break; |
| 188 | + case "alias": |
| 189 | + break; |
| 190 | + default: |
| 191 | + throw new SqlParseException("scripted_metric err or not define field " + param.getKey()); |
| 192 | + } |
| 193 | + } |
| 194 | + return scriptedMetricBuilder; |
| 195 | + } |
| 196 | + |
139 | 197 | private AggregationBuilder<?> geohashGrid(MethodField field) throws SqlParseException {
|
140 | 198 | String aggName = gettAggNameFromParamsOrAlias(field);
|
141 | 199 | GeoHashGridBuilder geoHashGrid = AggregationBuilders.geohashGrid(aggName);
|
|
0 commit comments