session-ios/Signal/src/Loki/Utilities/LokiPushNotificationManager...

44 lines
1.8 KiB
Swift
Raw Normal View History

2020-01-06 03:16:43 +01:00
import UIKit
2020-01-20 06:00:01 +01:00
// Ideally this should be in SignalServiceKit, but somehow linking fails when it is.
2020-01-06 03:16:43 +01:00
@objc(LKPushNotificationManager)
final class LokiPushNotificationManager : NSObject {
@objc static let shared = LokiPushNotificationManager()
private override init() { super.init() }
@objc(registerWithToken:)
func register(with token: Data) {
let hexEncodedToken = token.map { String(format: "%02.2hhx", $0) }.joined()
2020-02-19 06:45:38 +01:00
let userDefaults = UserDefaults.standard
let oldToken = userDefaults[.deviceToken]
let lastUploadTime = userDefaults[.lastDeviceTokenUpload]
2020-02-11 03:37:03 +01:00
let now = Date().timeIntervalSince1970
if hexEncodedToken == oldToken && now - lastUploadTime < 2 * 24 * 60 * 60 {
print("[Loki] Device token hasn't changed; no need to upload.")
2020-02-06 23:35:40 +01:00
return
}
2020-01-06 03:16:43 +01:00
// Send token to Loki server
let parameters = [ "token" : hexEncodedToken ]
2020-02-21 04:24:03 +01:00
#if DEBUG
let url = URL(string: "https://dev.apns.getsession.org/register")!
#else
2020-02-21 01:08:16 +01:00
let url = URL(string: "https://live.apns.getsession.org/register")!
2020-02-21 04:24:03 +01:00
#endif
2020-01-06 03:16:43 +01:00
let request = TSRequest(url: url, method: "POST", parameters: parameters)
request.allHTTPHeaderFields = [ "Content-Type" : "application/json" ]
TSNetworkManager.shared().makeRequest(request, success: { _, response in
guard let json = response as? JSON else { return }
guard json["code"] as? Int != 0 else {
return print("[Loki] An error occured during device token registration: \(json["message"] as? String ?? "nil").")
}
2020-02-19 06:45:38 +01:00
userDefaults[.deviceToken] = hexEncodedToken
userDefaults[.lastDeviceTokenUpload] = now
2020-01-06 03:16:43 +01:00
}, failure: { _, error in
print("[Loki] Couldn't register device token.")
})
}
}