com.sksamuel.elastic4s.handlers.index.IndexHandlers.scala Maven / Gradle / Ivy
package com.sksamuel.elastic4s.handlers.index
import com.fasterxml.jackson.annotation.JsonProperty
import com.sksamuel.elastic4s.HttpEntity.ByteArrayEntity
import com.sksamuel.elastic4s._
import com.sksamuel.elastic4s.ext.Maps
import com.sksamuel.elastic4s.handlers.{ElasticErrorParser, VersionTypeHttpString}
import com.sksamuel.elastic4s.requests.common.RefreshPolicyHttpValue
import com.sksamuel.elastic4s.requests.indexes.analyze.{AnalyzeRequest, AnalyzeResponse}
import com.sksamuel.elastic4s.requests.indexes.{GetIndexRequest, IndexRequest, IndexResponse}
import java.nio.charset.StandardCharsets
trait IndexHandlers {
implicit object IndexHandler extends Handler[IndexRequest, IndexResponse] {
override def responseHandler: ResponseHandler[IndexResponse] = new ResponseHandler[IndexResponse] {
override def handle(response: HttpResponse): Either[ElasticError, IndexResponse] = response.statusCode match {
case 201 | 200 => Right(ResponseHandler.fromResponse[IndexResponse](response))
case 400 | 401 | 403 | 409 | 500 => Left(ElasticErrorParser.parse(response))
case _ => sys.error(response.toString)
}
}
override def build(request: IndexRequest): ElasticRequest = {
val (method, endpoint) = request.id match {
case Some(id) =>
"PUT" -> s"/${ElasticUrlEncoder.encodeUrlFragment(request.index.name)}/_doc/${ElasticUrlEncoder.encodeUrlFragment(id.toString)}"
case None =>
"POST" -> s"/${ElasticUrlEncoder.encodeUrlFragment(request.index.name)}/_doc"
}
val params = scala.collection.mutable.Map.empty[String, String]
request.createOnly.foreach(
createOnly =>
if (createOnly)
params.put("op_type", "create")
)
request.routing.foreach(params.put("routing", _))
request.parent.foreach(params.put("parent", _))
request.timeout.foreach(params.put("timeout", _))
request.pipeline.foreach(params.put("pipeline", _))
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", _))
val body = IndexContentBuilder(request)
val entity = ByteArrayEntity(body.getBytes(StandardCharsets.UTF_8), Some("application/json"))
logger.debug(s"Endpoint=$endpoint")
ElasticRequest(method, endpoint, params.toMap, entity)
}
}
implicit object GetIndexHandler extends Handler[GetIndexRequest, Map[String, GetIndexResponse]] {
override def build(request: GetIndexRequest): ElasticRequest = {
val endpoint = "/" + request.index
val method = "GET"
ElasticRequest(method, endpoint)
}
override def responseHandler: ResponseHandler[Map[String, GetIndexResponse]] = {
ResponseHandler.default[Map[String, GetIndexResponse]].map { map =>
map.mapValues { resp => if (resp.mappings.meta == null) resp.copy(mappings = resp.mappings.copy(meta = Map.empty)) else resp }.toMap
}
}
}
implicit object AnalyzeRequestHandler extends Handler[AnalyzeRequest, AnalyzeResponse] {
override def responseHandler: ResponseHandler[AnalyzeResponse] = AnalyzeResponseHandler
override def build(analyzeRequest: AnalyzeRequest): ElasticRequest = {
val utf8 = StandardCharsets.UTF_8.name()
val (method, endpoint) = analyzeRequest.index.map { index =>
"GET" -> s"/${ElasticUrlEncoder.encodeUrlFragment(index)}/_analyze"
}.getOrElse {
"GET" -> s"/_analyze"
}
val body = AnalyseRequestContentBuilder(analyzeRequest)
val entity = ByteArrayEntity(body.getBytes(StandardCharsets.UTF_8), Some("application/json"))
logger.debug(s"Endpoint=$endpoint")
ElasticRequest(method, endpoint, Map.empty[String, Any], entity)
}
}
}
case class Mapping(properties: Map[String, Field],
@JsonProperty("_meta") meta: Map[String, Any] = Map.empty)
case class Field(`type`: Option[String], properties: Option[Map[String, Field]] = None)
case class GetIndexResponse(aliases: Map[String, Map[String, Any]],
mappings: Mapping,
@JsonProperty("settings") private val _settings: Map[String, Any]) {
def settings: Map[String, Any] = Maps.flatten(_settings, ".")
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy