aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala
diff options
context:
space:
mode:
authorvlad <vlad@driver.xyz>2017-06-13 16:12:20 -0700
committervlad <vlad@driver.xyz>2017-06-13 16:12:20 -0700
commitcd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c (patch)
tree062e8dad1a1513e26b0fd08b1742d6ff2ee874f7 /src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala
parent0000a65ab4479a2a40e2d6468036438e9705b4aa (diff)
downloadrest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.gz
rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.bz2
rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.zip
Adding domain entitiesv0.1.0
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala b/src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala
new file mode 100644
index 0000000..3dee8ea
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuicommon/concurrent/MdcExecutionContext.scala
@@ -0,0 +1,35 @@
+package xyz.driver.pdsuicommon.concurrent
+
+import org.slf4j.MDC
+
+import scala.concurrent.{ExecutionContext, ExecutionContextExecutor}
+
+object MdcExecutionContext {
+ def from(orig: ExecutionContext): ExecutionContext = new MdcExecutionContext(orig)
+}
+
+class MdcExecutionContext(orig: ExecutionContext) extends ExecutionContextExecutor {
+
+ def execute(runnable: Runnable): Unit = {
+ val parentMdcContext = MDC.getCopyOfContextMap
+
+ orig.execute(new Runnable {
+ def run(): Unit = {
+ val saveMdcContext = MDC.getCopyOfContextMap
+ setContextMap(parentMdcContext)
+
+ try {
+ runnable.run()
+ } finally {
+ setContextMap(saveMdcContext)
+ }
+ }
+ })
+ }
+
+ private[this] def setContextMap(context: java.util.Map[String, String]): Unit =
+ Option(context).fold(MDC.clear())(MDC.setContextMap)
+
+ def reportFailure(t: Throwable): Unit = orig.reportFailure(t)
+
+}