aboutsummaryrefslogtreecommitdiff
path: root/mavigator-server/src/main/scala/mavigator/Main.scala
blob: 6ea894e381ba71f85ed651a85d84947b37e6c818 (plain) (blame)
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
package mavigator

import akka.actor._
import akka.http.scaladsl._
import akka.http.scaladsl.server._
import akka.stream._
import scala.concurrent.Await
import scala.concurrent.duration.Duration

object Main {

  implicit lazy val system = ActorSystem("mavigator")
  implicit lazy val materializer = ActorMaterializer()

  def main(args: Array[String]): Unit = {
    import system.dispatcher

    system.log.info("System started.")

    val router = Router.route

    system.log.info(s"Starting server")
    val binding = Http(system).bindAndHandle(router, "0.0.0.0", 8080)

    for (b <- binding) {
      val addr = b.localAddress.getHostString()
      val port = b.localAddress.getPort()
      system.log.info(s"Server is listening on $addr:$port")
    }
    
    scala.io.StdIn.readLine()

    binding.flatMap{b =>
      system.log.info("Shutting down server...")
      b.unbind()
    }.onComplete{ _ =>
      system.log.info("Server shut down")
      system.terminate()
    }

    Await.result(system.whenTerminated, Duration.Inf)

  }
}