mirror of
https://github.com/oxen-io/session-ios.git
synced 2023-12-13 21:30:14 +01:00
75 lines
2.8 KiB
Swift
75 lines
2.8 KiB
Swift
//
|
|
// Copyright (c) 2018 Open Whisper Systems. All rights reserved.
|
|
//
|
|
|
|
import Foundation
|
|
import SignalServiceKit
|
|
import SignalMessaging
|
|
|
|
class DebugUICalling: DebugUIPage {
|
|
|
|
// MARK: Dependencies
|
|
|
|
var messageSender: MessageSender {
|
|
return SSKEnvironment.shared.messageSender
|
|
}
|
|
|
|
// MARK: Overrides
|
|
|
|
override func name() -> String {
|
|
return "Calling"
|
|
}
|
|
|
|
override func section(thread aThread: TSThread?) -> OWSTableSection? {
|
|
guard let thread = aThread as? TSContactThread else {
|
|
owsFailDebug("Calling is only valid for contact thread, got thread: \(String(describing: aThread))")
|
|
return nil
|
|
}
|
|
|
|
let sectionItems = [
|
|
OWSTableItem(title: "Send 'hangup' for old call") { [weak self] in
|
|
guard let strongSelf = self else { return }
|
|
|
|
let kFakeCallId = UInt64(12345)
|
|
var hangupMessage: SSKProtoCallMessageHangup
|
|
do {
|
|
let hangupBuilder = SSKProtoCallMessageHangup.builder(id: kFakeCallId)
|
|
hangupMessage = try hangupBuilder.build()
|
|
} catch {
|
|
owsFailDebug("could not build proto")
|
|
return
|
|
}
|
|
let callMessage = OWSOutgoingCallMessage(thread: thread, hangupMessage: hangupMessage)
|
|
|
|
strongSelf.messageSender.sendPromise(message: callMessage).done {
|
|
Logger.debug("Successfully sent hangup call message to \(thread.contactIdentifier())")
|
|
}.catch { error in
|
|
Logger.error("failed to send hangup call message to \(thread.contactIdentifier()) with error: \(error)")
|
|
}.retainUntilComplete()
|
|
},
|
|
OWSTableItem(title: "Send 'busy' for old call") { [weak self] in
|
|
guard let strongSelf = self else { return }
|
|
|
|
let kFakeCallId = UInt64(12345)
|
|
var busyMessage: SSKProtoCallMessageBusy
|
|
do {
|
|
let busyBuilder = SSKProtoCallMessageBusy.builder(id: kFakeCallId)
|
|
busyMessage = try busyBuilder.build()
|
|
} catch {
|
|
owsFailDebug("Couldn't build proto")
|
|
return
|
|
}
|
|
|
|
let callMessage = OWSOutgoingCallMessage(thread: thread, busyMessage: busyMessage)
|
|
|
|
strongSelf.messageSender.sendPromise(message: callMessage).done {
|
|
Logger.debug("Successfully sent busy call message to \(thread.contactIdentifier())")
|
|
}.catch { error in
|
|
Logger.error("failed to send busy call message to \(thread.contactIdentifier()) with error: \(error)")
|
|
}.retainUntilComplete()
|
|
}
|
|
]
|
|
|
|
return OWSTableSection(title: "Call Debug", items: sectionItems)
|
|
}
|
|
}
|