// // HttpHandlers+Files.swift // Swifter // // Copyright (c) 2014-2016 Damian KoĊ‚akowski. All rights reserved. // import Foundation extension HttpHandlers { private static let rangePrefix = "bytes=" public class func directory(dir: String) -> (HttpRequest -> HttpResponse) { return { r in guard let localPath = r.params.first else { return HttpResponse.NotFound } let filesPath = dir + "/" + localPath.1 guard let fileBody = NSData(contentsOfFile: filesPath) else { return HttpResponse.NotFound } if let rangeHeader = r.headers["range"] { guard rangeHeader.hasPrefix(HttpHandlers.rangePrefix) else { return HttpResponse.BadRequest } #if os(Linux) let rangeString = rangeHeader.substringFromIndex(HttpHandlers.rangePrefix.characters.count) #else let rangeString = rangeHeader.substringFromIndex(rangeHeader.startIndex.advancedBy(HttpHandlers.rangePrefix.characters.count)) #endif let rangeStringExploded = rangeString.split("-") guard rangeStringExploded.count == 2 else { return HttpResponse.BadRequest } let startStr = rangeStringExploded[0] let endStr = rangeStringExploded[1] guard let start = Int(startStr), end = Int(endStr) else { var array = [UInt8](count: fileBody.length, repeatedValue: 0) fileBody.getBytes(&array, length: fileBody.length) return HttpResponse.RAW(200, "OK", nil, { $0.write(array) }) } let chunkLength = end - start let chunkRange = NSRange(location: start, length: chunkLength + 1) guard chunkRange.location + chunkRange.length <= fileBody.length else { return HttpResponse.RAW(416, "Requested range not satisfiable", nil, nil) } let chunk = fileBody.subdataWithRange(chunkRange) let headers = [ "Content-Range" : "bytes \(startStr)-\(endStr)/\(fileBody.length)" ] var content = [UInt8](count: chunk.length, repeatedValue: 0) chunk.getBytes(&content, length: chunk.length) return HttpResponse.RAW(206, "Partial Content", headers, { $0.write(content) }) } else { var content = [UInt8](count: fileBody.length, repeatedValue: 0) fileBody.getBytes(&content, length: fileBody.length) return HttpResponse.RAW(200, "OK", nil, { $0.write(content) }) } } } public class func directoryBrowser(dir: String) -> ( HttpRequest -> HttpResponse ) { return { r in if let (_, value) = r.params.first { let filePath = dir + "/" + value let fileManager = NSFileManager.defaultManager() var isDir: ObjCBool = false if fileManager.fileExistsAtPath(filePath, isDirectory: &isDir) { if isDir { do { let files = try fileManager.contentsOfDirectoryAtPath(filePath) var response = "

\(filePath)


" response += files.map({ ""}).joinWithSeparator("") response += "
\($0)
" return HttpResponse.OK(.Html(response)) } catch { return HttpResponse.NotFound } } else { if let fileBody = NSData(contentsOfFile: filePath) { var array = [UInt8](count: fileBody.length, repeatedValue: 0) fileBody.getBytes(&array, length: fileBody.length) return HttpResponse.RAW(200, "OK", nil, { $0.write(array) }) } } } } return HttpResponse.NotFound } } }