DemoServer.swift 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. //
  2. // DemoServer.swift
  3. // Swifter
  4. // Copyright (c) 2015 Damian Kołakowski. All rights reserved.
  5. //
  6. import Foundation
  7. public func demoServer(publicDir: String?) -> HttpServer {
  8. let server = HttpServer()
  9. if let publicDir = publicDir {
  10. server["/resources/(.+)"] = HttpHandlers.directory(publicDir)
  11. }
  12. server["/files(.+)"] = HttpHandlers.directoryBrowser("~/")
  13. server["/magic"] = { .OK(.Html("You asked for " + $0.url)) }
  14. server["/test"] = { request in
  15. var headersInfo = ""
  16. for (name, value) in request.headers {
  17. headersInfo += "\(name) : \(value)<br>"
  18. }
  19. var queryParamsInfo = ""
  20. for (name, value) in request.urlParams {
  21. queryParamsInfo += "\(name) : \(value)<br>"
  22. }
  23. return .OK(.Html("<h3>Address: \(request.address)</h3><h3>Url:</h3> \(request.url)<h3>Method: \(request.method)</h3><h3>Headers:</h3>\(headersInfo)<h3>Query:</h3>\(queryParamsInfo)"))
  24. }
  25. server["/params/(.+)/(.+)"] = { request in
  26. var capturedGroups = ""
  27. for (index, group) in request.capturedUrlGroups.enumerate() {
  28. capturedGroups += "Expression group \(index) : \(group)<br>"
  29. }
  30. return .OK(.Html("Url: \(request.url)<br>Method: \(request.method)<br>\(capturedGroups)"))
  31. }
  32. server["/json"] = { request in
  33. return .OK(.Json(["posts" : [[ "id" : 1, "message" : "hello world"],[ "id" : 2, "message" : "sample message"]], "new_updates" : false]))
  34. }
  35. server["/redirect"] = { request in
  36. return .MovedPermanently("http://www.google.com")
  37. }
  38. server["/long"] = { request in
  39. var longResponse = ""
  40. for k in 0..<1000 { longResponse += "(\(k)),->" }
  41. return .OK(.Html(longResponse))
  42. }
  43. server["/demo"] = { request in
  44. return .OK(.Html("<center><h2>Hello Swift</h2>" +
  45. "<img src=\"https://devimages.apple.com.edgekey.net/swift/images/swift-hero_2x.png\"/><br>" +
  46. "</center>"))
  47. }
  48. server["/login"] = { request in
  49. switch request.method.uppercaseString {
  50. case "GET":
  51. if let rootDir = publicDir {
  52. if let html = NSData(contentsOfFile:"\(rootDir)/login.html") {
  53. var array = [UInt8](count: html.length, repeatedValue: 0)
  54. html.getBytes(&array, length: html.length)
  55. return HttpResponse.RAW(200, "OK", nil, array)
  56. } else {
  57. return .NotFound
  58. }
  59. }
  60. case "POST":
  61. let formFields = request.parseForm()
  62. return HttpResponse.OK(.Html(formFields.map({ "\($0.0) = \($0.1)" }).joinWithSeparator("<br>")))
  63. default:
  64. return .NotFound
  65. }
  66. return .NotFound
  67. }
  68. server["/raw"] = { request in
  69. return HttpResponse.RAW(200, "OK", ["XXX-Custom-Header": "value"], [UInt8]("Sample Response".utf8))
  70. }
  71. server["/"] = { request in
  72. var listPage = "Available services:<br><ul>"
  73. listPage += server.routes.map({ "<li><a href=\"\($0)\">\($0)</a></li>"}).joinWithSeparator("")
  74. return .OK(.Html(listPage))
  75. }
  76. return server
  77. }