From 1c4cb72b209ab11c9e52c3bb490adf759f17fd0c Mon Sep 17 00:00:00 2001 From: lihaoyi Date: Sun, 23 Nov 2014 05:37:28 -0800 Subject: Added autowire section in client-server --- .../server/src/main/scala/simple/Page.scala | 21 +++++++++ .../server/src/main/scala/simple/Server.scala | 51 ++++++++++++++++++++++ 2 files changed, 72 insertions(+) create mode 100644 examples/crossBuilds/clientserver2/server/src/main/scala/simple/Page.scala create mode 100644 examples/crossBuilds/clientserver2/server/src/main/scala/simple/Server.scala (limited to 'examples/crossBuilds/clientserver2/server/src/main/scala') diff --git a/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Page.scala b/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Page.scala new file mode 100644 index 0000000..ce6617c --- /dev/null +++ b/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Page.scala @@ -0,0 +1,21 @@ +package simple +import scalatags.Text.all._ + +object Page{ + val boot = + "Client().main(document.getElementById('contents'))" + val skeleton = + html( + head( + script(src:="/client-fastopt.js"), + link( + rel:="stylesheet", + href:="http://yui.yahooapis.com/pure/0.5.0/pure-min.css" + ) + ), + body( + onload:=boot, + div(id:="contents") + ) + ) +} diff --git a/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Server.scala b/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Server.scala new file mode 100644 index 0000000..df5f877 --- /dev/null +++ b/examples/crossBuilds/clientserver2/server/src/main/scala/simple/Server.scala @@ -0,0 +1,51 @@ +package simple + +import akka.actor.ActorSystem +import spray.http.{HttpEntity, MediaTypes} +import spray.routing.SimpleRoutingApp +import scala.concurrent.ExecutionContext.Implicits.global + +object Router extends autowire.Server[String, upickle.Reader, upickle.Writer]{ + def read[Result: upickle.Reader](p: String) = upickle.read[Result](p) + def write[Result: upickle.Writer](r: Result) = upickle.write(r) +} + +object Server extends SimpleRoutingApp with Api{ + def main(args: Array[String]): Unit = { + implicit val system = ActorSystem() + startServer("localhost", port = 8080){ + get{ + pathSingleSlash{ + complete{ + HttpEntity( + MediaTypes.`text/html`, + Page.skeleton.render + ) + } + } ~ + getFromResourceDirectory("") + } ~ + post{ + path("ajax" / Segments){ s => + extract(_.request.entity.asString) { e => + complete { + Router.route[Api](Server)( + autowire.Core.Request(s, upickle.read[Map[String, String]](e)) + ) + } + } + } + } + } + } + def list(path: String) = { + val (dir, last) = path.splitAt(path.lastIndexOf("/") + 1) + val files = + Option(new java.io.File("./" + dir).listFiles()) + .toSeq.flatten + for{ + f <- files + if f.getName.startsWith(last) + } yield FileData(f.getName, f.length()) + } +} \ No newline at end of file -- cgit v1.2.3