Собственный сотовый вызов не работает при входящем вызове VOIP в iOS 13 - PullRequest
0 голосов
/ 26 сентября 2019

Я реализовал набор вызовов для аудио- и видеозвонков с помощью push-набора VOIP в iOS, и он отлично работает в iOS 12 и предыдущих версиях, а также нормально работает в iOS 13 и 13.1.

Но происходит сбой в 2 сценариях:

1) Наше приложение находится в состоянии переднего плана: когда выполняется сотовый вызов и принимается VOIP push, то экран входящих вызовов Call Kit отображается в течение 5 - 10 секунд, а затемСотовые и VOIP-вызовы не выполняются с предупреждением «Call Failed».

2) Наше приложение находится в фоновом режиме или в состоянии Kill: когда выполняется сотовый вызов и принимается VOIP push, то и сотовые вызовы, и VOIP-вызовы не работают сОповещение "Ошибка вызова".В этот раз интерфейс входящего вызова не отображается.

Я показываю свой код здесь:

- (void)registerAppForVOIPPush {

    PKPushRegistry *pushRegistry = [[PKPushRegistry alloc] initWithQueue:dispatch_get_main_queue()];
    pushRegistry.delegate = self;
    pushRegistry.desiredPushTypes = [NSSet setWithObject:PKPushTypeVoIP];
}

Затем нажмите делегатов

#pragma mark PKPushRegistryDelegate ----

- (void)pushRegistry:(PKPushRegistry *)registry didUpdatePushCredentials: (PKPushCredentials *)credentials forType:(NSString *)type {

    NSString *newToken = [self hexadecimalStringFromData:credentials.token];
    //Make a note of this token to a server to send VOIP for a particular device
    NSLog(@"VOIP token ::: %@", newToken);
    _voipToken = newToken;
}

- (void)pushRegistry:(PKPushRegistry *)registry didReceiveIncomingPushWithPayload:(PKPushPayload *)payload forType:(PKPushType)type {
    //available(iOS, introduced: 8.0, deprecated: 11.0)
    [self pushRegistryDidReceivedPushWithPayload:payload forType:type withCompletionHandler:NULL];
}

- (void)pushRegistry:(PKPushRegistry *)registry didReceiveIncomingPushWithPayload:(PKPushPayload *)payload forType:(PKPushType)type withCompletionHandler:(void (^)(void))completion {
    //available(iOS 11.0, *)
    [self pushRegistryDidReceivedPushWithPayload:payload forType:type withCompletionHandler:completion];
}

- (void)pushRegistryDidReceivedPushWithPayload:(PKPushPayload *)payload forType:(PKPushType)type withCompletionHandler:(void (^)(void))completion {

    //Call kit configration
    CXProviderConfiguration *providerConfig = [[CXProviderConfiguration alloc] initWithLocalizedName:@"my app Call"];
    providerConfig.supportsVideo = NO;
    providerConfig.maximumCallGroups = 1;
    providerConfig.maximumCallsPerCallGroup = 1;
    providerConfig.supportedHandleTypes = [[NSSet alloc] initWithObjects:[NSNumber numberWithInteger:CXHandleTypeGeneric], nil];
    providerConfig.iconTemplateImageData = UIImagePNGRepresentation([UIImage imageNamed:@"IconMask"]);


    CXProvider *provider = [[CXProvider alloc] initWithConfiguration:providerConfig];
    [provider setDelegate:self queue:nil];

    //generate token
    NSUUID *callbackUUIDToken = [NSUUID UUID];

    //Display callkit

    NSString *uniqueIdentifier = @"Max test";
    CXCallUpdate *update = [[CXCallUpdate alloc] init];
    update.remoteHandle = [[CXHandle alloc] initWithType:CXHandleTypeGeneric value:uniqueIdentifier];
    update.supportsGrouping = FALSE;
    update.supportsUngrouping = FALSE;
    update.supportsHolding = FALSE;
    update.localizedCallerName = uniqueIdentifier;
    update.hasVideo = NO;
    [provider reportNewIncomingCallWithUUID:callbackUUIDToken update:update completion:^(NSError * _Nullable error) {
        NSLog(@"reportNewIncomingCallWithUUID error: %@",error);
    }];

    if (completion) {
        dispatch_async(dispatch_get_main_queue(), ^{
            completion();
        });
    }
}

Я отлично реализовал метод делегата поставщика

- (void)provider:(CXProvider *)provider performAnswerCallAction:(CXAnswerCallAction *)action{
    [action fulfill];
}

- (void)provider:(CXProvider *)provider performEndCallAction:(CXEndCallAction *)action{
    [action fulfill];
}

, а также управлял другими методами делегатов для управления вызовами и всем прочим, и он отлично работает в любых условиях.

Я проверил эти 2 сценария с другими приложениями, такими как Google Duo, Whatsapp иЛицо время, и он показывает call-kit правильно, без сбоев, и в моем приложении это не сработало.Я понятия не имею, где это происходит.

Итак, у меня есть эти 2 заявленные проблемы для iOS 13 и более поздних версий.Любая помощь будет оценена.Спасибо.

1 Ответ

2 голосов
/ 26 сентября 2019

Это, вероятно, ошибка iOS 13, и, если вы еще этого не сделали, вы должны сообщить об этом в Apple.

Я думаю, что причина, по которой такие приложения, как Whatapp (и та, которую я разрабатываю)работаем, это то, что мы создаем приложение против iOS 12 SDK.Мы делаем это из-за ограничений push-уведомлений VoIP, введенных в iOS 13. Итак, вы можете попытаться обойти эту проблему - по крайней мере до апреля 2020 года - используя iOS 12 SDK.Надеюсь, Apple, мы скоро исправим эту проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...