session-ios/Session/Meta/AppDelegate.swift

95 lines
4.1 KiB
Swift
Raw Normal View History

import PromiseKit
import WebRTC
extension AppDelegate {
@objc
func setUpCallHandling() {
2021-08-18 02:33:33 +02:00
// Offer messages
MessageReceiver.handleOfferCallMessage = { message in
DispatchQueue.main.async {
2021-08-17 08:02:20 +02:00
let sdp = RTCSessionDescription(type: .offer, sdp: message.sdps![0])
guard let presentingVC = CurrentAppContext().frontmostViewController() else { preconditionFailure() } // TODO: Handle more gracefully
2021-09-29 03:17:48 +02:00
if let conversationVC = presentingVC as? ConversationVC, let contactThread = conversationVC.thread as? TSContactThread, contactThread.contactSessionID() == message.sender! {
let callVC = CallVC(for: message.sender!, mode: .answer(sdp: sdp))
callVC.modalPresentationStyle = .overFullScreen
callVC.modalTransitionStyle = .crossDissolve
2021-09-23 10:04:16 +02:00
callVC.conversationVC = conversationVC
conversationVC.inputAccessoryView?.isHidden = true
conversationVC.inputAccessoryView?.alpha = 0
2021-09-29 03:17:48 +02:00
presentingVC.present(callVC, animated: true, completion: nil)
} else {
2021-09-23 10:04:16 +02:00
}
}
}
2021-08-18 05:07:15 +02:00
// Answer messages
MessageReceiver.handleAnswerCallMessage = { message in
DispatchQueue.main.async {
guard let callVC = CurrentAppContext().frontmostViewController() as? CallVC else { return }
callVC.handleAnswerMessage(message)
}
}
2021-08-18 02:33:33 +02:00
// End call messages
MessageReceiver.handleEndCallMessage = { message in
DispatchQueue.main.async {
guard let callVC = CurrentAppContext().frontmostViewController() as? CallVC else { return }
callVC.handleEndCallMessage(message)
}
}
}
@objc(syncConfigurationIfNeeded)
func syncConfigurationIfNeeded() {
2021-02-26 05:56:41 +01:00
guard Storage.shared.getUser()?.name != nil else { return }
let userDefaults = UserDefaults.standard
let lastSync = userDefaults[.lastConfigurationSync] ?? .distantPast
2021-05-03 03:42:07 +02:00
guard Date().timeIntervalSince(lastSync) > 7 * 24 * 60 * 60,
2021-03-04 03:50:13 +01:00
let configurationMessage = ConfigurationMessage.getCurrent() else { return } // Sync every 2 days
let destination = Message.Destination.contact(publicKey: getUserHexEncodedPublicKey())
Storage.shared.write { transaction in
let job = MessageSendJob(message: configurationMessage, destination: destination)
JobQueue.shared.add(job, using: transaction)
}
2021-01-13 06:10:06 +01:00
userDefaults[.lastConfigurationSync] = Date()
}
func forceSyncConfigurationNowIfNeeded() -> Promise<Void> {
2021-03-04 03:50:13 +01:00
guard Storage.shared.getUser()?.name != nil,
let configurationMessage = ConfigurationMessage.getCurrent() else { return Promise.value(()) }
let destination = Message.Destination.contact(publicKey: getUserHexEncodedPublicKey())
let (promise, seal) = Promise<Void>.pending()
2021-01-13 06:10:06 +01:00
Storage.writeSync { transaction in
MessageSender.send(configurationMessage, to: destination, using: transaction).done {
seal.fulfill(())
}.catch { _ in
seal.fulfill(()) // Fulfill even if this failed; the configuration in the swarm should be at most 2 days old
}.retainUntilComplete()
}
return promise
}
@objc func startClosedGroupPoller() {
guard OWSIdentityManager.shared().identityKeyPair() != nil else { return }
ClosedGroupPoller.shared.start()
}
@objc func stopClosedGroupPoller() {
ClosedGroupPoller.shared.stop()
}
@objc func getAppModeOrSystemDefault() -> AppMode {
let userDefaults = UserDefaults.standard
2021-08-18 01:56:28 +02:00
if userDefaults.dictionaryRepresentation().keys.contains("appMode") {
let mode = userDefaults.integer(forKey: "appMode")
return AppMode(rawValue: mode) ?? .light
} else {
if #available(iOS 13.0, *) {
return UITraitCollection.current.userInterfaceStyle == .dark ? .dark : .light
} else {
return .light
}
}
}
}