import PromiseKit @objc public final class LokiMessagingAPI : NSObject { private static let baseURL = "http://13.238.53.205" private static let port = "8080" private static let apiVersion = "v1" public static let defaultTTL: UInt64 = 4 * 24 * 60 * 60 // MARK: Types private enum Method : String { case retrieveAllMessages = "retrieve" case sendMessage = "store" } public typealias RawResponse = TSNetworkManager.NetworkManagerResult public enum Error : LocalizedError { case proofOfWorkCalculationFailed public var errorDescription: String? { switch self { case .proofOfWorkCalculationFailed: return NSLocalizedString("Failed to calculate proof of work.", comment: "") } } } // MARK: Lifecycle override private init() { } // MARK: API private static func invoke(_ method: Method, parameters: [String:String] = [:]) -> Promise { let url = URL(string: "\(baseURL):\(port)/\(apiVersion)/storage_rpc")! let request = TSRequest(url: url, method: "POST", parameters: [ "method" : method.rawValue, "params" : parameters ]) return TSNetworkManager.shared().makePromise(request: request) } public static func sendSignalMessage(_ signalMessage: SignalMessage, to destination: String, requiringPOW isPOWRequired: Bool) -> Promise { return LokiMessage.fromSignalMessage(signalMessage, requiringPOW: isPOWRequired).then(sendMessage) } public static func sendMessage(_ lokiMessage: LokiMessage) -> Promise { return invoke(.sendMessage, parameters: lokiMessage.toJSON()) } public static func retrieveAllMessages() -> Promise { let parameters = [ "pubKey" : OWSIdentityManager.shared().identityKeyPair()!.hexEncodedPublicKey, "lastHash" : "" // TODO: Implement ] return invoke(.retrieveAllMessages, parameters: parameters) } // MARK: Obj-C API @objc public static func sendSignalMessage(_ signalMessage: SignalMessage, to destination: String, requiringPOW isPOWRequired: Bool, completionHandler: @escaping (Any?, NSError?) -> Void) { sendSignalMessage(signalMessage, to: destination, requiringPOW: isPOWRequired).done { completionHandler($0.responseObject, nil) }.catch { completionHandler(nil, $0 as NSError) } } }