All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sksamuel.elastic4s.handlers.task.TaskHandlers.scala Maven / Gradle / Ivy

package com.sksamuel.elastic4s.handlers.task

import com.sksamuel.elastic4s.ext.OptionImplicits.RichOption
import com.sksamuel.elastic4s.handlers.ElasticErrorParser
import com.sksamuel.elastic4s.requests.task.{CancelTaskByIdRequest, CancelTasksRequest, GetTask, GetTaskResponse, ListTaskResponse, ListTasks, Node, Task}
import com.sksamuel.elastic4s.{ElasticError, ElasticRequest, Handler, HttpResponse, ResponseHandler}

import scala.util.Try

trait TaskHandlers {

  implicit object GetTaskHandler extends Handler[GetTask, GetTaskResponse] {
    override def build(request: GetTask): ElasticRequest = {
      ElasticRequest("GET", s"/_tasks/${request.nodeId}:${request.taskId}")
    }
  }

  implicit object ListTaskHandler extends Handler[ListTasks, ListTaskResponse] {

    override def build(request: ListTasks): ElasticRequest = {

      val params = scala.collection.mutable.Map.empty[String, String]
      if (request.nodeIds.nonEmpty)
        params.put("nodes", request.nodeIds.mkString(","))
      if (request.actions.nonEmpty)
        params.put("actions", request.actions.mkString(","))
      if (request.detailed.getOrElse(false))
        params.put("detailed", "true")
      if (request.waitForCompletion.getOrElse(false))
        params.put("wait_for_completion", "true")
      request.groupBy.foreach(params.put("group_by", _))

      ElasticRequest("GET", s"/_tasks", params.toMap)
    }
  }

  abstract class AbstractCancelTaskHandler[U] extends Handler[U, Boolean] {

    override def responseHandler: ResponseHandler[Boolean] = new ResponseHandler[Boolean] {
      override def handle(response: HttpResponse): Either[ElasticError, Boolean] = response.statusCode match {
        case 200 | 201 | 202 | 203 | 204 => {
          val entity = response.entity.getOrError("No entity defined")
          // It can fail on a 200 by returning a response containing node_failures
          if (entity.content.contains("node_failures")) Right[ElasticError, Boolean](false)
          else {
            Try(ResponseHandler.fromEntity[ListTaskResponse](entity)).map { (list: ListTaskResponse) =>
              // Check that all the tasks on all the nodes are cancelled
              list.nodes.forall { case (_, node: Node) =>
                node.tasks.forall { case (_, task: Task) =>
                  task.cancelled.getOrElse(false)
                }
              }
            }.toEither.fold((_: Throwable) => Right[ElasticError, Boolean](false), b => Right[ElasticError, Boolean](b))
          }
        }
        case _ =>
          Left[ElasticError, Boolean](ElasticErrorParser.parse(response))
      }
    }

  }

  implicit object CancelTaskHandler extends AbstractCancelTaskHandler[CancelTasksRequest] {

    override def build(request: CancelTasksRequest): ElasticRequest = {

      val params = scala.collection.mutable.Map.empty[String, String]
      if (request.nodeIds.nonEmpty)
        params.put("nodes", request.nodeIds.mkString(","))
      if (request.actions.nonEmpty)
        params.put("actions", request.actions.mkString(","))

      ElasticRequest("POST", "/_tasks/_cancel", params.toMap)
    }
  }

  implicit object CancelTaskByIdHandler extends AbstractCancelTaskHandler[CancelTaskByIdRequest] {

    override def build(request: CancelTaskByIdRequest): ElasticRequest =
      ElasticRequest("POST", s"/_tasks/${request.nodeId}:${request.taskId}/_cancel")
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy