Skip to content

Commit

Permalink
Merge pull request #635 from softwaremill/ox-app
Browse files Browse the repository at this point in the history
Use OxApp for Netty sync server
  • Loading branch information
adamw authored Sep 23, 2024
2 parents b3c72c0 + 95ed011 commit bb0e604
Show file tree
Hide file tree
Showing 12 changed files with 35 additions and 46 deletions.
3 changes: 1 addition & 2 deletions backend/src/main/twirl/MainFutureNettyScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,9 @@ import ExecutionContext.Implicits.global
val program =
for
binding <- NettyFutureServer(@if(addMetrics) {serverOptions}).port(port).addEndpoints(Endpoints.all).start()
_ <- Future {
_ <- Future:
println(s"@if(addDocumentation){Go to http://localhost:${binding.port}/docs to open SwaggerUI. }else{Server started at http://localhost:${binding.port}. }Press ENTER key to exit.")
StdIn.readLine()
}
stop <- binding.stop()
yield stop

Expand Down
3 changes: 1 addition & 2 deletions backend/src/main/twirl/MainFuturePekkoScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,9 @@ import scala.io.StdIn
val bindingFuture = Http()
.newServerAt("localhost", port)
.bindFlow(route)
.map { binding =>
.map: binding =>
println(s"@if(addDocumentation){Go to http://localhost:${binding.localAddress.getPort}/docs to open SwaggerUI.}else{Server started at http://localhost:${binding.localAddress.getPort}.} Press ENTER key to exit.")
binding
}

StdIn.readLine()

Expand Down
10 changes: 4 additions & 6 deletions backend/src/main/twirl/MainFutureVertxScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,17 @@ import scala.io.StdIn
val router = Router.router(vertx)

Endpoints.all
.foreach(endpoint => {
.foreach: endpoint =>
VertxFutureServerInterpreter(@if(addMetrics) {serverOptions}).route(endpoint)
.apply(router)
})

val program = for {
val program = for
binding <- server.requestHandler(router).listen(port).asScala
_ <- Future {
_ <- Future:
println(s"@if(addDocumentation){Go to http://localhost:${binding.actualPort()}/docs to open SwaggerUI. }else{Server started at http://localhost:${binding.actualPort()}. }Press ENTER key to exit.")
StdIn.readLine()
}
stop <- binding.close().asScala
} yield stop
yield stop

Await.result(program, Duration.Inf)

7 changes: 3 additions & 4 deletions backend/src/main/twirl/MainIOHttp4sScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,9 @@ object Main extends IOApp:
.withPort(port)
.withHttpApp(Router("/" -> routes).orNotFound)
.build
.use { server =>
for {
.use: server =>
for
_ <- IO.println(s"@if(addDocumentation){Go to http://localhost:${server.address.getPort}/docs to open SwaggerUI. }else{Server started at http://localhost:${server.address.getPort}. }Press ENTER key to exit.")
_ <- IO.readLine
} yield ()
}
yield ()
.as(ExitCode.Success)
3 changes: 1 addition & 2 deletions backend/src/main/twirl/MainIONettyScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ object Main extends IOApp:
NettyCatsServer
.io()
}
.use { server =>
.use: server =>
for
bind <- server
.port(port)
Expand All @@ -30,5 +30,4 @@ object Main extends IOApp:
_ <- IO.readLine
_ <- bind.stop()
yield bind
}
.as(ExitCode.Success)
13 changes: 5 additions & 8 deletions backend/src/main/twirl/MainIOVertxScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -19,27 +19,24 @@ object Main extends IOApp:

Dispatcher[IO]
@if(addMetrics) {
.map(d => {
.map: d =>
VertxCatsServerOptions
.customiseInterceptors(d)
.metricsInterceptor(Endpoints.prometheusMetrics.metricsInterceptor())
.options
})
}
.use { @if(addMetrics) {serverOptions} else {dispatcher} =>
for {
.use: @if(addMetrics) {serverOptions} else {dispatcher} =>
for
bind <- IO.delay {
Endpoints.all
.foreach(endpoint => {
.foreach: endpoint =>
VertxCatsServerInterpreter[IO](@if(addMetrics) {serverOptions} else {dispatcher})
.route(endpoint)
.apply(router)
})
server.requestHandler(router).listen(port)
}.flatMap(_.asF[IO])
_ <- IO.println(s"@if(addDocumentation){Go to http://localhost:${bind.actualPort()}/docs to open SwaggerUI. }else{Server started at http://localhost:${bind.actualPort()}. }Press ENTER key to exit.")
_ <- IO.readLine
_ <- IO.delay(server.close).flatMap(_.asF[IO].void)
} yield bind
}
yield bind
.as(ExitCode.Success)
18 changes: 9 additions & 9 deletions backend/src/main/twirl/MainSyncNettyScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@ package @groupId
import ox.*
import sttp.tapir.server.netty.sync.@if(addMetrics){{NettySyncServer, NettySyncServerOptions}}else{NettySyncServer}

@@main def run(): Unit =
@if(addMetrics) {
val serverOptions = NettySyncServerOptions.customiseInterceptors
.metricsInterceptor(Endpoints.prometheusMetrics.metricsInterceptor())
.options
}
val port = sys.env.get("HTTP_PORT").flatMap(_.toIntOption).getOrElse(8080)
supervised {
object Main extends OxApp.Simple:

def run(using Ox): Unit =
@if(addMetrics) {
val serverOptions = NettySyncServerOptions.customiseInterceptors
.metricsInterceptor(Endpoints.prometheusMetrics.metricsInterceptor())
.options
}
val port = sys.env.get("HTTP_PORT").flatMap(_.toIntOption).getOrElse(8080)
val binding = useInScope(NettySyncServer(@if(addMetrics){serverOptions}).port(port).addEndpoints(Endpoints.all).start())(_.stop())
println(s"@if(addDocumentation){Go to http://localhost:${binding.port}/docs to open SwaggerUI. }else{Server started at http://localhost:${binding.port}. }")
never
}
7 changes: 3 additions & 4 deletions backend/src/main/twirl/MainZIOHttp4sScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,8 @@ object Main extends ZIOAppDefault:
.withPort(port)
.withHttpApp(Router("/" -> routes).orNotFound)
.build
.use { server =>
for {
.use: server =>
for
_ <- Console.printLine(s"@if(addDocumentation){Go to http://localhost:${server.address.getPort}/docs to open SwaggerUI. }else{Server started at http://localhost:${server.address.getPort}. }Press ENTER key to exit.")
_ <- Console.readLine
} yield ()
}
yield ()
4 changes: 2 additions & 2 deletions backend/src/main/twirl/MainZIONettyScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ object Main extends ZIOAppDefault:
}
val server = NettyZioServer.apply(options).port(port)

for {
for
bind <- server.addEndpoints(Endpoints.all).start()
_ <- Console.printLine(s"@if(addDocumentation){Go to http://localhost:${bind.port}/docs to open SwaggerUI. }else{Server started at http://localhost:${bind.port}. }Press ENTER key to exit.")
_ <- Console.readLine
_ <- bind.stop()
} yield ExitCode.success
yield ExitCode.success
7 changes: 3 additions & 4 deletions backend/src/main/twirl/MainZIOVertxScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ object Main extends ZIOAppDefault:
val server = vertx.createHttpServer()
val router = Router.router(vertx)

(for {
(for
serverStart <- ZIO
.attempt {
@if(addMetrics) {
Expand All @@ -28,14 +28,13 @@ object Main extends ZIOAppDefault:
.options
}
Endpoints.all
.foreach(endpoint => {
.foreach: endpoint =>
VertxZioServerInterpreter(@if(addMetrics) {serverOptions})
.route(endpoint)
.apply(router)
})
server.requestHandler(router).listen(port)
}.flatMap(_.asRIO)
_ <- Console.printLine(s"@if(addDocumentation){Go to http://localhost:${serverStart.actualPort()}/docs to open SwaggerUI. }else{Server started at http://localhost:${serverStart.actualPort()}. }Press ENTER key to exit.")
_ <- Console.readLine
} yield serverStart)
yield serverStart)
.exitCode
4 changes: 2 additions & 2 deletions backend/src/main/twirl/MainZIOhttpZIOScala3.scala.txt
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,11 @@ object Main extends ZIOAppDefault:

val port = sys.env.get("HTTP_PORT").flatMap(_.toIntOption).getOrElse(8080)

(for {
(for
actualPort <- Server.install(app) // or .serve if you don't need the port and want to keep it running without manual readLine
_ <- Console.printLine(s"@if(addDocumentation){Go to http://localhost:${actualPort}/docs to open SwaggerUI. }else{Server started at http://localhost:${actualPort}. }Press ENTER key to exit.")
_ <- Console.readLine
} yield ()
yield ()
).provide(
ZLayer.succeed(Server.Config.default.port(port)),
Server.live
Expand Down
2 changes: 1 addition & 1 deletion build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import scala.util.Try
val scala2Version = "2.13.14"
val scala3Version = "3.5.1"

val tapirVersion = "1.11.4"
val tapirVersion = "1.11.5"

val http4sEmberServerVersion = "0.23.28"
val http4sCirceVersion = "0.23.28"
Expand Down

0 comments on commit bb0e604

Please sign in to comment.