Fix DeleteRequest / GetRequest / UpdateRequest / ExplainRequest validation for null and/or empty id/type (#35314)
Closes #35297
This commit is contained in:
parent
42dcdd0aa8
commit
a467a816bc
|
@ -25,6 +25,7 @@ import org.elasticsearch.action.CompositeIndicesRequest;
|
||||||
import org.elasticsearch.action.DocWriteRequest;
|
import org.elasticsearch.action.DocWriteRequest;
|
||||||
import org.elasticsearch.action.support.replication.ReplicatedWriteRequest;
|
import org.elasticsearch.action.support.replication.ReplicatedWriteRequest;
|
||||||
import org.elasticsearch.common.Nullable;
|
import org.elasticsearch.common.Nullable;
|
||||||
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.io.stream.StreamInput;
|
import org.elasticsearch.common.io.stream.StreamInput;
|
||||||
import org.elasticsearch.common.io.stream.StreamOutput;
|
import org.elasticsearch.common.io.stream.StreamOutput;
|
||||||
import org.elasticsearch.common.lucene.uid.Versions;
|
import org.elasticsearch.common.lucene.uid.Versions;
|
||||||
|
@ -83,13 +84,13 @@ public class DeleteRequest extends ReplicatedWriteRequest<DeleteRequest>
|
||||||
@Override
|
@Override
|
||||||
public ActionRequestValidationException validate() {
|
public ActionRequestValidationException validate() {
|
||||||
ActionRequestValidationException validationException = super.validate();
|
ActionRequestValidationException validationException = super.validate();
|
||||||
if (type == null) {
|
if (Strings.isEmpty(type)) {
|
||||||
validationException = addValidationError("type is missing", validationException);
|
validationException = addValidationError("type is missing", validationException);
|
||||||
}
|
}
|
||||||
if (id == null) {
|
if (Strings.isEmpty(id)) {
|
||||||
validationException = addValidationError("id is missing", validationException);
|
validationException = addValidationError("id is missing", validationException);
|
||||||
}
|
}
|
||||||
if (!versionType.validateVersionForWrites(version)) {
|
if (versionType.validateVersionForWrites(version) == false) {
|
||||||
validationException = addValidationError("illegal version value [" + version + "] for version type ["
|
validationException = addValidationError("illegal version value [" + version + "] for version type ["
|
||||||
+ versionType.name() + "]", validationException);
|
+ versionType.name() + "]", validationException);
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,8 @@ import org.elasticsearch.search.internal.AliasFilter;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static org.elasticsearch.action.ValidateActions.addValidationError;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Explain request encapsulating the explain query and document identifier to get an explanation for.
|
* Explain request encapsulating the explain query and document identifier to get an explanation for.
|
||||||
*/
|
*/
|
||||||
|
@ -152,11 +154,11 @@ public class ExplainRequest extends SingleShardRequest<ExplainRequest> implement
|
||||||
@Override
|
@Override
|
||||||
public ActionRequestValidationException validate() {
|
public ActionRequestValidationException validate() {
|
||||||
ActionRequestValidationException validationException = super.validateNonNullIndex();
|
ActionRequestValidationException validationException = super.validateNonNullIndex();
|
||||||
if (type == null) {
|
if (Strings.isEmpty(type)) {
|
||||||
validationException = ValidateActions.addValidationError("type is missing", validationException);
|
validationException = addValidationError("type is missing", validationException);
|
||||||
}
|
}
|
||||||
if (id == null) {
|
if (Strings.isEmpty(id)) {
|
||||||
validationException = ValidateActions.addValidationError("id is missing", validationException);
|
validationException = addValidationError("id is missing", validationException);
|
||||||
}
|
}
|
||||||
if (query == null) {
|
if (query == null) {
|
||||||
validationException = ValidateActions.addValidationError("query is missing", validationException);
|
validationException = ValidateActions.addValidationError("query is missing", validationException);
|
||||||
|
|
|
@ -25,6 +25,7 @@ import org.elasticsearch.action.RealtimeRequest;
|
||||||
import org.elasticsearch.action.ValidateActions;
|
import org.elasticsearch.action.ValidateActions;
|
||||||
import org.elasticsearch.action.support.single.shard.SingleShardRequest;
|
import org.elasticsearch.action.support.single.shard.SingleShardRequest;
|
||||||
import org.elasticsearch.common.Nullable;
|
import org.elasticsearch.common.Nullable;
|
||||||
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.io.stream.StreamInput;
|
import org.elasticsearch.common.io.stream.StreamInput;
|
||||||
import org.elasticsearch.common.io.stream.StreamOutput;
|
import org.elasticsearch.common.io.stream.StreamOutput;
|
||||||
import org.elasticsearch.common.lucene.uid.Versions;
|
import org.elasticsearch.common.lucene.uid.Versions;
|
||||||
|
@ -33,6 +34,8 @@ import org.elasticsearch.search.fetch.subphase.FetchSourceContext;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static org.elasticsearch.action.ValidateActions.addValidationError;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A request to get a document (its source) from an index based on its type (optional) and id. Best created using
|
* A request to get a document (its source) from an index based on its type (optional) and id. Best created using
|
||||||
* {@link org.elasticsearch.client.Requests#getRequest(String)}.
|
* {@link org.elasticsearch.client.Requests#getRequest(String)}.
|
||||||
|
@ -91,13 +94,13 @@ public class GetRequest extends SingleShardRequest<GetRequest> implements Realti
|
||||||
@Override
|
@Override
|
||||||
public ActionRequestValidationException validate() {
|
public ActionRequestValidationException validate() {
|
||||||
ActionRequestValidationException validationException = super.validateNonNullIndex();
|
ActionRequestValidationException validationException = super.validateNonNullIndex();
|
||||||
if (type == null) {
|
if (Strings.isEmpty(type)) {
|
||||||
validationException = ValidateActions.addValidationError("type is missing", validationException);
|
validationException = addValidationError("type is missing", validationException);
|
||||||
}
|
}
|
||||||
if (id == null) {
|
if (Strings.isEmpty(id)) {
|
||||||
validationException = ValidateActions.addValidationError("id is missing", validationException);
|
validationException = addValidationError("id is missing", validationException);
|
||||||
}
|
}
|
||||||
if (!versionType.validateVersionForReads(version)) {
|
if (versionType.validateVersionForReads(version) == false) {
|
||||||
validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type ["
|
validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type ["
|
||||||
+ versionType.name() + "]", validationException);
|
+ versionType.name() + "]", validationException);
|
||||||
}
|
}
|
||||||
|
|
|
@ -136,10 +136,10 @@ public class UpdateRequest extends InstanceShardOperationRequest<UpdateRequest>
|
||||||
if(upsertRequest != null && upsertRequest.version() != Versions.MATCH_ANY) {
|
if(upsertRequest != null && upsertRequest.version() != Versions.MATCH_ANY) {
|
||||||
validationException = addValidationError("can't provide version in upsert request", validationException);
|
validationException = addValidationError("can't provide version in upsert request", validationException);
|
||||||
}
|
}
|
||||||
if (type == null) {
|
if (Strings.isEmpty(type)) {
|
||||||
validationException = addValidationError("type is missing", validationException);
|
validationException = addValidationError("type is missing", validationException);
|
||||||
}
|
}
|
||||||
if (id == null) {
|
if (Strings.isEmpty(id)) {
|
||||||
validationException = addValidationError("id is missing", validationException);
|
validationException = addValidationError("id is missing", validationException);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Licensed to Elasticsearch under one or more contributor
|
||||||
|
* license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright
|
||||||
|
* ownership. Elasticsearch licenses this file to you under
|
||||||
|
* the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.elasticsearch.action.delete;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
|
import org.elasticsearch.test.ESTestCase;
|
||||||
|
|
||||||
|
import static org.hamcrest.CoreMatchers.hasItems;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
|
||||||
|
public class DeleteRequestTests extends ESTestCase {
|
||||||
|
|
||||||
|
public void testValidation() {
|
||||||
|
{
|
||||||
|
final DeleteRequest request = new DeleteRequest("index4", "_doc", "0");
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, nullValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
final DeleteRequest request = new DeleteRequest("index4", randomBoolean() ? "" : null, randomBoolean() ? "" : null);
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, not(nullValue()));
|
||||||
|
assertThat(validate.validationErrors(), hasItems("type is missing", "id is missing"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.action.explain;
|
package org.elasticsearch.action.explain;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
import org.elasticsearch.common.io.stream.BytesStreamOutput;
|
import org.elasticsearch.common.io.stream.BytesStreamOutput;
|
||||||
import org.elasticsearch.common.io.stream.NamedWriteableAwareStreamInput;
|
import org.elasticsearch.common.io.stream.NamedWriteableAwareStreamInput;
|
||||||
import org.elasticsearch.common.io.stream.NamedWriteableRegistry;
|
import org.elasticsearch.common.io.stream.NamedWriteableRegistry;
|
||||||
|
@ -35,6 +36,10 @@ import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.hamcrest.CoreMatchers.hasItems;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
|
||||||
public class ExplainRequestTests extends ESTestCase {
|
public class ExplainRequestTests extends ESTestCase {
|
||||||
private NamedWriteableRegistry namedWriteableRegistry;
|
private NamedWriteableRegistry namedWriteableRegistry;
|
||||||
|
|
||||||
|
@ -70,4 +75,24 @@ public class ExplainRequestTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testValidation() {
|
||||||
|
{
|
||||||
|
final ExplainRequest request = new ExplainRequest("index4", "_doc", "0");
|
||||||
|
request.query(QueryBuilders.termQuery("field", "value"));
|
||||||
|
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, nullValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
final ExplainRequest request = new ExplainRequest("index4", randomBoolean() ? "" : null, randomBoolean() ? "" : null);
|
||||||
|
request.query(QueryBuilders.termQuery("field", "value"));
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, not(nullValue()));
|
||||||
|
assertThat(validate.validationErrors(), hasItems("type is missing", "id is missing"));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Licensed to Elasticsearch under one or more contributor
|
||||||
|
* license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright
|
||||||
|
* ownership. Elasticsearch licenses this file to you under
|
||||||
|
* the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.elasticsearch.action.get;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
|
import org.elasticsearch.test.ESTestCase;
|
||||||
|
|
||||||
|
import static org.hamcrest.CoreMatchers.hasItems;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
|
||||||
|
public class GetRequestTests extends ESTestCase {
|
||||||
|
|
||||||
|
public void testValidation() {
|
||||||
|
{
|
||||||
|
final GetRequest request = new GetRequest("index4", "_doc", "0");
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, nullValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
final GetRequest request = new GetRequest("index4", randomBoolean() ? "" : null, randomBoolean() ? "" : null);
|
||||||
|
final ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, not(nullValue()));
|
||||||
|
assertThat(validate.validationErrors(), hasItems("type is missing", "id is missing"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
package org.elasticsearch.action.update;
|
package org.elasticsearch.action.update;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
import org.elasticsearch.action.DocWriteResponse;
|
import org.elasticsearch.action.DocWriteResponse;
|
||||||
import org.elasticsearch.action.delete.DeleteRequest;
|
import org.elasticsearch.action.delete.DeleteRequest;
|
||||||
import org.elasticsearch.action.index.IndexRequest;
|
import org.elasticsearch.action.index.IndexRequest;
|
||||||
|
@ -61,6 +62,9 @@ import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.common.xcontent.XContentHelper.toXContent;
|
import static org.elasticsearch.common.xcontent.XContentHelper.toXContent;
|
||||||
import static org.elasticsearch.script.MockScriptEngine.mockInlineScript;
|
import static org.elasticsearch.script.MockScriptEngine.mockInlineScript;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertToXContentEquivalent;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertToXContentEquivalent;
|
||||||
|
import static org.hamcrest.CoreMatchers.hasItems;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
import static org.hamcrest.Matchers.contains;
|
import static org.hamcrest.Matchers.contains;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.instanceOf;
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
@ -511,6 +515,25 @@ public class UpdateRequestTests extends ESTestCase {
|
||||||
assertThat(updateRequest.validate().validationErrors(), contains("can't provide version in upsert request"));
|
assertThat(updateRequest.validate().validationErrors(), contains("can't provide version in upsert request"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testValidate() {
|
||||||
|
{
|
||||||
|
UpdateRequest request = new UpdateRequest("index", "type", "id");
|
||||||
|
request.doc("{}", XContentType.JSON);
|
||||||
|
ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, nullValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
UpdateRequest request = new UpdateRequest("index", randomBoolean() ? "" : null, randomBoolean() ? "" : null);
|
||||||
|
request.doc("{}", XContentType.JSON);
|
||||||
|
ActionRequestValidationException validate = request.validate();
|
||||||
|
|
||||||
|
assertThat(validate, not(nullValue()));
|
||||||
|
assertThat(validate.validationErrors(), hasItems("type is missing", "id is missing"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void testRoutingExtraction() throws Exception {
|
public void testRoutingExtraction() throws Exception {
|
||||||
GetResult getResult = new GetResult("test", "type", "1", 0, false, null, null);
|
GetResult getResult = new GetResult("test", "type", "1", 0, false, null, null);
|
||||||
IndexRequest indexRequest = new IndexRequest("test", "type", "1");
|
IndexRequest indexRequest = new IndexRequest("test", "type", "1");
|
||||||
|
|
Loading…
Reference in New Issue