Skip to content

Commit

Permalink
Refactor the way of loading hosts from configuration. Add test case f…
Browse files Browse the repository at this point in the history
…or CerebroRequest
  • Loading branch information
moliware committed May 21, 2019
1 parent 4342348 commit dc0b5e9
Show file tree
Hide file tree
Showing 16 changed files with 96 additions and 71 deletions.
2 changes: 1 addition & 1 deletion app/controllers/RestController.scala
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ class RestController @Inject()(val authentication: AuthenticationModule,
case Success(status, body) =>
val data = Json.obj(
"mappings" -> ClusterMapping(body),
"host" -> request.target.host
"host" -> request.target.host.name
)
CerebroResponse(status, data)

Expand Down
6 changes: 3 additions & 3 deletions app/elastic/HTTPElasticClient.scala
Original file line number Diff line number Diff line change
Expand Up @@ -319,10 +319,10 @@ class HTTPElasticClient @Inject()(client: WSClient) extends ElasticClient {
body: Option[String] = None,
target: ElasticServer,
headers: Seq[(String, String)] = Seq()) = {
val authentication = target.authentication
val url = s"${target.host.replaceAll("/+$", "")}$uri"
val authentication = target.host.authentication
val url = s"${target.host.name.replaceAll("/+$", "")}$uri"

val mergedHeaders = headers ++ target.forwardHeaders()
val mergedHeaders = headers ++ target.headers

val request =
authentication.foldLeft(client.url(url).withMethod(method).withHttpHeaders(mergedHeaders: _*)) {
Expand Down
11 changes: 6 additions & 5 deletions app/models/CerebroRequest.scala
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ object CerebroRequest {
def apply(request: AuthRequest[JsValue], hosts: Hosts): CerebroRequest = {
val body = request.body

val host = (body \ "host").asOpt[String].getOrElse(throw MissingTargetHostException)
val hostName = (body \ "host").asOpt[String].getOrElse(throw MissingTargetHostException)
val username = (body \ "username").asOpt[String]
val password = (body \ "password").asOpt[String]

Expand All @@ -48,12 +48,13 @@ object CerebroRequest {
case _ => None
}

val server = hosts.getServer(host) match {
case Some(ElasticServer(h, a, forward_header)) => ElasticServer(h, a.orElse(requestAuth), forward_header)
case None => ElasticServer(host, requestAuth)
val server = hosts.getHost(hostName) match {
case Some(host @ Host(h, a, headersWhitelist)) =>
val headers = headersWhitelist.flatMap(headerName => request.headers.get(headerName).map(headerName -> _))
ElasticServer(host.copy(authentication = a.orElse(requestAuth)), headers)
case None => ElasticServer(Host(hostName, requestAuth))
}

server.setForwardHeader(request.headers)
CerebroRequest(server, body, request.user)
}

Expand Down
17 changes: 1 addition & 16 deletions app/models/ElasticServer.scala
Original file line number Diff line number Diff line change
@@ -1,18 +1,3 @@
package models

import play.api.mvc.Headers

case class ElasticServer(host: String, authentication: Option[ESAuth] = None, forwardHeadersNames: Seq[String] = Seq.empty) {

protected var _headers: Seq[(String, String)] = Seq()

def setForwardHeader(headers : Headers) {
for (e <- forwardHeadersNames) {
if (headers.hasHeader(e)) {
_headers = _headers :+ (e, headers.get(e).orNull)
}
}
}

def forwardHeaders(): Seq[(String, String)] = _headers
}
case class ElasticServer(host: Host, headers: Seq[(String, String)] = Seq.empty)
3 changes: 3 additions & 0 deletions app/models/Host.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package models

case class Host(name: String, authentication: Option[ESAuth] = None, headersWhitelist: Seq[String] = Seq.empty)
12 changes: 6 additions & 6 deletions app/models/Hosts.scala
Original file line number Diff line number Diff line change
Expand Up @@ -14,30 +14,30 @@ trait Hosts {

def getHostNames(): Seq[String]

def getServer(name: String): Option[ElasticServer]
def getHost(name: String): Option[Host]

}

@Singleton
class HostsImpl @Inject()(config: Configuration) extends Hosts {

val hosts: Map[String, ElasticServer] = Try(config.underlying.getConfigList("hosts").asScala.map(Configuration(_))) match {
val hosts: Map[String, Host] = Try(config.underlying.getConfigList("hosts").asScala.map(Configuration(_))) match {
case Success(hostsConf) => hostsConf.map { hostConf =>
val host = hostConf.getOptional[String]("host").get
val name = hostConf.getOptional[String]("name").getOrElse(host)
val username = hostConf.getOptional[String]("auth.username")
val password = hostConf.getOptional[String]("auth.password")
val forward_headers = hostConf.getOptional[Seq[String]](path = "forward_headers").getOrElse(Seq.empty[String])
val headersWhitelist = hostConf.getOptional[Seq[String]](path = "headers-whitelist") .getOrElse(Seq.empty[String])
(username, password) match {
case (Some(username), Some(password)) => (name -> ElasticServer(host, Some(ESAuth(username, password)), forward_headers))
case _ => (name -> ElasticServer(host, None, forward_headers))
case (Some(username), Some(password)) => name -> Host(host, Some(ESAuth(username, password)), headersWhitelist)
case _ => name -> Host(host, None, headersWhitelist)
}
}.toMap
case Failure(_) => Map()
}

def getHostNames() = hosts.keys.toSeq

def getServer(name: String) = hosts.get(name)
def getHost(name: String) = hosts.get(name)

}
2 changes: 1 addition & 1 deletion conf/application.conf
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ hosts = [
#{
# host = "http://localhost:9200"
# name = "Localhost cluster"
# forward_headers = [ "x-proxy-user", "x-proxy-roles", "X-Forwarded-For" ]
# headers-whitelist = [ "x-proxy-user", "x-proxy-roles", "X-Forwarded-For" ]
#}
# Example of host with authentication
#{
Expand Down
12 changes: 6 additions & 6 deletions test/controllers/AnalysisControllerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package controllers

import elastic.{ElasticResponse, Success}
import models.ElasticServer
import models.{ElasticServer, Host}
import play.api.libs.json.Json
import play.api.test.FakeRequest
import play.api.test.Helpers._
Expand Down Expand Up @@ -30,7 +30,7 @@ object AnalysisControllerSpec extends MockedServices {
|]
""".stripMargin
)
client.getIndices(ElasticServer("somehost")) returns Future.successful(Success(200, expectedResponse))
client.getIndices(ElasticServer(Host("somehost"))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/analysis/indices").withBody(Json.obj("host" -> "somehost"))).get
ensure(response, 200, Json.arr("index1", "index2"))
}
Expand Down Expand Up @@ -58,7 +58,7 @@ object AnalysisControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.getIndexSettings("foo", ElasticServer("somehost")) returns Future.successful(Success(200, expectedResponse))
client.getIndexSettings("foo", ElasticServer(Host("somehost"))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/analysis/analyzers").withBody(Json.obj("host" -> "somehost", "index" -> "foo"))).get
ensure(response, 200, Json.arr("foo_analyzer"))
}
Expand All @@ -83,7 +83,7 @@ object AnalysisControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.getIndexMapping("foo", ElasticServer("somehost")) returns Future.successful(Success(200, expectedResponse))
client.getIndexMapping("foo", ElasticServer(Host("somehost"))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/analysis/fields").withBody(Json.obj("host" -> "somehost", "index" -> "foo"))).get
ensure(response, 200, Json.arr("name"))
}
Expand All @@ -104,7 +104,7 @@ object AnalysisControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.analyzeTextByAnalyzer("foo", "bar", "qux", ElasticServer("somehost")) returns Future.successful(Success(200, expectedResponse))
client.analyzeTextByAnalyzer("foo", "bar", "qux", ElasticServer(Host("somehost"))) returns Future.successful(Success(200, expectedResponse))
val params = Json.obj("host" -> "somehost", "index" -> "foo", "analyzer" -> "bar", "text" -> "qux")
val response = route(application, FakeRequest(POST, "/analysis/analyze/analyzer").withBody(params)).get
val expected = Json.parse(
Expand Down Expand Up @@ -138,7 +138,7 @@ object AnalysisControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.analyzeTextByField("foo", "bar", "qux", ElasticServer("somehost")) returns Future.successful(Success(200, expectedResponse))
client.analyzeTextByField("foo", "bar", "qux", ElasticServer(Host("somehost"))) returns Future.successful(Success(200, expectedResponse))
val params = Json.obj("host" -> "somehost", "index" -> "foo", "field" -> "bar", "text" -> "qux")
val response = route(application, FakeRequest(POST, "/analysis/analyze/field").withBody(params)).get
val expected = Json.parse(
Expand Down
8 changes: 4 additions & 4 deletions test/controllers/ClusterChangesControllerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package controllers

import elastic.Success
import models.ElasticServer
import models.{ElasticServer, Host}
import play.api.libs.json.Json
import play.api.test.FakeRequest
import play.api.test.Helpers._
Expand Down Expand Up @@ -117,9 +117,9 @@ object ClusterChangesControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.executeRequest("GET", "_cluster/state/blocks", None, ElasticServer("somehost", None)) returns Future.successful(Success(200, stateResponse))
client.executeRequest("GET", "_nodes/transport", None, ElasticServer("somehost", None)) returns Future.successful(Success(200, nodesResponse))
client.executeRequest("GET", "_aliases", None, ElasticServer("somehost", None)) returns Future.successful(Success(200, aliasesResponse))
client.executeRequest("GET", "_cluster/state/blocks", None, ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, stateResponse))
client.executeRequest("GET", "_nodes/transport", None, ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, nodesResponse))
client.executeRequest("GET", "_aliases", None, ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, aliasesResponse))
val response = route(application, FakeRequest(POST, "/cluster_changes").withBody(Json.obj("host" -> "somehost"))).get
ensure(response, 200, expectedResponse)
}
Expand Down
6 changes: 3 additions & 3 deletions test/controllers/ClusterSettingsControllerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package controllers

import elastic.Success
import models.ElasticServer
import models.{ElasticServer, Host}
import play.api.libs.json.Json
import play.api.test.FakeRequest
import play.api.test.Helpers._
Expand All @@ -28,7 +28,7 @@ object ClusterSettingsControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.getClusterSettings(ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.getClusterSettings(ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/cluster_settings").withBody(Json.obj("host" -> "somehost"))).get
ensure(response, 200, expectedResponse)
}
Expand All @@ -50,7 +50,7 @@ object ClusterSettingsControllerSpec extends MockedServices {
| "transient": {}
|}
""".stripMargin)
client.saveClusterSettings(body, ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.saveClusterSettings(body, ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/cluster_settings/save").withBody(Json.obj("host" -> "somehost", "settings" -> body))).get
ensure(response, 200, expectedResponse)
}
Expand Down
10 changes: 5 additions & 5 deletions test/controllers/CommonsControllerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package controllers

import elastic.Success
import models.ElasticServer
import models.{ElasticServer, Host}
import play.api.libs.json.Json
import play.api.test.FakeRequest
import play.api.test.Helpers._
Expand Down Expand Up @@ -36,7 +36,7 @@ class CommonsControllerSpec extends MockedServices {
|]
""".stripMargin
)
client.getIndices(ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.getIndices(ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/commons/indices").withBody(Json.obj("host" -> "somehost"))).get
ensure(response, 200, Json.arr("index1", "index2"))
}
Expand All @@ -52,7 +52,7 @@ class CommonsControllerSpec extends MockedServices {
""".stripMargin
)
val body = Json.obj("host" -> "somehost", "index" -> "someIndex")
client.getIndexMapping("someIndex", ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.getIndexMapping("someIndex", ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/commons/get_index_mapping").withBody(body)).get
ensure(response, 200, expectedResponse)
}
Expand Down Expand Up @@ -84,7 +84,7 @@ class CommonsControllerSpec extends MockedServices {
""".stripMargin
)
val body = Json.obj("host" -> "somehost", "index" -> "someIndex")
client.getIndexSettings("someIndex", ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.getIndexSettings("someIndex", ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/commons/get_index_settings").withBody(body)).get
ensure(response, 200, expectedResponse)
}
Expand Down Expand Up @@ -524,7 +524,7 @@ class CommonsControllerSpec extends MockedServices {
""".stripMargin
)
val body = Json.obj("host" -> "somehost", "node" -> "someNode")
client.nodeStats("someNode", ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.nodeStats("someNode", ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/commons/get_node_stats").withBody(body)).get
ensure(response, 200, expectedResponse)
}
Expand Down
6 changes: 3 additions & 3 deletions test/controllers/IndexSettingsControllerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package controllers

import elastic.Success
import models.ElasticServer
import models.{ElasticServer, Host}
import play.api.libs.json.Json
import play.api.test.FakeRequest
import play.api.test.Helpers._
Expand Down Expand Up @@ -35,7 +35,7 @@ object IndexSettingsControllerSpec extends MockedServices {
|}
""".stripMargin
)
client.getIndexSettingsFlat("foo", ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.getIndexSettingsFlat("foo", ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/index_settings").withBody(Json.obj("host" -> "somehost", "index" -> "foo"))).get
ensure(response, 200, expectedResponse)
}
Expand All @@ -57,7 +57,7 @@ object IndexSettingsControllerSpec extends MockedServices {
| "acknowledged":true
|}
""".stripMargin)
client.updateIndexSettings("foo", body, ElasticServer("somehost", None)) returns Future.successful(Success(200, expectedResponse))
client.updateIndexSettings("foo", body, ElasticServer(Host("somehost", None))) returns Future.successful(Success(200, expectedResponse))
val response = route(application, FakeRequest(POST, "/index_settings/update").withBody(Json.obj("host" -> "somehost", "index" -> "foo", "settings" -> body))).get
ensure(response, 200, expectedResponse)
}
Expand Down
Loading

0 comments on commit dc0b5e9

Please sign in to comment.