Throw 400 on unknown metrics in Job Stats (elastic/elasticsearch#446)
Closes elastic/elasticsearch#426 Original commit: elastic/x-pack-elasticsearch@86f136f5c0
This commit is contained in:
parent
b6bdef474d
commit
04445ce95f
|
@ -5,6 +5,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.prelert.action;
|
package org.elasticsearch.xpack.prelert.action;
|
||||||
|
|
||||||
|
import org.elasticsearch.ElasticsearchStatusException;
|
||||||
import org.elasticsearch.action.Action;
|
import org.elasticsearch.action.Action;
|
||||||
import org.elasticsearch.action.ActionListener;
|
import org.elasticsearch.action.ActionListener;
|
||||||
import org.elasticsearch.action.ActionRequestValidationException;
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
|
@ -50,6 +51,7 @@ import org.elasticsearch.xpack.prelert.utils.ExceptionsHelper;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
@ -62,12 +64,16 @@ public class GetJobsAction extends Action<GetJobsAction.Request, GetJobsAction.R
|
||||||
public static final GetJobsAction INSTANCE = new GetJobsAction();
|
public static final GetJobsAction INSTANCE = new GetJobsAction();
|
||||||
public static final String NAME = "cluster:admin/prelert/jobs/get";
|
public static final String NAME = "cluster:admin/prelert/jobs/get";
|
||||||
|
|
||||||
|
private static final String ALL = "_all";
|
||||||
private static final String CONFIG = "config";
|
private static final String CONFIG = "config";
|
||||||
private static final String DATA_COUNTS = "data_counts";
|
private static final String DATA_COUNTS = "data_counts";
|
||||||
private static final String MODEL_SIZE_STATS = "model_size_stats";
|
private static final String MODEL_SIZE_STATS = "model_size_stats";
|
||||||
private static final String SCHEDULER_STATE = "scheduler_state";
|
private static final String SCHEDULER_STATE = "scheduler_state";
|
||||||
private static final String STATUS = "status";
|
private static final String STATUS = "status";
|
||||||
|
|
||||||
|
private static final List<String> METRIC_WHITELIST = Arrays.asList(ALL, CONFIG, DATA_COUNTS,
|
||||||
|
MODEL_SIZE_STATS, SCHEDULER_STATE, STATUS);
|
||||||
|
|
||||||
private GetJobsAction() {
|
private GetJobsAction() {
|
||||||
super(NAME);
|
super(NAME);
|
||||||
}
|
}
|
||||||
|
@ -87,6 +93,8 @@ public class GetJobsAction extends Action<GetJobsAction.Request, GetJobsAction.R
|
||||||
public static final ObjectParser<Request, ParseFieldMatcherSupplier> PARSER = new ObjectParser<>(NAME, Request::new);
|
public static final ObjectParser<Request, ParseFieldMatcherSupplier> PARSER = new ObjectParser<>(NAME, Request::new);
|
||||||
public static final ParseField METRIC = new ParseField("metric");
|
public static final ParseField METRIC = new ParseField("metric");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static {
|
static {
|
||||||
PARSER.declareString(Request::setJobId, Job.ID);
|
PARSER.declareString(Request::setJobId, Job.ID);
|
||||||
PARSER.declareObject(Request::setPageParams, PageParams.PARSER, PageParams.PAGE);
|
PARSER.declareObject(Request::setPageParams, PageParams.PARSER, PageParams.PAGE);
|
||||||
|
@ -171,7 +179,13 @@ public class GetJobsAction extends Action<GetJobsAction.Request, GetJobsAction.R
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setStats(Set<String> stats) {
|
public void setStats(Set<String> stats) {
|
||||||
if (stats.contains("_all")) {
|
for (String s : stats) {
|
||||||
|
if (!METRIC_WHITELIST.contains(s)) {
|
||||||
|
throw new ElasticsearchStatusException("Metric [" + s + "] is not a valid metric. "
|
||||||
|
+ "Accepted metrics are: [" + METRIC_WHITELIST + "]", RestStatus.BAD_REQUEST);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (stats.contains(ALL)) {
|
||||||
all();
|
all();
|
||||||
} else {
|
} else {
|
||||||
config(stats.contains(CONFIG));
|
config(stats.contains(CONFIG));
|
||||||
|
|
|
@ -129,3 +129,11 @@ setup:
|
||||||
- is_false: jobs.0.model_size_stats
|
- is_false: jobs.0.model_size_stats
|
||||||
- match: { jobs.0.scheduler_state.status: STOPPED }
|
- match: { jobs.0.scheduler_state.status: STOPPED }
|
||||||
|
|
||||||
|
---
|
||||||
|
"Test bad metric":
|
||||||
|
- do:
|
||||||
|
catch: request
|
||||||
|
xpack.prelert.get_jobs:
|
||||||
|
job_id: "job-stats-test"
|
||||||
|
metric: "foobar"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue