rename doc to upsert in update API

a better descriptive name for it, and won't clash with future features on the update api
This commit is contained in:
Shay Banon 2012-06-13 12:42:10 +02:00
parent e4b11e0b15
commit 0b4fe4add3
5 changed files with 49 additions and 49 deletions

View File

@ -165,11 +165,11 @@ public class TransportUpdateAction extends TransportInstanceSingleOperationActio
// no doc, what to do, what to do... // no doc, what to do, what to do...
if (!getResult.exists()) { if (!getResult.exists()) {
if (request.indexRequest() == null) { if (request.upsertRequest() == null) {
listener.onFailure(new DocumentMissingException(new ShardId(request.index(), request.shardId()), request.type(), request.id())); listener.onFailure(new DocumentMissingException(new ShardId(request.index(), request.shardId()), request.type(), request.id()));
return; return;
} }
IndexRequest indexRequest = request.indexRequest(); IndexRequest indexRequest = request.upsertRequest();
indexRequest.index(request.index()).type(request.type()).id(request.id()) indexRequest.index(request.index()).type(request.type()).id(request.id())
// it has to be a "create!" // it has to be a "create!"
.create(true) .create(true)

View File

@ -63,7 +63,7 @@ public class UpdateRequest extends InstanceShardOperationRequest {
private ReplicationType replicationType = ReplicationType.DEFAULT; private ReplicationType replicationType = ReplicationType.DEFAULT;
private WriteConsistencyLevel consistencyLevel = WriteConsistencyLevel.DEFAULT; private WriteConsistencyLevel consistencyLevel = WriteConsistencyLevel.DEFAULT;
private IndexRequest indexRequest; private IndexRequest upsertRequest;
UpdateRequest() { UpdateRequest() {
@ -339,68 +339,68 @@ public class UpdateRequest extends InstanceShardOperationRequest {
* Sets the index request to be used if the document does not exists. Otherwise, a {@link org.elasticsearch.index.engine.DocumentMissingException} * Sets the index request to be used if the document does not exists. Otherwise, a {@link org.elasticsearch.index.engine.DocumentMissingException}
* is thrown. * is thrown.
*/ */
public UpdateRequest doc(IndexRequest indexRequest) { public UpdateRequest upsert(IndexRequest upsertRequest) {
this.indexRequest = indexRequest; this.upsertRequest = upsertRequest;
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(XContentBuilder source) { public UpdateRequest upsert(XContentBuilder source) {
safeIndexRequest().source(source); safeUpsertRequest().source(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(Map source) { public UpdateRequest upsert(Map source) {
safeIndexRequest().source(source); safeUpsertRequest().source(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(Map source, XContentType contentType) { public UpdateRequest upsert(Map source, XContentType contentType) {
safeIndexRequest().source(source, contentType); safeUpsertRequest().source(source, contentType);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(String source) { public UpdateRequest upsert(String source) {
safeIndexRequest().source(source); safeUpsertRequest().source(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(byte[] source) { public UpdateRequest upsert(byte[] source) {
safeIndexRequest().source(source); safeUpsertRequest().source(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequest doc(byte[] source, int offset, int length) { public UpdateRequest upsert(byte[] source, int offset, int length) {
safeIndexRequest().source(source, offset, length); safeUpsertRequest().source(source, offset, length);
return this; return this;
} }
public IndexRequest indexRequest() { public IndexRequest upsertRequest() {
return this.indexRequest; return this.upsertRequest;
} }
private IndexRequest safeIndexRequest() { private IndexRequest safeUpsertRequest() {
if (indexRequest == null) { if (upsertRequest == null) {
indexRequest = new IndexRequest(); upsertRequest = new IndexRequest();
} }
return indexRequest; return upsertRequest;
} }
@Override @Override
@ -431,8 +431,8 @@ public class UpdateRequest extends InstanceShardOperationRequest {
} }
} }
if (in.readBoolean()) { if (in.readBoolean()) {
indexRequest = new IndexRequest(); upsertRequest = new IndexRequest();
indexRequest.readFrom(in); upsertRequest.readFrom(in);
} }
} }
@ -473,15 +473,15 @@ public class UpdateRequest extends InstanceShardOperationRequest {
out.writeUTF(field); out.writeUTF(field);
} }
} }
if (indexRequest == null) { if (upsertRequest == null) {
out.writeBoolean(false); out.writeBoolean(false);
} else { } else {
out.writeBoolean(true); out.writeBoolean(true);
// make sure the basics are set // make sure the basics are set
indexRequest.index(index); upsertRequest.index(index);
indexRequest.type(type); upsertRequest.type(type);
indexRequest.id(id); upsertRequest.id(id);
indexRequest.writeTo(out); upsertRequest.writeTo(out);
} }
} }
} }

View File

@ -187,56 +187,56 @@ public class UpdateRequestBuilder extends BaseRequestBuilder<UpdateRequest, Upda
* Sets the index request to be used if the document does not exists. Otherwise, a {@link org.elasticsearch.index.engine.DocumentMissingException} * Sets the index request to be used if the document does not exists. Otherwise, a {@link org.elasticsearch.index.engine.DocumentMissingException}
* is thrown. * is thrown.
*/ */
public UpdateRequestBuilder setDoc(IndexRequest indexRequest) { public UpdateRequestBuilder setUpsert(IndexRequest indexRequest) {
request.doc(indexRequest); request.upsert(indexRequest);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(XContentBuilder source) { public UpdateRequestBuilder setUpsert(XContentBuilder source) {
request.doc(source); request.upsert(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(Map source) { public UpdateRequestBuilder setUpsert(Map source) {
request.doc(source); request.upsert(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(Map source, XContentType contentType) { public UpdateRequestBuilder setUpsert(Map source, XContentType contentType) {
request.doc(source, contentType); request.upsert(source, contentType);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(String source) { public UpdateRequestBuilder setUpsert(String source) {
request.doc(source); request.upsert(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(byte[] source) { public UpdateRequestBuilder setUpsert(byte[] source) {
request.doc(source); request.upsert(source);
return this; return this;
} }
/** /**
* Sets the doc source of the update request to be used when the document does not exists. * Sets the doc source of the update request to be used when the document does not exists.
*/ */
public UpdateRequestBuilder setDoc(byte[] source, int offset, int length) { public UpdateRequestBuilder setUpsert(byte[] source, int offset, int length) {
request.doc(source, offset, length); request.upsert(source, offset, length);
return this; return this;
} }

View File

@ -104,9 +104,9 @@ public class RestUpdateAction extends BaseRestHandler {
if (content.containsKey("params")) { if (content.containsKey("params")) {
updateRequest.scriptParams((Map<String, Object>) content.get("params")); updateRequest.scriptParams((Map<String, Object>) content.get("params"));
} }
if (content.containsKey("doc")) { if (content.containsKey("upsert")) {
IndexRequest indexRequest = new IndexRequest(); IndexRequest indexRequest = new IndexRequest();
indexRequest.source((Map) content.get("doc"), xContentType); indexRequest.source((Map) content.get("upsert"), xContentType);
indexRequest.routing(request.param("routing")); indexRequest.routing(request.param("routing"));
indexRequest.parent(request.param("parent")); // order is important, set it after routing, so it will set the routing indexRequest.parent(request.param("parent")); // order is important, set it after routing, so it will set the routing
indexRequest.timestamp(request.param("timestamp")); indexRequest.timestamp(request.param("timestamp"));
@ -115,7 +115,7 @@ public class RestUpdateAction extends BaseRestHandler {
} }
indexRequest.version(RestActions.parseVersion(request)); indexRequest.version(RestActions.parseVersion(request));
indexRequest.versionType(VersionType.fromString(request.param("version_type"), indexRequest.versionType())); indexRequest.versionType(VersionType.fromString(request.param("version_type"), indexRequest.versionType()));
updateRequest.doc(indexRequest); updateRequest.upsert(indexRequest);
} }
} catch (Exception e) { } catch (Exception e) {
try { try {

View File

@ -92,7 +92,7 @@ public class UpdateTests extends AbstractNodesTests {
assertThat(clusterHealth.status(), equalTo(ClusterHealthStatus.GREEN)); assertThat(clusterHealth.status(), equalTo(ClusterHealthStatus.GREEN));
client.prepareUpdate("test", "type1", "1") client.prepareUpdate("test", "type1", "1")
.setDoc(XContentFactory.jsonBuilder().startObject().field("field", 1).endObject()) .setUpsert(XContentFactory.jsonBuilder().startObject().field("field", 1).endObject())
.setScript("ctx._source.field += 1") .setScript("ctx._source.field += 1")
.execute().actionGet(); .execute().actionGet();
@ -102,7 +102,7 @@ public class UpdateTests extends AbstractNodesTests {
} }
client.prepareUpdate("test", "type1", "1") client.prepareUpdate("test", "type1", "1")
.setDoc(XContentFactory.jsonBuilder().startObject().field("field", 1).endObject()) .setUpsert(XContentFactory.jsonBuilder().startObject().field("field", 1).endObject())
.setScript("ctx._source.field += 1") .setScript("ctx._source.field += 1")
.execute().actionGet(); .execute().actionGet();