DemoServer.swift 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. //
  2. // DemoServer.swift
  3. // Swifter
  4. //
  5. // Copyright (c) 2014-2016 Damian Kołakowski. All rights reserved.
  6. //
  7. #if os(Linux)
  8. import Glibc
  9. #else
  10. import Foundation
  11. #endif
  12. public func demoServer(publicDir: String) -> HttpServer {
  13. print(publicDir)
  14. let server = HttpServer()
  15. server["/public/:path"] = shareFilesFromDirectory(publicDir)
  16. server["/public/"] = shareFilesFromDirectory(publicDir) // needed to serve index file at root level
  17. server["/files/:path"] = directoryBrowser("/")
  18. server["/"] = scopes {
  19. html {
  20. body {
  21. ul(server.routes) { service in
  22. li {
  23. a { href = service; inner = service }
  24. }
  25. }
  26. }
  27. }
  28. }
  29. server["/magic"] = { .OK(.Html("You asked for " + $0.path)) }
  30. server["/test/:param1/:param2"] = { r in
  31. scopes {
  32. html {
  33. body {
  34. h3 { inner = "Address: \(r.address)" }
  35. h3 { inner = "Url: \(r.path)" }
  36. h3 { inner = "Method: \(r.method)" }
  37. h3 { inner = "Query:" }
  38. table(r.queryParams) { param in
  39. tr {
  40. td { inner = param.0 }
  41. td { inner = param.1 }
  42. }
  43. }
  44. h3 { inner = "Headers:" }
  45. table(r.headers) { header in
  46. tr {
  47. td { inner = header.0 }
  48. td { inner = header.1 }
  49. }
  50. }
  51. h3 { inner = "Route params:" }
  52. table(r.params) { param in
  53. tr {
  54. td { inner = param.0 }
  55. td { inner = param.1 }
  56. }
  57. }
  58. }
  59. }
  60. }(r)
  61. }
  62. server.GET["/upload"] = scopes {
  63. html {
  64. body {
  65. form {
  66. method = "POST"
  67. action = "/upload"
  68. enctype = "multipart/form-data"
  69. input { name = "my_file1"; type = "file" }
  70. input { name = "my_file2"; type = "file" }
  71. input { name = "my_file3"; type = "file" }
  72. button {
  73. type = "submit"
  74. inner = "Upload"
  75. }
  76. }
  77. }
  78. }
  79. }
  80. server.POST["/upload"] = { r in
  81. var response = ""
  82. for multipart in r.parseMultiPartFormData() {
  83. response += "Name: \(multipart.name) File name: \(multipart.fileName) Size: \(multipart.body.count)<br>"
  84. }
  85. return HttpResponse.OK(.Html(response))
  86. }
  87. server.GET["/login"] = scopes {
  88. html {
  89. head {
  90. script { src = "http://cdn.staticfile.org/jquery/2.1.4/jquery.min.js" }
  91. stylesheet { href = "http://cdn.staticfile.org/twitter-bootstrap/3.3.0/css/bootstrap.min.css" }
  92. }
  93. body {
  94. h3 { inner = "Sign In" }
  95. form {
  96. method = "POST"
  97. action = "/login"
  98. fieldset {
  99. input { placeholder = "E-mail"; name = "email"; type = "email"; autofocus = "" }
  100. input { placeholder = "Password"; name = "password"; type = "password"; autofocus = "" }
  101. a {
  102. href = "/login"
  103. button {
  104. type = "submit"
  105. inner = "Login"
  106. }
  107. }
  108. }
  109. }
  110. javascript {
  111. src = "http://cdn.staticfile.org/twitter-bootstrap/3.3.0/js/bootstrap.min.js"
  112. }
  113. }
  114. }
  115. }
  116. server.POST["/login"] = { r in
  117. let formFields = r.parseUrlencodedForm()
  118. return HttpResponse.OK(.Html(formFields.map({ "\($0.0) = \($0.1)" }).joinWithSeparator("<br>")))
  119. }
  120. server.OPTIONS["/login"] = { r in
  121. let response = ""
  122. return HttpResponse.OK(.Json(response))
  123. }
  124. server["/demo"] = scopes {
  125. html {
  126. body {
  127. center {
  128. h2 { inner = "Hello Swift" }
  129. img { src = "https://devimages.apple.com.edgekey.net/swift/images/swift-hero_2x.png" }
  130. }
  131. }
  132. }
  133. }
  134. server["/raw"] = { r in
  135. return HttpResponse.RAW(200, "OK", ["XXX-Custom-Header": "value"], { try $0.write([UInt8]("test".utf8)) })
  136. }
  137. server["/redirect"] = { r in
  138. HttpResponse.OK(.Html(""))
  139. return .MovedPermanently("http://www.google.com")
  140. }
  141. server["/long"] = { r in
  142. var longResponse = ""
  143. for k in 0..<1000 { longResponse += "(\(k)),->" }
  144. return .OK(.Html(longResponse))
  145. }
  146. server["/wildcard/*/test/*/:param"] = { r in
  147. return .OK(.Html(r.path))
  148. }
  149. server["/stream"] = { r in
  150. return HttpResponse.RAW(200, "OK", nil, { w in
  151. for i in 0...100 {
  152. try w.write([UInt8]("[chunk \(i)]".utf8))
  153. }
  154. })
  155. }
  156. server["/websocket-echo"] = websocket({ (session, text) in
  157. session.writeText(text)
  158. }, { (session, binary) in
  159. session.writeBinary(binary)
  160. })
  161. server.notFoundHandler = { r in
  162. return .MovedPermanently("https://github.com/404")
  163. }
  164. server.middleware.append { r in
  165. print("Middleware: \(r.address) -> \(r.method) -> \(r.path)")
  166. return nil
  167. }
  168. return server
  169. }