forked from moia-oss/scala-http-client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
LoggingExample.scala
45 lines (36 loc) · 1.66 KB
/
LoggingExample.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package io.moia.scalaHttpClient
import org.apache.pekko.actor.typed.ActorSystem
import org.apache.pekko.actor.typed.scaladsl.Behaviors
import org.apache.pekko.http.scaladsl.model._
import com.typesafe.scalalogging._
import io.moia.scalaHttpClient.CustomLogging.LoggingContext
import org.slf4j.LoggerFactory
import java.time.Clock
import scala.concurrent.ExecutionContext
import scala.concurrent.duration._
object CustomLogging {
final case class LoggingContext(context: String)
implicit val canLogString: CanLog[LoggingContext] = new CanLog[LoggingContext] {
override def logMessage(originalMsg: String, ctx: LoggingContext): String = ???
override def afterLog(ctx: LoggingContext): Unit = ???
}
val theLogger: LoggerTakingImplicit[LoggingContext] = Logger.takingImplicit(LoggerFactory.getLogger(getClass.getName))
}
object Example {
implicit val system: ActorSystem[_] = ActorSystem(Behaviors.empty, "test")
implicit val executionContext: ExecutionContext = system.executionContext
// create the client
val httpClient = new LoggingHttpClient[LoggingContext](
config = HttpClientConfig("http", "127.0.0.1", 8888),
name = "TestClient",
httpMetrics = HttpMetrics.none[LoggingContext],
retryConfig = RetryConfig.default,
clock = Clock.systemUTC(),
logger = CustomLogging.theLogger,
awsRequestSigner = None
)
// create an implicit logging context
implicit val ctx: LoggingContext = LoggingContext("Logging Context")
// make a request
httpClient.request(HttpMethods.POST, HttpEntity.Empty, "/test", Seq.empty, Deadline.now + 10.seconds)
}