You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

82 lines
3.0 KiB

// Copyright © 2015 Abhishek Banthia
import Cocoa
class NetworkManager: NSObject {
static let parsingError: NSError = {
let userInfoDictionary: [String: Any] = [NSLocalizedDescriptionKey: "Parsing Error"]
let error = NSError(domain: "APIError", code: 102, userInfo: userInfoDictionary)
return error
}()
static let internalServerError: NSError = {
let userInfoDictionary: [String: Any] = [NSLocalizedDescriptionKey: "Internal Error",
NSLocalizedFailureReasonErrorKey: "There was a problem retrieving your information. Please try again later. If the problem continues please contact App Support."]
let error = NSError(domain: "APIError", code: 100, userInfo: userInfoDictionary)
return error
}()
static let unableToGenerateURL: NSError = {
let userInfoDictionary: [String: Any] = [NSLocalizedDescriptionKey: "Unable to generate URL",
NSLocalizedFailureReasonErrorKey: "There was a problem searching the location. Please try again later. If the problem continues please contact App Support."]
let error = NSError(domain: "APIError", code: 100, userInfo: userInfoDictionary)
return error
}()
}
@objc extension NetworkManager {
@discardableResult
class func task(with path: String, completionHandler: @escaping (_ response: Data?, _ error: NSError?) -> Void) -> URLSessionDataTask? {
let configuration = URLSessionConfiguration.default
configuration.timeoutIntervalForRequest = 20
let session = URLSession(configuration: configuration)
guard let encodedPath = path.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed),
let url = URL(string: encodedPath) else {
completionHandler(nil, unableToGenerateURL)
return nil
}
var request = URLRequest(url: url)
request.setValue("application/json", forHTTPHeaderField: "Content-Type")
request.setValue("application/json", forHTTPHeaderField: "Accept")
let dataTask = session.dataTask(with: request) { data, urlResponse, error in
guard error == nil, let httpURLResponse = urlResponse as? HTTPURLResponse, let json = data else {
completionHandler(nil, internalServerError)
return
}
if httpURLResponse.statusCode != 200 {
completionHandler(nil, internalServerError)
return
}
completionHandler(json, nil)
}
dataTask.resume()
return dataTask
}
class func isConnected() -> Bool {
// For tests
if ProcessInfo.processInfo.arguments.contains("mockNetworkDown") {
return false
}
let status = Reach().connectionStatus()
switch status {
case .online(.wwan):
return true
case .online(.wiFi):
return true
default:
return false
}
}
}