Нет голосовой связи при потоковой передаче вызова с использованием CallKit - PullRequest
0 голосов
/ 28 декабря 2018

Я пытался позвонить с добавочного номера 100 (приложение Linphone) на номер 102 (мое приложение).Внутренний номер 102 показал экран входящего вызова, а затем нажал кнопку «Принять», после чего добавочный номер 100 начинает разговаривать с добавочным номером 102, но добавочный номер 102 не может слышать что-либо от 100, а также добавочный номер 100 также не может слышать от 102.

Я думаю, что проблема из-за приложения.Но я не знаю, что не так с моим приложением.

Эти функции я объявил в appdelegate файле для обработки входящего вызова

let callKitManager = CallKitCallInit(uuid: UUID(), handle: "")

lazy var providerDelegate: ProviderDelegate = ProviderDelegate(callKitManager: self.callKitManager)


func displayIncomingCall(uuid: UUID, handle: String, completion: ((NSError?) -> Void)?) {
    providerDelegate.reportIncomingCall(uuid: uuid, handle: handle, completion: completion)
}

Это ProviderDelegate файл

extension ProviderDelegate: CXProviderDelegate {

func providerDidReset(_ provider: CXProvider) {
    print("Stop Audio ==STOP-AUDIO==")

    for call in callKitManager.calls {
        call.end(uuid: UUID())
    }

    callKitManager.removeAllCalls()
}

func provider(_ provider: CXProvider, perform action: CXAnswerCallAction) {

    guard let call = callKitManager.callWithUUID(uuid: action.callUUID) else {
        action.fail()
        return
    }

    configureAudioSession()

    call.answer()

    action.fulfill()

}

func provider(_ provider: CXProvider, perform action: CXEndCallAction) {

    guard let call = callKitManager.callWithUUID(uuid: action.callUUID) else {
        action.fail()
        return
    }


    print("Stop audio ==STOP-AUDIO==")
    configureAudioSession()

    call.end(uuid: action.callUUID)


    action.fulfill()

    callKitManager.remove(call: call)
}


func provider(_ provider: CXProvider, didActivate audioSession: AVAudioSession) {
    print("Starting audio ==STARTING-AUDIO==")
}


func provider(_ provider: CXProvider, didDeactivate audioSession: AVAudioSession) {
    print("Received \(#function)")
}

func configureAudioSession() {
    let session = AVAudioSession.sharedInstance()
    do {
        try? session.setCategory(AVAudioSessionCategoryPlayAndRecord)
        try? session.setMode(AVAudioSessionModeVoiceChat)
        try? session.setPreferredSampleRate(44100.0)
        try? session.setPreferredIOBufferDuration(0.005)
        try? session.setActive(true)
    } 

    }
 }

class ProviderDelegate: NSObject {

fileprivate let callKitManager: CallKitCallInit
fileprivate let provider: CXProvider

init(callKitManager: CallKitCallInit) {
    self.callKitManager = callKitManager

    provider = CXProvider(configuration: type(of: self).providerConfiguration)

    super.init()

    provider.setDelegate(self, queue: nil)

}


static var providerConfiguration: CXProviderConfiguration {
    let providerConfiguration = CXProviderConfiguration(localizedName: "vKclub")

    providerConfiguration.supportsVideo = false
    providerConfiguration.maximumCallsPerCallGroup = 1
    providerConfiguration.supportedHandleTypes = [.phoneNumber]
    return providerConfiguration
}

func reportIncomingCall(uuid: UUID, handle: String, hasVideo: Bool = false, completion: ((NSError?) -> Void)?) {

    print("This is UUID === ", uuid)
    configureAudioSession()
    let update = CXCallUpdate()
    update.remoteHandle = CXHandle(type: .phoneNumber, value: handle)
    update.hasVideo = hasVideo


    provider.reportNewIncomingCall(with: uuid, update: update) { error in


        if error == nil {
            // 3.
            self.configureAudioSession()
            let call = CallKitCallInit(uuid: uuid, handle: handle)
            self.callKitManager.add(call: call)
            lastCallUUID = uuid
            print("UUID === ", uuid)
        } else {

        }

        // 4.
        completion?(error as NSError?)
    }


}

}

...