aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/core/app/module.scala
diff options
context:
space:
mode:
authorzachdriver <zach@driver.xyz>2017-10-17 14:51:21 -0700
committerGitHub <noreply@github.com>2017-10-17 14:51:21 -0700
commit2af63e7fb8b15568adaf2d9f0a6b395d6719fd71 (patch)
treebb66e54c3f7ff26af279df255452566df057223b /src/main/scala/xyz/driver/core/app/module.scala
parentb00892d723f6dedf50dc1c1fde7d443e9c3f9497 (diff)
parent1aaaf7a5ecf2cd28350fff872e334f9f6186966a (diff)
downloaddriver-core-2af63e7fb8b15568adaf2d9f0a6b395d6719fd71.tar.gz
driver-core-2af63e7fb8b15568adaf2d9f0a6b395d6719fd71.tar.bz2
driver-core-2af63e7fb8b15568adaf2d9f0a6b395d6719fd71.zip
Merge pull request #74 from drivergroup/zsmith/rest-app-packages
Split app and rest packages into separate files
Diffstat (limited to 'src/main/scala/xyz/driver/core/app/module.scala')
-rw-r--r--src/main/scala/xyz/driver/core/app/module.scala50
1 files changed, 50 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/core/app/module.scala b/src/main/scala/xyz/driver/core/app/module.scala
new file mode 100644
index 0000000..c6f979f
--- /dev/null
+++ b/src/main/scala/xyz/driver/core/app/module.scala
@@ -0,0 +1,50 @@
+package xyz.driver.core.app
+
+import akka.http.scaladsl.model.StatusCodes
+import akka.http.scaladsl.server.Directives.complete
+import akka.http.scaladsl.server.{Route, RouteConcatenation}
+import xyz.driver.core.rest.{NoServiceDiscovery, SavingUsedServiceDiscovery, ServiceDiscovery}
+
+import scala.reflect.runtime.universe._
+
+trait Module {
+ val name: String
+ def route: Route
+ def routeTypes: Seq[Type]
+
+ val serviceDiscovery: ServiceDiscovery with SavingUsedServiceDiscovery = new NoServiceDiscovery()
+
+ def activate(): Unit = {}
+ def deactivate(): Unit = {}
+}
+
+class EmptyModule extends Module {
+ override val name: String = "Nothing"
+
+ override def route: Route = complete(StatusCodes.OK)
+
+ override def routeTypes: Seq[Type] = Seq.empty[Type]
+}
+
+class SimpleModule(override val name: String, override val route: Route, routeType: Type) extends Module {
+ def routeTypes: Seq[Type] = Seq(routeType)
+}
+
+/**
+ * Module implementation which may be used to composed a few
+ *
+ * @param name more general name of the composite module,
+ * must be provided as there is no good way to automatically
+ * generalize the name from the composed modules' names
+ * @param modules modules to compose into a single one
+ */
+class CompositeModule(override val name: String, modules: Seq[Module]) extends Module with RouteConcatenation {
+
+ override def route: Route = RouteConcatenation.concat(modules.map(_.route): _*)
+
+ override def routeTypes: Seq[Type] = modules.flatMap(_.routeTypes)
+
+ override def activate(): Unit = modules.foreach(_.activate())
+
+ override def deactivate(): Unit = modules.reverse.foreach(_.deactivate())
+}