// // 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 .BadRequest(.Text("Invalid value of 'Range' header: \(r.headers["range"])")) } #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 .BadRequest(.Text("Invalid value of 'Range' header: \(r.headers["range"])")) } 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 guard let (_, value) = r.params.first else { return HttpResponse.NotFound } let filePath = dir + "/" + value let fileManager = NSFileManager.defaultManager() var isDir: ObjCBool = false guard fileManager.fileExistsAtPath(filePath, isDirectory: &isDir) else { return HttpResponse.NotFound } if isDir { do { let files = try fileManager.contentsOfDirectoryAtPath(filePath) var response = "
| \($0) |