com.sksamuel.elastic4s.handlers.delete.DeleteHandlers.scala Maven / Gradle / Ivy
package com.sksamuel.elastic4s.handlers.delete
import com.sksamuel.elastic4s.ext.OptionImplicits.RichOption
import com.sksamuel.elastic4s.handlers.{ElasticErrorParser, VersionTypeHttpString}
import com.sksamuel.elastic4s.handlers.searches.queries.QueryBuilderFn
import com.sksamuel.elastic4s.json.{XContentBuilder, XContentFactory}
import com.sksamuel.elastic4s.requests.common.{RefreshPolicyHttpValue, Slicing}
import com.sksamuel.elastic4s.requests.delete.{DeleteByIdRequest, DeleteByQueryRequest, DeleteByQueryResponse, DeleteResponse}
import com.sksamuel.elastic4s.requests.task.CreateTaskResponse
import com.sksamuel.elastic4s.{ElasticError, ElasticRequest, ElasticUrlEncoder, Handler, HttpEntity, HttpResponse, ResponseHandler}
object DeleteByQueryBodyFn {
def apply(request: DeleteByQueryRequest): XContentBuilder = {
val builder = XContentFactory.jsonBuilder()
builder.rawField("query", QueryBuilderFn(request.query))
request.slice.foreach { slice =>
builder.startObject("slice")
builder.field("id", slice.id)
builder.field("max", slice.max)
builder.endObject()
}
builder.endObject()
builder
}
}
trait DeleteHandlers {
implicit object DeleteByQueryHandler extends Handler[DeleteByQueryRequest, Either[DeleteByQueryResponse, CreateTaskResponse]] {
override def responseHandler: ResponseHandler[Either[DeleteByQueryResponse, CreateTaskResponse]] = new ResponseHandler[Either[DeleteByQueryResponse, CreateTaskResponse]] {
override def handle(response: HttpResponse): Either[ElasticError, Either[DeleteByQueryResponse, CreateTaskResponse]] =
response.statusCode match {
case 200 | 201 =>
val entity = response.entity.getOrError("No entity defined but was expected")
entity.get match {
case TaskRegex(nodeId, taskId) => Right(Right(CreateTaskResponse(nodeId, taskId)))
case _ => Right(Left(ResponseHandler.fromResponse[DeleteByQueryResponse](response)))
}
case _ => Left(ElasticErrorParser.parse(response))
}
}
override def build(request: DeleteByQueryRequest): ElasticRequest = {
val endpoint = s"/${request.indexes.values.map(ElasticUrlEncoder.encodeUrlFragment).mkString(",")}/_delete_by_query"
val params = scala.collection.mutable.Map.empty[String, String]
if (request.proceedOnConflicts.getOrElse(false))
params.put("conflicts", "proceed")
request.refresh.map(RefreshPolicyHttpValue.apply).foreach(params.put("refresh", _))
request.requestsPerSecond.map(_.toString).foreach(params.put("requests_per_second", _))
request.timeout.map(_.toMillis + "ms").foreach(params.put("timeout", _))
request.scrollSize.map(_.toString).foreach(params.put("scroll_size", _))
request.routing.map(_.toString).foreach(params.put("routing", _))
request.maxDocs.map(_.toString).foreach(params.put("max_docs", _))
request.waitForActiveShards.map(_.toString).foreach(params.put("wait_for_active_shards", _))
request.waitForCompletion.map(_.toString).foreach(params.put("wait_for_completion", _))
request.slices.foreach(s =>
if (s == Slicing.AutoSlices) params.put("slices", Slicing.AutoSlicesValue) else params.put("slices", s.toString)
)
request.ignoreUnavailable.map(_.toString).foreach(params.put("ignore_unavailable", _))
val body = DeleteByQueryBodyFn(request)
logger.debug(s"Delete by query ${body.string}")
val entity = HttpEntity(body.string, "application/json")
ElasticRequest("POST", endpoint, params.toMap, entity)
}
}
implicit object DeleteByIdHandler extends Handler[DeleteByIdRequest, DeleteResponse] {
override def responseHandler: ResponseHandler[DeleteResponse] = new ResponseHandler[DeleteResponse] {
override def handle(response: HttpResponse): Either[ElasticError, DeleteResponse] = {
def right = Right(ResponseHandler.fromResponse[DeleteResponse](response))
def left = Left(ElasticErrorParser.parse(response))
response.statusCode match {
case 200 | 201 => right
// annoying, 404s can return different types of data for a delete
case 404 =>
response.entity match {
case None => Left(ElasticErrorParser.parse(response))
case Some(e) =>
val node = ResponseHandler.json(e)
if (node.has("error")) left else right
}
case _ => left
}
}
}
override def build(request: DeleteByIdRequest): ElasticRequest = {
val endpoint =
s"/${ElasticUrlEncoder.encodeUrlFragment(request.index.index)}/_doc/${ElasticUrlEncoder.encodeUrlFragment(request.id.toString)}"
val params = scala.collection.mutable.Map.empty[String, String]
request.parent.foreach(params.put("parent", _))
request.routing.foreach(params.put("routing", _))
request.refresh.map(RefreshPolicyHttpValue.apply).foreach(params.put("refresh", _))
request.version.map(_.toString).foreach(params.put("version", _))
request.ifPrimaryTerm.map(_.toString).foreach(params.put("if_primary_term", _))
request.ifSeqNo.map(_.toString).foreach(params.put("if_seq_no", _))
request.versionType.map(VersionTypeHttpString.apply).foreach(params.put("version_type", _))
request.waitForActiveShards.foreach(params.put("wait_for_active_shards", _))
ElasticRequest("DELETE", endpoint, params.toMap)
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy